赞
踩
服务发现和服务健康监测
可以作为微服务的注册中心,为其他的微服务提供注册与发现
动态配置服务
可以对配置文件进行动态的刷新
pom文件
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.3.2.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <groupId>org.example</groupId> <artifactId>nacos-study</artifactId> <packaging>pom</packaging> <version>1.0-SNAPSHOT</version> <modelVersion>4.0.0</modelVersion> <artifactId>config</artifactId> <properties> <nacos-config-spring-boot.version>0.2.1</nacos-config-spring-boot.version> </properties> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency> <dependency> <groupId>com.alibaba.boot</groupId> <artifactId>nacos-config-spring-boot-starter</artifactId> <version>${nacos-config-spring-boot.version}</version> </dependency> <dependency> <groupId>com.alibaba.boot</groupId> <artifactId>nacos-config-spring-boot-actuator</artifactId> <version>${nacos-config-spring-boot.version}</version> </dependency> </dependencies> </project>
配置文件application.yml
nacos:
config:
server-addr: 127.0.0.1:8848
server:
port: 8080
ConfigApplication启动类
@SpringBootApplication
// 加载dataId为 example的配置源,并开启自动更新
@NacosPropertySource(dataId = "example", autoRefreshed = true, groupId = "DEFAULT_GROUP")
public class ConfigApplication {
public static void main(String[] args) {
SpringApplication.run(ConfigApplication.class, args);
}
}
ConfigController
@Controller
@RequestMapping("/config")
public class ConfigController {
@NacosValue(value = "${useLocalCache:false}",autoRefreshed = true)
private boolean useLocalCache;
@RequestMapping("/get")
@ResponseBody
public boolean get(){
return useLocalCache;
}
}
配置到这里基本完成,然后启动服务 接来下所有的请求调用,全部都使用postman来完成 获取刚刚自定义的配置
http://localhost:8080/config/get 此时发现得到的返回值为false 然后调用Nacos的Api,来动态修改这个配置,注意这里请求方式必须为POST
http://127.0.0.1:8848/nacos/v1/cs/configs?dataId=example&group=DEFAULT_GROUP&content=useLocalCache=true
结果返回true,表示调用成功 这时我们再次调用上面获取配置的接口
http://localhost:8080/config/get 发现返回值以及是true,表示动态刷新成功了
pom文件
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.3.2.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <groupId>org.example</groupId> <artifactId>nacos-study</artifactId> <packaging>pom</packaging> <version>1.0-SNAPSHOT</version> <modelVersion>4.0.0</modelVersion> <artifactId>discovery</artifactId> <properties> <nacos-discovery-spring-boot.version>0.2.1</nacos-discovery-spring-boot.version> </properties> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>com.alibaba.boot</groupId> <artifactId>nacos-discovery-spring-boot-starter</artifactId> <version>${nacos-discovery-spring-boot.version}</version> </dependency> </dependencies> </project>
application.yml配置文件
nacos:
discovery:
server-addr: 127.0.0.1:8848
server:
port: 8081
DiscoveryApplication启动类
@SpringBootApplication
public class DiscoveryApplication {
public static void main(String[] args){
SpringApplication.run(DiscoveryApplication.class, args);
}
}
通过NamingService来获取指定名称注册的实例信息
@RestController
@RequestMapping("/discovery")
public class DiscoveryController {
@NacosInjected
private NamingService namingService;
@RequestMapping("/get")
public List<Instance> get(@RequestParam String serviceName) throws NacosException {
return namingService.getAllInstances(serviceName);
}
}
此时我们来获取一个名字为discovery实例的信息
http://localhost:8081/discovery/get?serviceName=discovery
发现返回值为空,因为我们还没有主动的去向Nacos服务端注册discovery实例的信息
我们通过下面的API来注册实例,注意请求方式必须为PUT
http://127.0.0.1:8848/nacos/v1/ns/instance?serviceName=discovery&ip=127.0.0.1&port=8081
此时在调用上面的查询API,就能看到对应的数据了
pom文件
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.3.2.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <groupId>org.example</groupId> <artifactId>nacos-study</artifactId> <packaging>pom</packaging> <version>1.0-SNAPSHOT</version> <modelVersion>4.0.0</modelVersion> <artifactId>spring-cloud</artifactId> <properties> <spring-boot.version>2.3.2.RELEASE</spring-boot.version> <spring-cloud.version>Hoxton.SR7</spring-cloud.version> </properties> <dependencies> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId> <version>2.2.1.RELEASE</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> </dependencies> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-dependencies</artifactId> <version>${spring-boot.version}</version> <type>pom</type> <scope>import</scope> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <version>${spring-cloud.version}</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> </project>
bootstrap.yaml配置文件
server:
port: 8082
spring:
application:
name: cloudConfig
cloud:
nacos:
config:
server-addr: 127.0.0.1:8848
file-extension: yaml
CloudConfigApplication启动类
@SpringBootApplication
public class CloudConfigApplication {
public static void main(String[] args) {
SpringApplication.run(CloudConfigApplication.class, args);
}
}
ConfigController测试类
@RestController @RequestMapping("/config") @RefreshScope public class ConfigController { /** * 这里备注一下,如果配置文件为yaml格式的,在调用刷新配置文件接口的时候 * http://127.0.0.1:8848/nacos/v1/cs/configs?dataId=cloudConfig.yaml&group=DEFAULT_GROUP&content=useLocalCache=true * * 在最后那里,因为yaml配置文件里面参数和冒号“:”中间有一个空格,所有这里也要加一个空格,并且,等于符号也要改成冒号“:”要改成下面这样 * http://127.0.0.1:8848/nacos/v1/cs/configs?dataId=cloudConfig.yaml&group=DEFAULT_GROUP&content=useLocalCache: true */ @Value("${useLocalCache:false}") private boolean useLocalCache; @RequestMapping("/get") public boolean get() { return useLocalCache; } }
首先我们来修改useLocalCache的值为true,注意请求方式为post
http://127.0.0.1:8848/nacos/v1/cs/configs?dataId=cloudConfig.yaml&group=DEFAULT_GROUP&content=useLocalCache: true
这里的dataId的值由三部分组成
${prefix}-${spring.profiles.active}.${file-extension}
prefix:代表应用的名称,也就是spring.application.name配置的值,也可以通过spring.cloud.nacos.config.prefix来指定
spring.profiles.active:对应当前环境的profile,也就是spring.profiles.active配置的值,如果没有的话,这个值可以忽略,对应的-也忽略
file-extension:为当前配置类容的数据格式,通过spring.cloud.nacos.config.file-extension来配置,目前只支持properties 和 yaml
上面的api返回结果true,就证明,修改成功,这时可以去对应的管理平台查看
此时我们调用***http://localhost:8082/config/get***
可以看见返回值为true,证明修改成功
这里需要一个生产者和一个消费者来证明Nacos提供的服务的注册和发现
pom文件
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <groupId>org.example</groupId> <artifactId>nacos-study</artifactId> <packaging>pom</packaging> <version>1.0-SNAPSHOT</version> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.3.2.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <modelVersion>4.0.0</modelVersion> <artifactId>spring-cloud</artifactId> <properties> <spring-boot.version>2.3.2.RELEASE</spring-boot.version> <spring-cloud.version>Hoxton.SR7</spring-cloud.version> </properties> <dependencies> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> <version>2.2.1.RELEASE</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> </dependencies> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-dependencies</artifactId> <version>${spring-boot.version}</version> <type>pom</type> <scope>import</scope> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <version>${spring-cloud.version}</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> </project>
bootstrap.yaml配置文件
server:
port: 8011
spring:
application:
name: cloud-provider
cloud:
nacos:
discovery:
server-addr: 127.0.0.1:8848
ProviderApplication启动类和接口提供
@SpringBootApplication @EnableDiscoveryClient public class ProviderApplication { public static void main(String[] args) { SpringApplication.run(ProviderApplication.class, args); } @RestController class EchoController { @RequestMapping(value = "/echo/{string}", method = RequestMethod.GET) public String echo(@PathVariable String string) { return "Hello Nacos Discovery " + string; } } }
pom文件,和上面生产者的一样
bootstrap.yaml配置文件
server:
port: 8012
spring:
application:
name: cloud-consumer
cloud:
nacos:
discovery:
server-addr: 127.0.0.1:8848
ConsumerApplication启动类,以及测试方法
@SpringBootApplication @EnableDiscoveryClient public class ConsumerApplication { @LoadBalanced @Bean public RestTemplate restTemplate() { return new RestTemplate(); } public static void main(String[] args) { SpringApplication.run(ConsumerApplication.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://cloud-provider/echo/" + str, String.class); } } }
此时调用 http://localhost:8012/echo/2020
获取到返回值 Hello Nacos Discovery 2020
[点这里](https://github.com/longhao1213/nacos-study)
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。