博主是在windows下进行安装的,所以如果想在Linux下安装请看官方详细教程
在Nacos的GitHub页面,提供有下载链接,可以下载编译好的Nacos服务端或者源代码:
GitHub主页:https://github.com/alibaba/nacos
GitHub的Release下载页:https://github.com/alibaba/nacos/releases
博主这边采用的nacos版本是1.4.1的,其他版本请看官网详细教程
注意:请解压至无中文目录的文件夹内
目录说明:
Nacos的默认端口是8848,如果你电脑上的其它进程占用了8848端口,请先尝试关闭该进程。
如果无法关闭占用8848端口的进程,也可以进入nacos的conf目录,修改application.properties文件中的端口:
启动非常简单,进入bin目录,结构如下:
windows下的启动命令
startup.cmd -m standalone
-m:表示模式
standalone:表示单机启动
执行效果图如下:
点击链接输入用户名:nacos,密码:nacos,即可进入nacos控制台
父工程
<dependency>
<groupId>com.alibaba.cloudgroupId>
<artifactId>spring-cloud-alibaba-dependenciesartifactId>
<version>2.2.5.RELEASEversion>
<type>pomtype>
<scope>importscope>
dependency>
客户端:
<dependency>
<groupId>com.alibaba.cloudgroupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discoveryartifactId>
dependency>
修改客户端项目中的application.yml文件,注释eureka地址,添加nacos地址:
spring:
cloud:
nacos:
server-addr: localhost:8848 #nacos服务地址
服务调用尽可能选择本地集群的服务,跨集群调用延迟较高
本地集群不可访问时,再去访问其它集群
修改客户端服务者的application.yml文件,添加如下内容:
spring:
cloud:
nacos:
server-addr: localhost:8848 #nacos服务地址
discovery:
cluster-name: HZ #集群名称,这里HZ代指杭州
分别启动UserApplication1和UserApplicattion2,然后修改cluster-name的名字改为SH,接着启动UserApplication3,即可得到两个集群:
修改客户端服务消费者中的application.yml,设置集群为HZ:
spring:
cloud:
nacos:
server-addr: localhost:8848 #nacos服务地址
discovery:
cluster-name: HZ #集群名称,这里HZ代指杭州
然后在客户端服务消费者中设置负载均衡的IRule为NacosRule,这个规则优先会寻找与自己同集群的服务:
userservice:
ribbon:
NFLoadBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule # 负载均衡规则
当我们HZ集群内的实例都没被启动,但SH集群的实例启动时,会出现跨集群访问,此时我们可以在控制台的日志中查看到一个跨集群访问的提示:
我们可以根据Nacos控制台的实例编辑功能来修改实例的权重:
当我们给权重设为0时,此时实例则不会被访问。
Nacos中服务存储和数据存储的最外层都是一个名为namespace的东西,用来做最外层隔离
在Nacos控制台可以创建namespace,用来隔离不同环境
然后填写一个新的命名空间信息:
保存后会在控制台看到这个命名空间的id:
修改客户端服务消费者的application.yml,添加namespace:
spring:
datasource:
url: jdbc:mysql://localhost:3306/cloud_order?useSSL=false
username: root
password: SHIyb021010
driver-class-name: com.mysql.jdbc.Driver
application:
name: orderservice #user服务的服务名称
cloud:
nacos:
server-addr: localhost:8848 #nacos服务地址
discovery:
cluster-name: HZ #集群名称,这里HZ代指杭州
namespace: 492a7d5d-237b-46a1-a99a-fa8e98e4b0f9 # 命名空间,填ID
重启客户端服务消费者后,再来查看控制台:
此时访问order-service,因为namespace不同,会导致找不到userservice,控制台会报错:
服务注册到Nacos时,可以选择注册为临时或非临时实例,通过下面的配置来设置:
spring:
cloud:
nacos:
discovery:
ephemeral: false #设置非临时实例
临时实例宕机时,会从nacos的服务列表中剔除,而非临时实例则不会