Nacos push domain with CoreDNS
Nacos DNS user guide
This plugin provides a DNS-F client based on CoreDNS, which can help export those registed services on Nacos as DNS domain. DNS-F client is a dedicated agent process(side car) beside the application’s process to foward the service discovery DNS domain query request to Nacos.
Quick Start
To build and run nacos coredns plugin, the OS must be Linux or Mac. And also, make sure your nacos version is 2.2 or higher and golang version is 1.17 or higher. And golang environments(GOPATH,GOROOT,GOHOME) must be configured correctly. Because it needs to support the gRPC connection feature of the nacos2.x version and the go mod function.
Build
Configuration
To run nacos coredns plugin, you need a configuration file. A possible file may be as bellow:
- forward: domain names those not registered in nacos will be forwarded to upstream.
- nacos_namespaceId: nacos namespaceId, defalut is public.
- nacos_server_host: Ip and Port of nacos server, seperated by comma if there are two or more nacos servers
Run
- Firstly, you need to deploy nacos server. Here
- Secondly, register service on nacos.
- Finally, configure the file ($path_to_corefile) and the port ($dns_port) to run the plugin.
Test
Input the service name ($nacos_service_name) , and the plugin’s IP address ($dns_ip) and port ($dns_port) . We can get the DNS answer from the plugin.