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注解即可