2.springcloudalibaba项目搭建(基于alibaba2021.0.5.0版本)

前言

nacos已经搭建好了,现在搭建springcloudalibaba项目。这里对于springcloudalibaba版本的选择,选择支持jdk8的最新版本,我本地的jdk为1.8版本,就直接用支持jdk8的版本。
在这里插入图片描述

这里选择的springcloudalibaba 2021.0.5.0*版本。

一、项目配置

先自己建立一个springboot项目,具体过程就不展示了

1.1 pom配置

关键nacos配置如下,注意这里的nacos2.0 discoverry和nacos config要一起引入使用,否则启动会报错如下

Server check fail, please check server 127.0.0.1 ,port 9848 is available , error ={}
 <!-- SpringCloud Alibaba Nacos -->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>

        <!-- SpringCloud Alibaba Nacos Config -->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-bootstrap</artifactId>
        </dependency>

完整的配置pom如下:

<?xml version="1.0" encoding="UTF-8"?>
<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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.springcloudalibaba</groupId>
    <artifactId>gateway</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>gateway</name>
    <description>Demo project for Spring Boot</description>
    <properties>
        <java.version>8</java.version>
        <spring-boot.version>2.6.13</spring-boot.version>
        <spring-cloud.version>2021.0.5</spring-cloud.version>
        <spring-cloud-alibaba.version>2021.0.5.0</spring-cloud-alibaba.version>
    </properties>
    <dependencies>
        <!-- SpringCloud Gateway -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-gateway</artifactId>
        </dependency>

        <!-- SpringCloud Alibaba Nacos -->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>

        <!-- SpringCloud Alibaba Nacos Config -->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-bootstrap</artifactId>
        </dependency>
    </dependencies>
    <dependencyManagement>
    <dependencies>
    <!-- SpringCloud 微服务 -->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-dependencies</artifactId>
        <version>${spring-cloud.version}</version>
        <type>pom</type>
        <scope>import</scope>
    </dependency>

    <!-- SpringCloud Alibaba 微服务 -->
    <dependency>
        <groupId>com.alibaba.cloud</groupId>
        <artifactId>spring-cloud-alibaba-dependencies</artifactId>
        <version>${spring-cloud-alibaba.version}</version>
        <type>pom</type>
        <scope>import</scope>
    </dependency>

    <!-- SpringBoot 依赖配置 -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-dependencies</artifactId>
        <version>${spring-boot.version}</version>
        <type>pom</type>
        <scope>import</scope>
    </dependency>
    </dependencies>
    </dependencyManagement>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <version>2.6.0</version>
                <configuration>
                    <excludes>
                        <exclude>
                            <groupId>org.projectlombok</groupId>
                            <artifactId>lombok</artifactId>
                        </exclude>
                    </excludes>
                </configuration>
            </plugin>
        </plugins>
    </build>

</project>

1.2 nacos新建命名空间

新建名为test的命名空间,记住这个命名空间id,后面会用到
在这里插入图片描述

1.3 项目配置

新建bootstrap.yml文件,

  1. 配置服务注册到nacos配置
spring:
  application:
    # 应用名称
    name: gateway
  profiles:
    # 环境配置
    active: dev
  main:
    allow-bean-definition-overriding: true
  cloud:
    nacos:
      discovery:
        # 服务注册地址
        server-addr: 192.168.184.130:8848
        group: alibaba
        #服务命名空间,即上面创建命名空间的时候自动生成的id
        namespace: 7dd9fa65-9c9d-484f-94f8-d621ca05d0e5
        #是否注册到nacos,false不注册到nacos,默认true
        register-enabled: true

2.配置中心配置
这里的配置是部署到环境后自动读取nacos的配置文件启动服务,达到灵活配置服务配置的目的。读取的规则为
s p r i n g . a p p l i c a t i o n . n a m e − {spring.application.name}- spring.application.name{spring.profiles.active}.yml
例如我这里的为gateway-dev.yml
shared-configs为共享配置,即一个命名空间下所有的服务都可以读取到的配置,一般用来设置多个服务共享的配置,例如我这里配置的为application- s p r i n g . p r o f i l e s . a c t i v e . {spring.profiles.active}. spring.profiles.active.{spring.cloud.nacos.config.file-extension}
即application-dev.yml

      config:
        # 配置中心地址
        server-addr: 192.168.184.130:8848
        # 配置文件格式
        file-extension: yml
        group: ${spring.cloud.nacos.discovery.group}
        namespace: ${spring.cloud.nacos.discovery.namespace}
        #共享配置
        shared-configs[0]:
          data-id: application-${spring.profiles.active}.${spring.cloud.nacos.config.file-extension} # 配置文件名-Data Id
          group: ${spring.cloud.nacos.discovery.group}   # 默认为DEFAULT_GROUP
          refresh: false

