Dubbo supports an automatic instance discovery mechanism based on a registry center, where Dubbo providers register instance addresses to the registry center, and Dubbo consumers automatically obtain the latest instance changes by subscribing to changes in the registry center, ensuring that traffic is always forwarded to the correct nodes. Dubbo currently supports various registry centers such as Nacos, Zookeeper, and Kubernetes Service.
The following are some mainstream registry center implementations for Dubbo service discovery. For more extended implementations and working principles, please refer to Registry Center Reference Manual.
| Registry Center | Configuration Value | Service Discovery Model | Supports Authentication | spring-boot-starter | 
|---|---|---|---|---|
| Nacos | nacos | Application-level, Interface-level | Yes | dubbo-nacos-spring-boot-starter | 
| Zookeeper | zookeeper | Application-level, Interface-level | Yes | - dubbo-zookeeper-spring-boot-starter - dubbo-zookeeper-curator5-spring-boot-starter | 
| Kubernetes Service | Refer to the standalone usage documentation | Application-level | Yes | None | 
If your service requires warm-up time, such as initializing cache or waiting for resources to be ready, you can use the delay parameter for delayed registration. In a Spring application, delay = n(n > 0) means that the delay time starts from when the Spring context is initialized.
@DubboService(delay = 5000)
public class DemoServiceImpl implements DemoService {
}
With the above configuration, the application will delay exposing this service for 5 seconds (registering the service to the registry center 5 seconds after application startup). Alternatively, you can configure a global default value to allow all services to register after a 5-second delay:
dubbo:
  provider:
    delay: 5000
By configuring delay = -1, you can prevent the framework from automatically publishing the service to the registry center until the user manually completes the publication through commands like online. This feature can be used with deployment systems to achieve graceful service online management, giving users better control over timing. The specific configuration is as follows:
dubbo:
  provider:
    delay: -1
  application:
    manual-register: true
By controlling the timing of service instance publication to and removal from the registry center, each instance can handle all ongoing requests smoothly, preventing traffic loss during deployment. The recommended sequence for online and offline operations is as follows:
Configure instance address delayed (or manual) registration, for details refer to the previous section on delayed registration configuration.
Upon receiving new registered address instances, the consumer side will warm up the new instance by allocating a small portion of traffic to it at a certain ratio, gradually increasing the ratio until it is on par with other instances.
The calculation for warming up mainly involves two factors: the instance startup time timestamp and the total duration of warm-up warmup, which can be set via the warmup parameter. The calculation formula is similar:

The recommended steps for graceful offline are as follows:
kill pid. The framework will sequentially check the following:10000 milliseconds, adjustable through -Ddubbo.service.shutdown.wait=20000.In some scenarios, you may need to control the timing of address registration and removal in code. This can be achieved by calling the following code:
Dubbo supports configuring multiple registry centers within the same application. A single service or a group of services can be registered to multiple registry centers simultaneously, and a single service or a group of services can subscribe to addresses from multiple centers at the same time. For subscribers, it can also specify how to call addresses from multiple registry centers (prioritizing one registry center or other strategies).
To specify one or more global default registry centers, all services will default to register to or subscribe to the configured registry centers:
dubbo
 registries
  beijingRegistry
   register-mode: instance # New users are advised to use this; old users should remove this configuration if they wish to continue using the old service discovery model
   address: zookeeper://localhost:2181
  shanghaiRegistry
   register-mode: instance # New users are advised to use this; old users should remove this configuration if they wish to continue using the old service discovery model
   address: zookeeper://localhost:2182
To specify that a certain service registers to multiple registry centers:
@DubboService(registry = {"beijingRegistry"})
public class DemoServiceImpl implements DemoService {}
To specify that a certain service subscribes to addresses from multiple registry centers:
@DubboReference(registry = {"beijingRegistry"})
private DemoService demoService
For more configuration and usage scenarios regarding multiple registries, please refer to 【Reference Manual - Registry Center - Multiple Registries】
While Dubbo 3 is compatible with Dubbo 2’s interface-level service discovery, it defines a new application-level service discovery model. For their meanings and working principles, please refer to Application-level Service Discovery. Dubbo 3 has the capability to automatically negotiate the service discovery model, allowing old Dubbo 2 users to seamlessly upgrade to Dubbo 3.
If you are a new user of Dubbo, it is strongly recommended to add the following configuration item to clearly instruct the framework to use application-level service discovery:
dubbo:
  registry:
    address: "nacos://127.0.0.1:8848"
    register-mode: instance # New users should set this value to enable application-level service discovery; optional values are interface, instance, all
Old users are advised to refer to the Application-Level Service Discovery Migration Guide for a smooth migration.
If there are two mirrored environments and two registry centers, with a service deployed only on one registry center and not yet deployed on the other, while other applications in both registry centers require this service, the service provider can register the service only to the other registry center without subscribing to the service from the other registry center. This mechanism is typically used in scenarios where the provider is relatively static and unlikely to change, or in scenarios where providers and consumers are mutually independent.
dubbo:
  registry:
    subscribe: false
