Nacos初探

2020/05/21 SpringCloud

Nacos主要用于动态服务发现、服务配置、服务元数据以及流量管理。并且Nacos计划在2.0版本解决Spring Cloud与Kubernetes的”服务发现”和”配置 管理”的鸿沟,这是比较期待的。[]https://nacos.io/zh-cn/docs/what-is-nacos.html

Nacos是什么?

服务(Service)是 Nacos 世界的一等公民。Nacos 支持几乎所有主流类型的“服务”的发现、配置和管理,包括k8s,gRpc,Dubbo,Spring Cloud等。 关键特性主要有:

  • 服务发现和服务健康监测
  • 动态配置服务
  • 动态DNS服务
  • 服务及其元数据管理
Nacos与Spring Cloud

笔者采用的SpringCloud版本是Greenwich.SR2,所以对应的Nacos版本是2.1.2.RELEASE。详情见[]https://github.com/spring-cloud-incubator/spring-cloud-alibaba/wiki/%E7%89%88%E6%9C%AC%E8%AF%B4%E6%98%8E

启动Nacos server
  • clone项目
    git clone https://github.com/nacos-group/nacos-docker.git
    cd nacos-docker
    
  • 采用单机模式Mysql模式
    docker-compose -f example/standalone-mysql-5.7.yaml up -d 
    
  • 若不想下载也可以采用我编写的docker-compose.yaml文件
    version: '3'
    services:
    nacos:
      image: nacos/nacos-server:1.2.1
      container_name: nacos-standalone
      environment:
        - PREFER_HOST_MODE=hostname
        - MODE=standalone
      volumes:
        - ../data/nacos-server/logs/:/home/nacos/logs
      ports:
        - "8848:8848"
    
  • ui页面查看 nacos链接 []http://localhost:8848/nacos 默认账号密码: nacos nacos
添加依赖
            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-alibaba-dependencies</artifactId>
                <version>2.1.2.RELEASE</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>

            <!--nacos服务发现-->
            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
                <version>${nacos-discovery.version}</version>
            </dependency>
             <!--nacos配置-->
            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
                <version>${nacos-config.version}</version>
            </dependency>
yml文件中配置
spring
  cloud:
    nacos:
      discovery:
        server-addr: http://127.0.0.1:8848
      config:
        server-addr: http://127.0.0.1:8848
        file-extension: yaml
通过Spring Cloud 原生注解 @EnableDiscoveryClient开启服务注册发现功能
@SpringBootApplication
@EnableDiscoveryClient
public class NacosProviderApplication {

	public static void main(String[] args) {
		SpringApplication.run(NacosProviderApplication.class, args);
	}

	@RestController
	class EchoController {
		@RequestMapping(value = "/echo/{string}", method = RequestMethod.GET)
		public String echo(@PathVariable String string) {
			return "Hello Nacos Discovery " + string;
		}
	}
}
配置服务消费者
@SpringBootApplication
@EnableDiscoveryClient
public class NacosConsumerApplication {

    @LoadBalanced
    @Bean
    public RestTemplate restTemplate() {
        return new RestTemplate();
    }

    public static void main(String[] args) {
        SpringApplication.run(NacosConsumerApplication.class, args);
    }

    @RestController
    public class TestController {

        private final RestTemplate restTemplate;

        @Autowired
        public TestController(RestTemplate restTemplate) {this.restTemplate = restTemplate;}

        @RequestMapping(value = "/echo/{str}", method = RequestMethod.GET)
        public String echo(@PathVariable String str) {
            return restTemplate.getForObject("http://service-provider/echo/" + str, String.class);
        }
    }
}

官方采用的RestTemplate实现服务间的远程调用,若习惯使用Feign也是可以的,笔者亲测可行。

配置动态刷新

添加@RefreshScope注解即可

Search

    Table of Contents