完整的整个配置如下:

# Tomcat
server:
  port: 8080

# Spring
spring:
  application:
    # 应用名称
    name: gateway
  profiles:
    # 环境配置
    active: dev
  main:
    allow-bean-definition-overriding: true
  cloud:
    nacos:
      discovery:
        # 服务注册地址
        server-addr: 192.168.184.130:8848
        group: alibaba
        namespace: 7dd9fa65-9c9d-484f-94f8-d621ca05d0e5
        register-enabled: true
      config:
        # 配置中心地址
        server-addr: 192.168.184.130:8848
        # 配置文件格式
        file-extension: yml
        group: ${spring.cloud.nacos.discovery.group}
        namespace: ${spring.cloud.nacos.discovery.namespace}
        shared-configs[0]:
          data-id: application-${spring.profiles.active}.${spring.cloud.nacos.config.file-extension} # 配置文件名-Data Id
          group: ${spring.cloud.nacos.discovery.group}   # 默认为DEFAULT_GROUP
          refresh: false
logging:
  level:
    com.alibaba.nacos.client: info

1.4 nacos上配置配置文件

配置gateway-dev.yml文件如下,dataid为1.3里面配置的配置文件名称,group和项目服务一致即可。
在这里插入图片描述
配置application-dev.yml如下
在这里插入图片描述
这里我增加了两个配置,用于验证是否读取到了nacos上的配置。

1.5 代码新增测试读取服务配置代码

package com.springcloudalibaba.gateway.control;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class Control {
    @Value("${testName}")
    private String testName;

    @Value(("${publicName}"))
    private String publicName;

    @RequestMapping(value = "/hello")
    public String index() {
        System.out.println("testname: "+testName);
        System.out.println("publicName:"+publicName);
        return testName+publicName;
    }


}

1.6 启动类增加注解

启动类增加注解@EnableDiscoveryClient

package com.springcloudalibaba.gateway;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;

@SpringBootApplication
@EnableDiscoveryClient
public class GatewayApplication {

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

}

二、启动服务并测试

2.1 启动服务,查看是否注册成功

本地启动服务
在这里插入图片描述
在这里插入图片描述
可以看到服务已经注册上去了。

2.2 测试是否读取到了nacos上的配置

测试刚刚写的接口
在这里插入图片描述
在这里插入图片描述

可以看到已经请求到了刚刚写在nacos上的配置,测试成功。


总结

1.nacos2.0服务注册和服务配置要同时使用,否则会报错。
2.springcloudalibaba的版本、springcloud版本、springboot版本要版本匹配,不然容易出现不可预知的错误。

org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'serviceMetadataProcessor' defined in URL [jar:file:/home/nacos/target/nacos-server.jar!/BOOT-INF/lib/nacos-naming-2.1.1.jar!/com/alibaba/nacos/naming/core/v2/metadata/ServiceMetadataProcessor.class]: Bean instantiation via constructor failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [com.alibaba.nacos.naming.core.v2.metadata.ServiceMetadataProcessor]: Constructor threw exception; nested exception is java.lang.IllegalStateException: Fail to init node, please see the logs to find the reason. at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:315) at org.springframework.beans.factory.support.ConstructorResolver.autowireConstructor(ConstructorResolver.java:296) at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireConstructor(AbstractAutowireCapableBeanFactory.java:1372) at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1222) at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:582) at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:542) at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:335) at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:234) at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:333) at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:208) at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:953) at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:918) at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:583) at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:145) at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:745) at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:420) at org.springframework.boot.SpringApplication.run(SpringApplication.java:307) at org.springframework.boot.SpringApplication.run(SpringApplication.java:1317) at org.springframework.boot.SpringApplication.run(SpringApplication.java:1306) at com.alibaba.nacos.Nacos.main(Nacos.java:35) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:498) at org.springframework.boot.loader.MainMethodRunner.run(MainMethodRunner.java:49) at org.springframework.boot.loader.Launcher.launch(Launcher.java:108) at org.springframework.boot.loader.Launcher.launch(Launcher.java:58) at org.springframework.boot.loader.PropertiesLauncher.main(PropertiesLauncher.java:467) Caused by: org.springframework.beans.BeanInstantiationException: Failed to instantiate [com.alibaba.nacos.naming.core.v2.metadata.ServiceMetadataProcessor]: Constructor threw exception; nested exception is java.lang.IllegalStateException: Fail to init node, please see the logs to find the reason. at org.springframework.beans.BeanUtils.instantiateClass(BeanUtils.java:224) at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:117) at org.springframework.beans.factory.support.ConstructorResolver.instantiate(ConstructorResolver.java:311) ... 27 common frames omitted Caused by: java.lang.IllegalStateException: Fail to init node, please see the logs to find the reason. at com.alipay.sofa.jraft.RaftServiceFactory.createAndInitRaftNode(RaftServiceFactory.java:48) at com.alipay.sofa.jraft.RaftGroupService.start(RaftGroupService.java:129) at com.alibaba.nacos.core.distributed.raft.JRaftServer.createMultiRaftGroup(JRaftServer.java:260) at com.alibaba.nacos.core.distributed.raft.JRaftProtocol.addRequestProcessors(JRaftProtocol.java:163) at com.alibaba.nacos.naming.core.v2.metadata.ServiceMetadataProcessor.<init>(ServiceMetadataProcessor.java:73) at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62) at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45) at java.lang.reflect.Constructor.newInstance(Constructor.java:423) at org.springframework.beans.BeanUtils.instantiateClass(BeanUtils.java:211) ... 29 common frames omitted
06-13
<think>我们正在解决Nacos启动时出现的ServiceMetadataProcessorBean创建失败的问题。错误信息通常包含:BeanCreationException,java.lang.IllegalStateException:Failtoinitnode等。根据引用[1]和引用[2]的线索,我们可以推测问题可能与循环依赖或Nacos节点初始化失败有关。结合经验,这类问题通常由以下原因引起:1.版本不兼容:使用的Nacos版本SpringCloudAlibaba版本不匹配。2.配置错误:Nacos配置文件中可能存在错误的配置项,导致节点初始化失败。3.环境问题:如数据库连接失败(如果使用MySQL作为存储)或集群配置错误。解决方案步骤:步骤1:检查版本兼容性确保使用的SpringCloudAlibaba版本与Nacos版本兼容。参考官方版本兼容性说明:https://github.com/alibaba/spring-cloud-alibaba/wiki/版本说明例如,SpringCloudAlibaba2.2.5.RELEASE对应Nacos1.4.1。步骤2:检查Nacos配置检查Nacos的配置文件(application.properties或application.yml)是否正确,特别是数据库连接(如果使用MySQL)和集群配置。对于数据库配置,确保数据库服务可用,且配置正确。例如:```propertiesspring.datasource.platform=mysqldb.num=1db.url.0=jdbc:mysql://localhost:3306/nacos?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=truedb.user=rootdb.password=your_password```步骤3:检查集群配置如果是集群模式,确保每个节点的配置正确,并且节点之间网络互通。在集群配置文件中(cluster.conf)正确设置了所有节点的IP和端口。步骤4:清理缓存并重启清理Nacos的work目录(或data目录)下的缓存文件,然后重启Nacos。步骤5:查看日志仔细查看Nacos的日志文件(通常位于logs目录),根据日志中的错误信息进一步排查。步骤6:尝试单机模式如果集群模式启动有问题,可以尝试单机模式启动,以确定是否是集群配置的问题。单机模式启动命令:```bashshstartup.sh-mstandalone```如果以上步骤不能解决问题,请提供更详细的错误日志信息,以便进一步分析。根据引用[2]中的经验,伪集群搭建时只能启动一个服务,可能是端口冲突或者集群配置错误。请检查每个节点的端口设置(包括server.port、raftport等)是否冲突。另外,注意Nacos2.0版本需要额外的端口用于gRPC通信,因此需要确保这些端口(默认主端口+1000和+1001)也是可用的。例如,如果主端口为8848,则还需要9848和9849端口可用。如果问题仍然存在,可以尝试以下操作:1.更新到最新版本或稳定版本2.检查防火墙设置,确保相关端口开放。3.如果使用MySQL,检查数据库表结构是否正确(使用Nacos提供的SQL脚本初始化)。希望这些步骤能帮助您解决问题。§§相关问题§§1.如何检查SpringCloudAlibaba与Nacos的版本兼容性?2.Nacos集群配置的具体步骤是什么?3.如何解决Nacos启动时的数据库连接问题?4.Nacos2.0版本端口配置有哪些注意事项?5.如何排查Nacos节点初始化失败的原因?</think>### Nacos ServiceMetadataProcessor Bean创建失败问题解决方案 当Nacos启动时出现`ServiceMetadataProcessor` Bean创建失败,并抛出`IllegalStateException: Fail to init node`错误时,通常由以下原因引起: #### 核心问题分析 1. **节点初始化失败**:Nacos节点启动时无法完成初始化流程,常见于集群配置错误或资源冲突 2. **版本兼容性问题**:Nacos客户端/服务端版本Spring Cloud Alibaba版本不匹配 3. **依赖冲突**:项目中存在多个冲突的依赖包(如不同版本Spring或Nacos SDK) 4. **配置错误**:`cluster.conf`或`application.properties`配置不当 5. **资源限制**:端口占用或内存不足导致节点初始化失败 --- ### 解决方案步骤 #### 1. 验证版本兼容性(关键步骤) 检查版本匹配关系,参考官方兼容矩阵: ```bash # 查看Spring Cloud Alibaba版本 grep 'spring-cloud-alibaba' pom.xml # 查看Nacos客户端版本 grep 'nacos-client' pom.xml ``` 推荐组合示例: - Spring Cloud Alibaba 2021.0.5.0 + Nacos 2.2.1 - Spring Cloud Alibaba 2.2.10.RELEASE + Nacos 1.4.3 > **注意**:避免混用Nacos 1.x和2.x协议[^2] #### 2. 清理依赖冲突 在`pom.xml`中添加显式依赖声明: ```xml <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> <version>2021.0.5.0</version> <exclusions> <exclusion> <groupId>com.alibaba.nacos</groupId> <artifactId>nacos-client</artifactId> </exclusion> </exclusions> </dependency> <!-- 显式指定nacos-client版本 --> <dependency> <groupId>com.alibaba.nacos</groupId> <artifactId>nacos-client</artifactId> <version>2.2.1</version> </dependency> ``` #### 3. 检查集群配置 在`cluster.conf`中确保所有节点使用**统一协议**: ```properties # 正确示例 (Nacos 2.x集群) 192.168.1.101:8848 192.168.1.102:8848 192.168.1.103:8848 ``` 同时确认`application.properties`配置: ```properties # Nacos 2.x必须配置的端口偏移 server.port=8848 nacos.offset=1000 # 确保9848/9849端口可用 ``` #### 4. 处理节点初始化失败 ```bash # 停止所有Nacos进程 kill -9 $(ps -ef | grep nacos | grep -v grep | awk '{print $2}') # 清理临时文件 rm -rf /home/nacos/data/protocol rm -f /home/nacos/logs/*.log # 单节点启动验证 sh startup.sh -m standalone ``` #### 5. 验证数据库连接(若使用MySQL) 在`application.properties`中检查: ```properties spring.datasource.platform=mysql db.url.0=jdbc:mysql://127.0.0.1:3306/nacos?useUnicode=true&characterEncoding=utf8 db.user=nacos db.password=nacos@123 ``` 执行测试连接: ```bash mysql -u nacos -h 127.0.0.1 -p nacos@123 -e "USE nacos; SHOW TABLES;" ``` --- ### 关键日志分析点 检查`nacos/logs/nacos.log`: 1. `Fail to init node` 前的堆栈跟踪 2. `ProtocolManager` 相关初始化日志 3. 端口绑定异常:`Address already in use` 4. 数据库连接异常:`Communications link failure` > 若问题仍存在,尝试升级到Nacos 2.2.3+版本(修复了多个节点初始化BUG)[^2]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值