To facilitate development and testing, it is common to share a single registry center available for all services in a local environment. In this case, if a service provider being developed registers, it may affect the consumers’ normal operation. You can allow the service provider to only subscribe to services (since the developed service may depend on others) without registering the service being developed, by directly connecting to the tested service.

dubbo:
  registry:
    register: false
Control permissions through token verification at the registry center to determine whether to issue tokens to consumers, which can prevent consumers from bypassing the registry center to access providers. Additionally, the authorization method can be flexibly changed through the registry center without modifying or upgrading the providers.

Add the following configuration:
dubbo:
  provider:
    token: true #UUID
or
dubbo:
  provider:
    token: 123456
When the service provider starts, the Dubbo framework will automatically scan the available network device addresses on the local machine and register one of the valid IP addresses to the registry center. The scanning follows these principles or order:
In cases with multiple network devices, Dubbo will randomly choose one. If the registered IP address does not meet expectations, you can specify the address in the following ways.
-Ddubbo.network.interface.preferred=eth0.DUBBO_IP_TO_REGISTRY=30.5.10.11Finally, you can also specify the TCP listening address in the protocol configuration, as the listening address will be defaulted for sending to the registry center
dubbo:
  protocol:
    name: dubbo
    port: 20880
    host: 30.5.10.11 # It can also be a domain name, e.g., dubbo.apache.org
0.0.0.0:20880. If a host is specified, the framework will instead listen at 30.5.10.11:20880.By default, Dubbo checks during startup whether the dependent services are available. If they are not available (where the address list is empty), it will throw an exception, preventing the application from initializing to identify problems early during the online procedure. The default is check="true".
You can disable the check with check="false". For instance, during testing, some services may not be relevant, or circular dependencies may require one party to start first. Note that if check="false" and there are no available addresses at startup, there will always be a normal RPC reference returned, but initiating a call will result in a “No available addresses” exception. The RPC application will become available again when the service address list is restored.
1. Usage Scenarios
check=false)check=false)Check is only for startup checking; if there are corresponding dependencies during runtime, an error will still be thrown.
2. Configuration Method
@DubboReference(check = false)
private DemoService demoService;
dubbo:
  consumer:
    check: false
In addition to checking the consumer-side address list, Dubbo also supports connectivity checks with the registry center. By default, if the provider or consumer cannot connect to the registry center during the startup phase, the process startup will fail.
You can disable the registry center’s startup check so that even if the registry center connection fails, the process will continue to start normally. The framework will log all failed registration and subscription actions, and after the registry center connection is restored, it will attempt to re-register and subscribe until all failed events succeed.
dubbo:
  registry:
    check: false
When a service attempts to subscribe to addresses at the registry center, the registry center should synchronously return the current available address list. If it fails to read the available address list due to network issues, the framework will query the locally cached registry center addresses and return them (if you do not want to use cached addresses, you can set check=true to fail fast and throw an exception). Failed subscription actions will be placed in a retry queue, regularly retrying until successful to ensure that the latest address list can be read promptly after fault recovery.
The default storage path for the registry center cache file is: ${HOME}/.dubbo/dubbo-registry-{application-name}-{address}.cache, which will be refreshed periodically at certain intervals.
If local file caching is not required, you can disable it using the following configuration:
dubbo:
  registry:
    file-cache: false
When the link between the Dubbo process and the registry center is interrupted, the Dubbo framework will automatically attempt to recover and ensure that after the link is restored, all registered or subscribed services are restored to normal.
The Dubbo consumer process can automatically track the availability of provider instances through TCP links. When an instance is detected as unavailable, the consumer side will automatically move the unavailable instance to the unavailable address pool to ensure that normal service calls are not affected. Dubbo will automatically detect the blacklisted unavailable address pool, and when the TCP link is restored, automatically remove it from the unavailable address pool.
Empty push protection is for the consumer side. When empty push protection is enabled, the consumer process will ignore empty address events pushed from the registry center (it will continue to retain the current list of addresses in memory). This is to prevent clearing the registry center’s address list in some abnormal scenarios, leading to service call failures.
Empty push protection is disabled by default and can be enabled as follows:
dubbo:
  registry:
    enableEmptyProtection: true
If your project has service discovery enabled but you want to call a specific IP during testing, you can bypass the service discovery mechanism by setting the target IP address to direct connection mode.
Unlike RPC direct connectivity calls from client to server, enabling service discovery often encounters various strange call failure issues. Here are some common problems and troubleshooting methods.
check=false is configured, although the process starts successfully, service registration and subscription may not have succeeded.@DubboReference(check=false).