SpringCloud Alibaba——服务注册与发现(Nacos)

一、Nacos简介

          Nacos致力于帮助您发现、配置和管理微服务。Nacos提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据及流量管理。Nacos帮助您更敏捷和容易地构建、交付和管理微服务平台。Nacos是构建以“服务”为中心的现代应用架构 (例如微服务范式、云原生范式) 的服务基础设施。

安装Nacos

下载地址(版本:0.7.0):https://github.com/alibaba/nacos/releases

  • Linux:sh startup.sh 
  • Windows:startup.cmd 

访问:http://127.0.0.1:8848/nacos,可以进入Nacos的服务管理页面:

SpringCloud Alibaba——服务注册与发现(Nacos)_第1张图片

 

二、SpringCloud整合Nacos

完成了Nacos服务的安装和启动之后,下面就可以编写两个应用(服务提供者与服务消费者)来验证服务的注册与发现了。

spring cloud的版本以及spring cloud alibaba的版本,由于spring cloud alibaba还未纳入spring cloud的主版本管理中,所以需要自己加入,添加依赖文件(父工程):

    
		1.8
		Finchley.RELEASE
		0.2.1.RELEASE
		1.16.18
	

	
		
			
				org.springframework.cloud
				spring-cloud-dependencies
				${spring-cloud.version}
				pom
				import
			
			
				org.springframework.cloud
				spring-cloud-alibaba-dependencies
				${spring-cloud-alibaba-dependencies.version}
				pom
				import
			

			
				org.projectlombok
				lombok
				${lombok.version}
			
		
	


1、服务提供者( nacos-server)

加入Nacos的服务注册与发现模块:spring-cloud-starter-alibaba-nacos-discovery


		
			org.springframework.boot
			spring-boot-starter
		

		
			org.springframework.boot
			spring-boot-starter-test
			test
		

		
			org.springframework.boot
			spring-boot-starter-web
		

		
			org.springframework.cloud
			spring-cloud-starter-alibaba-nacos-discovery
		

		
			org.projectlombok
			lombok
		
	

创建启动类,并实现一个HTTP接口:

@EnableDiscoveryClient开启Spring Cloud的服务注册与发现,由于引入了spring-cloud-starter-alibaba-nacos-discovery模块,所以Spring Cloud Common中定义的那些与服务治理相关的接口将使用Nacos的实现。

package com.example.demo.nacos;

import lombok.extern.slf4j.Slf4j;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

@SpringBootApplication
@EnableDiscoveryClient
public class NacosServerApplication {

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

    @Slf4j
    @RestController
    static class TestController {

        @GetMapping("/hello")
        public String hello(String name) {
            log.info("name:{}", name);
            return "hello " + name;
        }

    }
}

配置服务名称和Nacos地址:

server:
  port: 8081

spring:
  application:
    name: nacos-server
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848

启动应用:

查看控制的日志,已经注册成功:

11:19:26.014  INFO 2620 --- [           main] o.s.c.a.n.registry.NacosServiceRegistry  : nacos registry, nacos-server 192.168.0.154:8081 register finished

浏览器访问:http://127.0.0.1:8848/nacos/查看服务列表,会显示当前注册的所有服务,以及每个服务的集群数目、实例数、健康实例数。点击详情,我们还能看到每个服务具体的实例信息,如下图所示:

SpringCloud Alibaba——服务注册与发现(Nacos)_第2张图片

2、服务消费者(nacos-client)

实现一个应用来消费上面已经注册到Nacos的服务,编辑pom.xml中的依赖内容,与上面服务提供者的一样即可:


		
			org.springframework.boot
			spring-boot-starter
		

		
			org.springframework.boot
			spring-boot-starter-test
			test
		

		
			org.springframework.boot
			spring-boot-starter-web
		

		
			org.springframework.cloud
			spring-cloud-starter-alibaba-nacos-discovery
		

		
			org.projectlombok
			lombok
		
	

创建启动类,并实现一个HTTP接口,在该接口中调用服务提供方的接口:

package com.example.demo.nacos;

import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.ServiceInstance;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.client.loadbalancer.LoadBalancerClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;

@EnableDiscoveryClient
@SpringBootApplication
public class NacosClientApplication {

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

	@Slf4j
	@RestController
	static class TestController{

		@Autowired
		LoadBalancerClient loadBalancerClient;

		/**
		 * 方法名:
		 * 功能:通过spring cloud common中的负载均衡接口选取服务提供节点实现接口调用
		 * 描述:
		 * 创建人:typ
		 * 创建时间:2019/1/21 10:54
		 * 修改人:
		 * 修改描述:
		 * 修改时间:
		 */
		@GetMapping("/test")
		public String test(){
			ServiceInstance serviceInstance = loadBalancerClient.choose("nacos-server");
			String url = serviceInstance.getUri() + "/hello?name=" + "zhangsan";
			RestTemplate restTemplate = new RestTemplate();
			String result = restTemplate.getForObject(url, String.class);
			return "Invoke : " + url + ", return : " + result;
		}
	}

}

使用Spring Cloud Common中的LoadBalancerClient接口来挑选服务实例信息。然后从挑选出的实例信息中获取可访问的URI,拼接上服务提供方的接口规则来发起调用。

配置服务名称和Nacos地址:

server:
  port: 8080
spring:
  application:
    name: nacos-client
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848

启动服务消费者,浏览器访问:http://localhost:8080/test

127.0.0.1:8080/test
Invoke : http://192.168.0.154:8081/hello?name=zhangsan, return : hello zhangsan

127.0.0.1:8080/test
Invoke : http://192.168.0.154:8082/hello?name=zhangsan, return : hello zhangsan

可以看到,两次不同请求的时候,真正实际调用的服务提供者实例是不同的,也就是说,通过LoadBalancerClient接口在获取服务实例的时候,已经实现了对服务提供方实例的负载均衡。但是很明显,这样的实现还是比较繁琐,预告下后面的几篇,关于服务消费的几种不同姿势。

参考资料

  • Nacos官方文档

 

欢迎关注

SpringCloud Alibaba——服务注册与发现(Nacos)_第3张图片

 

你可能感兴趣的:(springcloud)