nacos 是什么?
nacos是spring-cloud-alibaba的一个组件,可以用来当做配置中心,同时也可以作为注册中心,简单的理解 nacos=springcloud-eureka+springcloud-config; 但是不用单独的启动一个服务作为配置和注册中心了(其实也是启动了一个服务,只不过是打好的工具包,不用我们本地单独搭建工程启动)
提供了可视化操作页面。
后续会更新nacos与其他配置中心的对比
nacos快速开始
#下载地址(官方推荐稳定版本):https://github.com/alibaba/nacos/releases/tag/1.4.1
tar -zxvf nacos-server-1.4.1.tar.gz -C /usr/local/ #解压
cd /usr/local/nacos/bin
sh startup.sh -m standalone #单机模式启动
访问:http://ip:8848/nacos
用户名/密码 :nacos/nacos
nacos 数据源很有意思,单机模式启动,采用的内置的derby数据库,集群模式启动,需要调整为mysql外部数据库
nacos+springcloud
版本对应关系查询:https://github.com/alibaba/spring-cloud-alibaba/wiki/%E7%89%88%E6%9C%AC%E8%AF%B4%E6%98%8E
从上面地址中查询到对应的版本号,加入本地依赖管理
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.4.2</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dependencies</artifactId>
<version>2021.1</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>2020.0.1</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
加入dependency
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
配置文件
server:
port: 8080
spring:
application:
name: nacos-provider
cloud:
nacos:
discovery:
server-addr: 192.168.209.128:8848
启动,查看nacos控制台 http://ip:8848/nacos 服务列表,已经注册到nacos over!
PS:期间遇到过这么几个问题,跟大家分享一下:
java.lang.IllegalArgumentException: Param 'serviceName' is illegal, serviceName is blank
at com.alibaba.nacos.api.naming.utils.NamingUtils.getGroupedName(NamingUtils.java:47) ~[nacos-api-1.4.1.jar:na]
at com.alibaba.nacos.client.naming.NacosNamingService.subscribe(NacosNamingService.java:457) ~[nacos-client-1.4.1.jar:na]
at com.alibaba.cloud.nacos.discovery.NacosWatch.start(NacosWatch.java:123) ~[spring-cloud-starter-alibaba-nacos-discovery-2021.1.jar:2021.1]
at org.springframework.context.support.DefaultLifecycleProcessor.doStart(DefaultLifecycleProcessor.java:178) [spring-context-5.3.3.jar:5.3.3]
at org.springframework.context.support.DefaultLifecycleProcessor.access$200(DefaultLifecycleProcessor.java:54) [spring-context-5.3.3.jar:5.3.3]
at org.springframework.context.support.DefaultLifecycleProcessor$LifecycleGroup.start(DefaultLifecycleProcessor.java:356) [spring-context-5.3.3.jar:5.3.3]
at org.springframework.context.support.DefaultLifecycleProcessor$$Lambda$521/1694519286.accept(Unknown Source) [spring-context-5.3.3.jar:5.3.3]
at java.lang.Iterable.forEach(Iterable.java:75) [na:1.8.0_51]
at org.springframework.context.support.DefaultLifecycleProcessor.startBeans(DefaultLifecycleProcessor.java:155) [spring-context-5.3.3.jar:5.3.3]
at org.springframework.context.support.DefaultLifecycleProcessor.onRefresh(DefaultLifecycleProcessor.java:123) [spring-context-5.3.3.jar:5.3.3]
at org.springframework.context.support.AbstractApplicationContext.finishRefresh(AbstractApplicationContext.java:940) [spring-context-5.3.3.jar:5.3.3]
at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:591) [spring-context-5.3.3.jar:5.3.3]
at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:144) [spring-boot-2.4.2.jar:2.4.2]
at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:767) [spring-boot-2.4.2.jar:2.4.2]
at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:759) [spring-boot-2.4.2.jar:2.4.2]
at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:426) [spring-boot-2.4.2.jar:2.4.2]
at org.springframework.boot.SpringApplication.run(SpringApplication.java:326) [spring-boot-2.4.2.jar:2.4.2]
at org.springframework.boot.SpringApplication.run(SpringApplication.java:1311) [spring-boot-2.4.2.jar:2.4.2]
at org.springframework.boot.SpringApplication.run(SpringApplication.java:1300) [spring-boot-2.4.2.jar:2.4.2]
at com.example.nacosspringcloud.NacosSpringcloudApplication.main(NacosSpringcloudApplication.java:13) [classes/:na]
在yml中配spring.cloud.nacos.discovery.service=123 重启,无效;而且service 默认的读取的是spring.application.name的值
首先检查pom文件的<packaging>节点看是否配置的是pom,如果是pom,请调整
其次就是检查bootstrap.yml和application.yml同时存在,但是application.yml中并没有配置内容引起;其根本原因是因为bootstrap的配置文件没有被加载到导致报错;bootstrap优先加载,但是application.yml中的某些字段优先级别较高,会覆盖boostrap的内容,有些则不会
spring-cloud中使用bootstrap.yml需要添加依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bootstrap</artifactId>
</dependency>
2.更换版本之后,服务器正常启动,但是没有注册到nacos,增加spring-boot-starter-web的依赖,重启之后 控制台 输出:
![在这里插入图片描述](https://img-blog.csdnimg.cn/20210423110213348.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzM5NDY1NTE4,size_16,color_FFFFFF,t_70#pic_center)
查看nacos控制台
至此,服务已经成功注册到nacos
参考链接:
https://github.com/spring-cloud/spring-cloud-release/wiki
https://github.com/alibaba/spring-cloud-alibaba/wiki