Nacos服务注册与发现-实现服务提供者于消费者

Nacos服务注册与发现-实现服务提供者于消费者

本节实现基于Nacos的服务注册与发现,编写简单的Demo实现服务消费者调用服务提供者。

文章目录

  • Nacos服务注册与发现-实现服务提供者于消费者
    • 框架版本
    • 介绍
    • 编写服务提供者
      • 引入依赖
      • 修改配置文件
      • 编写Controller
    • 编写服务消费者
      • 引入依赖
      • 修改配置文件
      • 声明RestTemplate
      • 编写Controller
    • 测试
    • 代码地址

框架版本

  • Spring Boot 2.1.5
  • Nacos 1.1.4(使用Docker安装)
  • Docker 19.04

介绍

Nacos官方文档
Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据及流量管理。
Nacos 帮助您更敏捷和容易地构建、交付和管理微服务平台。 Nacos 是构建以“服务”为中心的现代应用架构 (例如微服务范式、云原生范式) 的服务基础设施.下图摘自Nacos官网
Nacos服务注册与发现-实现服务提供者于消费者_第1张图片

编写服务提供者

引入依赖

 /* 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即可在管理页面看到服务提供者于消费者
Nacos服务注册与发现-实现服务提供者于消费者_第2张图片

  • 使用Postman发送请求

从结果可以看出,返回的结果是服务提供者返回的消息。
Nacos服务注册与发现-实现服务提供者于消费者_第3张图片

代码地址

Github代码链接

你可能感兴趣的:(Spring,Cloud,Alibaba,微服务,Nacos,服务注册与发现)