When Dubbo uses version
3.0.0or higher, Nacos version2.0.0or higher is required.
The steps to integrate Dubbo with Nacos as a metadata center are very simple, mainly divided into adding Maven dependency and configuring metadata center.
If the metadata address (dubbo.metadata-report.address) is also not configured, the address of the registry will be used as the metadata center.
If the project has already enabled Nacos as the registry, no additional configuration is needed.
If Nacos registry has not been enabled, please refer to Adding Nacos Dependency for Registry.
<dubbo:metadata-report address="nacos://127.0.0.1:8848"/>
or
dubbo
  metadata-report
    address: nacos://127.0.0.1:8848
or
dubbo.metadata-report.address=nacos://127.0.0.1:8848
or
MetadataReportConfig metadataConfig = new MetadataReportConfig();
metadataConfig.setAddress("nacos://127.0.0.1:8848");
For the format of address, please refer to Nacos Registry - Enable Configuration.
For complete configuration parameters, please refer to metadata-report-config.
You can see the operational metadata information related to registered service providers and consumers on the Nacos console:

In Nacos, the concept of a configuration center exists, which is suitable for metadata storage. Under the configuration center scenario, there is the concept of a namespace. Under the namespace, there is also a group concept. That is, a configuration item is located through the namespace, group, and dataId. If the namespace is not specified, public is used as the default namespace.
Provider: namespace: 'public', dataId: '{service name}:{version}:{group}:provider:{application name}', group: 'dubbo'
Consumer: namespace: 'public', dataId: '{service name}:{version}:{group}:consumer:{application name}', group: 'dubbo'
When version or group does not exist, : is still retained:
Provider: namespace: 'public', dataId: '{service name}:::provider:{application name}', group: 'dubbo'
Consumer: namespace: 'public', dataId: '{service name}:::consumer:{application name}', group: 'dubbo'
Providers interface metadata details (controlled by report-definition=true):

Consumers interface information details (controlled by report-consumer-definition=true, default false):

As mentioned above, the service name and application name may be one-to-many. In Nacos, a single key-value is used for storage, with multiple application names separated by commas. Since data is stored as a single key-value, there may be concurrent overwrite issues in the case of multiple clients. Therefore, we use the publishConfigCas capability in Nacos to solve this problem. In Nacos, using publishConfigCas requires the user to provide a parameter casMd5, which is the md5 value of the previous configuration content. Different clients check the content value of Nacos before updating to compute the md5 value, which serves as a local credential. During the update, the credential md5 is sent to the server for comparison. If the values do not match, it indicates that it has been modified by another client during this time, requiring the credential to be retrieved again for a retry (CAS). Currently, if the retry fails 6 times, the mapping update action will be abandoned.
Nacos API:
ConfigService configService = ...
configService.publishConfigCas(key, group, content, ticket);
Mapping information is located in namespace: ‘public’, dataId: ‘{service name}’, group: ‘mapping’.

To enable remote interface configuration metadata registration, the following configuration must be added to the application, as by default, Dubbo3 application-level service discovery enables service introspection mode and does not register data to the metadata center.
 dubbo.application.metadata-type=remote
Or, enable centralized metadata registration even in introspection mode:
dubbo.application.metadata-type=local
dubbo.metadata-report.report-metadata=true
The detailed metadata information in the Nacos server is as follows:
