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


    转:

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


    默-存 2019-01-21 11:39:48 13718 收藏 10
    分类专栏: springcloud
    版权
    一、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整合Nacos

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

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

            <properties>
                <java.version>1.8</java.version>
                <spring-cloud.version>Finchley.RELEASE</spring-cloud.version>
                <spring-cloud-alibaba-dependencies.version>0.2.1.RELEASE</spring-cloud-alibaba-dependencies.version>
                <lombok.version>1.16.18</lombok.version>
            </properties>
         
            <dependencyManagement>
                <dependencies>
                    <dependency>
                        <groupId>org.springframework.cloud</groupId>
                        <artifactId>spring-cloud-dependencies</artifactId>
                        <version>${spring-cloud.version}</version>
                        <type>pom</type>
                        <scope>import</scope>
                    </dependency>
                    <dependency>
                        <groupId>org.springframework.cloud</groupId>
                        <artifactId>spring-cloud-alibaba-dependencies</artifactId>
                        <version>${spring-cloud-alibaba-dependencies.version}</version>
                        <type>pom</type>
                        <scope>import</scope>
                    </dependency>
         
                    <dependency>
                        <groupId>org.projectlombok</groupId>
                        <artifactId>lombok</artifactId>
                        <version>${lombok.version}</version>
                    </dependency>
                </dependencies>
            </dependencyManagement>
         
        </project>

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

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

        <dependencies>
                <dependency>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-starter</artifactId>
                </dependency>
         
                <dependency>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-starter-test</artifactId>
                    <scope>test</scope>
                </dependency>
         
                <dependency>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-starter-web</artifactId>
                </dependency>
         
                <dependency>
                    <groupId>org.springframework.cloud</groupId>
                    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
                </dependency>
         
                <dependency>
                    <groupId>org.projectlombok</groupId>
                    <artifactId>lombok</artifactId>
                </dependency>
            </dependencies>

    创建启动类,并实现一个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/查看服务列表,会显示当前注册的所有服务,以及每个服务的集群数目、实例数、健康实例数。点击详情,我们还能看到每个服务具体的实例信息,如下图所示:

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

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

        <dependencies>
                <dependency>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-starter</artifactId>
                </dependency>
         
                <dependency>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-starter-test</artifactId>
                    <scope>test</scope>
                </dependency>
         
                <dependency>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-starter-web</artifactId>
                </dependency>
         
                <dependency>
                    <groupId>org.springframework.cloud</groupId>
                    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
                </dependency>
         
                <dependency>
                    <groupId>org.projectlombok</groupId>
                    <artifactId>lombok</artifactId>
                </dependency>
            </dependencies>

    创建启动类,并实现一个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官方文档
    ————————————————
    版权声明:本文为CSDN博主「默-存」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    原文链接:https://blog.csdn.net/typ1805/java/article/details/86570880

  • 相关阅读:
    [C/C++] 结构体内存对齐用法
    [其他] 关于C语言中使用未声明函数的问题
    [其他] 项目中的一个小问题
    【C++】DLL内共享数据区在进程间共享数据(重要)
    [MFC] CString小用例
    [C++] 频谱图中 FFT快速傅里叶变换C++实现
    [MFC] TabControl选项卡的使用
    [MFC] CFile读写文件实现(高效)
    [MFC] 编辑框 EditControl 输入数字范围限制
    [MFC] 对话框菜单项Menu选中打勾(单选,多选)
  • 原文地址:https://www.cnblogs.com/libin6505/p/13229384.html
Copyright © 2020-2023  润新知