mirror of
https://github.com/google/nomulus.git
synced 2025-07-22 02:36:03 +02:00
This enables sharded DNS publishing on a per-TLD basis. Instead of a TLD-wide lock, the sharded scheme locks each update on the shard number, allowing parallel writes to DNS. We allow N (the number of shards) to be 0 or 1 for no sharding, and N > 1 for an N-way sharding scheme. Unless explicitly set, all TLDs default to a numShards of 0, so we don't have to reload all registry objects explicitly. WARNING: This will change the lock name upon deployment for the PublishDnsAction from "<TLD> Dns Updates" to "<TLD> Dns Updates shard 0". This may cause concurrency issues if the underlying DNSWriter is not parallel-write tolerant (currently all production usages are ZonemanWriter, which is parallel-tolerant, so no issues are expected). ------------- Created by MOE: https://github.com/google/moe MOE_MIGRATED_REVID=187525655
45 lines
1.3 KiB
Text
45 lines
1.3 KiB
Text
package(
|
|
default_testonly = 1,
|
|
default_visibility = ["//java/google/registry:registry_project"],
|
|
)
|
|
|
|
licenses(["notice"]) # Apache 2.0
|
|
|
|
load("//java/com/google/testing/builddefs:GenTestRules.bzl", "GenTestRules")
|
|
|
|
java_library(
|
|
name = "dns",
|
|
srcs = glob(["*.java"]),
|
|
resources = glob(["testdata/*.txt"]),
|
|
deps = [
|
|
"//java/google/registry/config",
|
|
"//java/google/registry/cron",
|
|
"//java/google/registry/dns",
|
|
"//java/google/registry/dns:constants",
|
|
"//java/google/registry/dns/writer",
|
|
"//java/google/registry/model",
|
|
"//java/google/registry/module/backend",
|
|
"//java/google/registry/request",
|
|
"//java/google/registry/request/lock",
|
|
"//java/google/registry/util",
|
|
"//javatests/google/registry/testing",
|
|
"//third_party/objectify:objectify-v4_1",
|
|
"@com_google_appengine_api_1_0_sdk//:testonly",
|
|
"@com_google_appengine_api_stubs",
|
|
"@com_google_code_findbugs_jsr305",
|
|
"@com_google_dagger",
|
|
"@com_google_guava",
|
|
"@com_google_truth",
|
|
"@com_google_truth_extensions_truth_java8_extension",
|
|
"@javax_servlet_api",
|
|
"@joda_time",
|
|
"@junit",
|
|
"@org_mockito_all",
|
|
],
|
|
)
|
|
|
|
GenTestRules(
|
|
name = "GeneratedTestRules",
|
|
test_files = glob(["*Test.java"]),
|
|
deps = [":dns"],
|
|
)
|