Nacos服务注册与发现-实现服务提供者于消费者
本节实现基于Nacos的服务注册与发现,编写简单的Demo实现服务消费者调用服务提供者。
文章目录
框架版本
- Spring Boot 2.1.5
- Nacos 1.1.4(使用Docker安装)
- Docker 19.04
介绍
Nacos官方文档
Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据及流量管理。
Nacos 帮助您更敏捷和容易地构建、交付和管理微服务平台。 Nacos 是构建以“服务”为中心的现代应用架构 (例如微服务范式、云原生范式) 的服务基础设施.下图摘自Nacos官网
编写服务提供者
引入依赖
/* Spring Boot Begin */
compile 'org.springframework.boot:spring-boot-starter-web'
compile 'org.springframework.boot:spring-boot-starter-actuator'
compile 'org.springframework.boot:spring-boot-starter-test'
/* Spring Boot End */
/* Logstash Begin */
compile 'net.logstash.logback:logstash-logback-encoder:5.3'
/* Logstash End */
compile 'com.alibaba.cloud:spring-cloud-starter-alibaba-nacos-discovery:2.1.0.RELEASE'
//增加log4j2日志组件集成
compile 'org.apache.skywalking:apm-toolkit-log4j-2.x:6.4.0'
修改配置文件
spring:
application:
name: nacos-provider
cloud:
nacos:
discovery:
server-addr: 192.168.23.100:8848
enabled: true
server:
port: 8080
编写Controller
@RestController
public class HelloProviderController {
private static final Logger LOGGER = LoggerFactory.getLogger(HelloProviderController.class);
@Autowired
HelloProviderServiceImpl helloServiceProviderService;
@GetMapping("/sayHi")
//对任何需要追踪的方法,使用 @Trace 标注,则此方法会被加入到追踪链中。
@Trace()
public String sayHi() {
LOGGER.info("调用服务提供者");
return helloServiceProviderService.sayHi();
}
}
服务提供者会返回一个字符串,类似于Hello Nacos, My Service Port is: 8080
编写服务消费者
引入依赖
dependencies {
/* Spring Boot Begin */
compile 'org.springframework.boot:spring-boot-starter-web'
compile 'org.springframework.boot:spring-boot-starter-actuator'
compile 'org.springframework.boot:spring-boot-starter-test'
/* Spring Boot End */
/* Logstash Begin */
compile 'net.logstash.logback:logstash-logback-encoder:5.3'
/* Logstash End */
compile 'com.alibaba.cloud:spring-cloud-starter-alibaba-nacos-discovery:2.1.0.RELEASE'
}
修改配置文件
spring:
application:
name: nacos-consumer
cloud:
nacos:
discovery:
server-addr: 192.168.23.100:8848
server:
port: 8081
声明RestTemplate
@Configuration
public class Config {
@Bean
@LoadBalanced
public RestTemplate restTemplate() {
return new RestTemplate();
}
}
编写Controller
@RestController
public class HelloConsumerController {
@Autowired
private RestTemplate restTemplate;
@GetMapping("/sayHi")
public String sayHi() {
String url = String.format("http://nacos-provider/sayHi");
System.out.println("request url:" + url);
return restTemplate.getForObject(url, String.class);
}
}
测试
- 安装顺序启动服务
- 保证Nacos正常
- 启动nacos-provider
- 启动nacos-consumer
启动成功后,登录Ncos即可在管理页面看到服务提供者于消费者
- 使用Postman发送请求
从结果可以看出,返回的结果是服务提供者返回的消息。
代码地址
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/13148.html