开发者

SpringBoot实现服务接入nacos注册中心流程详解

开发者 https://www.devze.com 2023-01-14 10:36 出处:网络 作者: 融极
目录概述接入nacos注册中心springboot服务pom文件application.properties配置源码分析小结源码流程图概述
目录
  • 概述
  • 接入nacos注册中心
    • springboot服务pom文件
    • application.properties配置
  • 源码分析
    • 小结
      • 源码流程图

        概述

        某些场景下只需要把springboot微服务化而不想引入springcloud如何实现的呢?

        下面我们介绍nacos注册中心方案。

        接入nacos注册中心

        springboot服务pom文件

        <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">
            <modelVersion>4.0.0</modelVersion>
            <parent>
                <groupId>com.study</groupId>
                <artifactId>practice</artifactId>
                <version>1.0.0-SNAPSHOT</vers开发者_JS教程ion>
            </parent>
            <artifactId>practice-demo</artifactId>
            <dependencyManagement>
                <dependencies>
                    <dependency>
                        <groupId>org.springframework.boot</groupId>
                        <artifactId>spring-boot-dependencies</artifactId>
                        <version>2.1.3.RELEASE</version>
                        <type>pom</type>
                        <scope>import</scope>
                    </dependency>
                </dependencies>
            </dependencyManagement>
            <properties>
                <project.build.sphpourceEncoding>UTF-8</project.build.sourceEncoding>
                <Java.version>1.8</java.version>
            </properties>
            <!-- springboot -->
            <dependencies>
                <dependency>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-starter-web</artifactId>
                    <exclusions>
                        <exclusion>
                            <groupId>org.springframework.boot</groupId>
                            <artifactId>spring-boot-starter-logging</artifactId>
                        </exclusion>
                    </exclusions>
                </dependency>
                <!--test -->
                <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-log4j2</artifactId>
                </dependency>
                <!--nacos注册中心-->
                <dependency>
                    <groupId>com.alibaba.boot</groupId>
                    <artifactId>nacos-discovery-spring-boot-starter</artifactId>
                    <version>0.2.7</version>
                </dependency>
            </dependencies>
            <build>
                <plugins>
                    <plugin>
                        <groupId>org.springframework.boot</groupId>
                        <artifactId>spring-boot-maven-plugin</artifacwww.devze.comtId>
                        <version>2.1.3.RELEASE</version>
                        <executions>
                            <execution>
                                <goals>
                                    <goal>repackage</goal>
                                </goals>
                            </execution>
                        </executions>
                    </plugin>
                </plugins>
            </build>
        </project>

        application.properties配置

        # nacos注册

        spring.application.name=file-server-service

        nacos.discovery.server-addr=192.168.1.1:8848,192.168.1.2:884编程客栈8

        nacos.discovery.auto-register=true

        nacos.discovery.enabled=true

        # 指定微服务注册那个地址

        nacos.discovery.register.ip=

        源码分析

        主流程:

        1、nacos-discovery-spring-boot-starter 启动服务通过SPI机制扫描到nacos-discovery-spring-boot-autoconfigure包。

        SpringBoot实现服务接入nacos注册中心流程详解

        2、nacos-discovery-spring-boot-autoconfigure项目通过自动装配功能装配nacos客户端

        SpringBoot实现服务接入nacos注册中心流程详解

        3、 Nacos自动配置服务实现Spring的应用监听器用来注册nacos服务

        NacosDiscoveryAutoRegister implements ApplicationListener

        4、NacosDiscoveryAutoRegister监听到spring的ServletWebServerInitializedEvent事件后把springboot服务注册到nacos注册中心

        5、调用nacos-client jar包中的com.alibaba.nacos.client.naming.net.NamingProxy#registerService完成服务注册

        核心处理逻辑:com.alibaba.nacos.client.naming.net.NamingProxy.java

            public String reqAPI(String api, Map<String, String> params, String body, List<String> servers, String method) throws NacosException {
                params.put("namespaceId", this.getNamespaceId());
                if (CollectionUtils.isEmpty(servers) && StringUtils.isEmpty(this.nacosDomain)) {
                    throw new NacosException(400, "no server available");
                } else {
                    NacosException exception = new NacosException();
                    // 如果nacos.discovery.server-addr是逗号分隔的列表走改分组
                    if (servers != null && !servers.isEmpty()) {
                        Random random = new Random(System.currentTimeMillis());
                        int index = random.nextInt(servers.size());
                        int i = 0;
                        while(i < servers.size()) {
                            String server = (String)servers.get(index);
                            try {
                                return this.callServer(api, params, body, server, method);
                            } catch (NacosException var13) {
                                exception = var13;
                                if (LogUtils.NAMING_LOGGER.isDebugEnabled()) {
                                    LogUtils.NAMING_LOGGER.debug("request {} failed.", server, var13);
                                }
                                index = (index + 1) % servers.size();
                                ++i;
                            }
                        }
                    }
                     // 如果nacos.discovery.server-addr只配置一个服务地址而不是逗号分隔的多个服务地址
                    if (StringUtils.isNotBlank(this.nacosDomain)) {
                        int i = 0;
                        while(i < 3) {
                            try {
                                return this.callServer(api, params, body, this.nacosDomain, method);
                            } catch (NacosException var12) {
                                exception = var12;
                                if (LogUtils.NAMING_LOGGER.isDebugEnabled()) {
                                    LogUtils.NAMING_LOGGER.debug("request {} failed.", this.nacosDomain, var12);
                                }
                                ++i;
                            }
                        }
                    }
        			...
                }
            }
        	/**
        		调用nacos服务器,把springboot服务注册为微服务
        		使用服务注册接口:http://xxx:xxx/nacos/v1/ns/instance
        	**/
            pjsublic String callServer(String api, Map<String, String> params, String body, String curServer, String method) throws NacosException {
                long start = System.currentTimeMillis();
                long end = 0L;
                this.injectSecurityInfo(params);
                List<String> headers = this.builderHeaders();
                String url;
                // 如果nacos.discovery.server-addr地址不是http://或者https://开头走该分组
                if (!curServer.startsWith("https://") && !curServer.startsWith("http://")) {
                    // 如果只写了ip地址,会追加默认的8848端口
                    if (!curServer.contains(":")) {
                        curServer = curServer + ":" + this.serverPort;
                    }
                    // 添加http前缀,http或者https,配置项com.alibaba.nacos.client.naming.tls.enable确定是http还是https
                    url = HttpClient.getPrefix() + curServer + api;
                } else {
                    url = curServer + api;
                }
                HttpResult result = HttpClient.request(url, headers, params, body, "UTF-8", method);
                end = System.currentTimeMillis();
                MetricsMonitor.getNamingRequestMonitor(method, url, String.valueOf(result.code))编程客栈.observe((double)(end - start));
                if (200 == result.code) {
                    return result.content;
                } else if (304 == result.code) {
                    return "";
                } else {
                    throw new NacosException(result.code, result.content);
                }
            }

        小结

        nacos.discovery.server-addr配置项支持的方式:

        单个ip:port形式

        nacos.discovery.server-addr=192.168.10.18:8858

        多个ip:port形式

        nacos.discovery.server-addr=192.168.10.18:8858,192.168.10.19:8858

        域名方式(http://或者https://开头)

        nacos.discovery.server-addr=https://www.xxx

        从源码我们可以看出,其实nacos.discovery.server-addr配置多个地址,nacos会随机选择一个服务器地址,如果注册成功就返回了,不会去处理其他的服务地址,除非一个地址注册失败才会使用其他的地址注册;nacos集群情况下,最好配置多个地址,放在一个nacos注册失败导致服务注册不上的问题。

        源码流程图

        SpringBoot实现服务接入nacos注册中心流程详解

        到此这篇关于SpringBoot实现服务接入nacos注册中心流程详解的文章就介绍到这了,更多相关SpringBoot接入nacos内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

        0

        精彩评论

        暂无评论...
        验证码 换一张
        取 消

        关注公众号