logo 范 · 拾光录
网址收集 关于作者 Github Gitee
杂文随笔5
Hexo博客:基础使用Hexo博客:Next主题Hexo博客:Next进阶使用Hexo博客:Next高级配置基于Node的WIKI管理
前端知识16
HTML常用知识CSS常用知识CSS美化checkbox复选框JavaScript常用知识JavaScript格式化时间戳JavaScript窗口宽高处理JavaScript黑夜主题切换实现方案JavaScript数字转大写简易图片查看器TypeScript基础知识Threejs基础三要素Threejs网格辅助和轨道控制器Threejs物体绘制Electron基础使用Nodejs基础知识animate.css页面动画
Vue框架19
Vite的使用及扩展Vue3父子组件Vue3使用Marked解析MarkdownMermaid图表生成库初始化页面加载动画Axios表单提交二维码解决方案NProgress加载进度条Vue3动态菜单实现Vue3使用ECharts图表Vue3处理Excel导入导出keep-alive页面缓存及setup问题Element:文件上传Element:结合Pinia实现动态菜单Element:图片上传组件Element:自定义统一弹窗组件Element:表格自定义指令控制按钮显示(鉴权)可视化大屏使用缩放适配分辨率
UniApp15
UniApp的基础使用封装网络请求工具及文件上传uni-app的开发记录微信小程序分享原生文件上传Pinia取消滚动条(兼容小程序)tabbar消息数量显示scroll-view上滑到底部加载数据状态栏高度动态设配数据共享与传递uview-plus导航栏实现背景融合Wot UIWot UI实现顶部背景图融合uni-app x
Java基础知识10
基础知识面向对象Lambda表达式常用API常用知识积累try-with-resource注解反射多线程经纬度距离计算
SpringBoot31
application配置Maven创建聚合项目全局异常处理锁机制项目启动初始化数据方式邮件功能集成原生定时任务异步集成阿里云OSS阿里OSS预签名上传基于hutool读excelJSR303WebSocketWebSocket版AI接口流式调用Smart-Doc接口文档生成器application配置信息加密雪花算法工具AOP实现请求参数脱敏思路JWT生成Token及工具类SpringBoot默认JSON与对象转换若依框架:安装使用若依框架:优化和调整文件上传若依框架:管理后台页面优化若依框架:后端接口代码优化SpringAISpringBoot实现AI接口流式调用服务启动时创建MySQL连接自建项目工程树形结构处理工具微信支付代码微信手机号登录
SpringMVC14
跨域处理拦截器RESTful风格伪前后端分离Jackson转换器调整Thymeleaf基于拦截器做权限校验AOP打印接口请求响应日志AOP打印接口请求响应耗时文件上传和回显POST请求加解密实现(AES)POST请求加解密实现(RSA+AES)参数动态校验实现方案真实IP和归属地
MyBatis8
MyBatis基本使用与配置Mapper使用相关MaBatis多数据源配置MyBatisPlus数据统计类处理方案MyBatisPlus条件查询正向工程的实现(H2)mybatis-plus-join
SpringCloud15
Netflix:微服务与搭建Netflix:服务的消费与提供Netflix:EurekaNetflix:ActuatorNetflix:RibbonNetflix:FeignNetflix:HystrixNetflix:ZuulAlibaba:简介与搭建Alibaba:Nacos注册中心Alibaba:RibbonAlibaba:OpenFeignAlibaba:Nacos配置中心Alibaba:GetewayAlibaba:Sentinel
MySQL6
MySQL基础知识MySQL多表查询与事务MySQL常用函数及解决方案MySQL视图MySQL索引安装MySQL
Redis7
Redis介绍和安装Redis配置文件Redis持久化Redis集群Redis语法基础Redis相关问题及解决方案SpringBoot集成Redis使用记录
MongoDB10
Linux安装MongoDBMongoDB基础语法MongoTemplate及SpringBoot配置MongoTemplate中Update操作MongoTemplate中聚合查询MongoTemplate日期归档示例项目使用相关知识归纳地理位置存储与距离查询MongoDB副本集与事务获取类名和属性名工具类
其他数据库1
H2数据库
Python编程6
Python基础知识Python语法yolo目标检测OpenCV的使用及树莓派平台condauv
工具集合13
IDEAMavenGradleGitNginx安装Nginx配置VSCodeJMeter压测DockerOllamaRustFSPicGoObs录制
Linux知识11
Linux常用命令Jar启动脚本VirtualBox安装CentOSVirtualBox安装Ubuntu树莓派安装及使用frp内网穿透ArchLinux:基础系统安装ArchLInux:图形化界面安装ArchLinux:常用软件ArchLinux:深度优化ArchLinux:Niri
创意设计2
Blender:入门知识UI设计基础知识
AI相关9
Claude CodeHermes AgentOpenAI基本使用OpenAI工具调用OpenAI记忆管理OpenAI推理执行OpenAI开发框架Langchainllama.cpp

简介

官方文档地址

作用:

注册中心:微服务拆分后,使用网络请求在各个服务之间进行调用,就会出现各个服务之间的调用错综复杂、难以维护。注册中心的作用就是管理所有微服务、解决微服务之间调用关系错综复杂、难以维护的问题

Nacos是一个更易于构建云原生应用的动态服务发现、服务配置和服务管理平台

注册中心原理

服务注册

Nacos Client会通过发送Rest请求的方式想Nacos Server注册自己的服务,提供自身的元数据,如IP地址、端口等信息,Server收到注册请求后,会把信息存储在一个双层的内存Map中

服务心跳

在注册后,Nacos Client会维护一个定时心跳来持续通知Server,确保自己一直处于可用状态,防止被删除,默认5秒发送一次

服务同步

Nacos Server集群之间会相互同步服务实例,用来保证数据的一致性

服务发现

服务消费者(Nacos Client)在调用服务提供者的服务时,会发送一个Rest请求给Server,获取已注册的服务清单,并且缓存到本地,同时会开启一个定时任务拉取服务端最新的注册信息到本地

服务健康值

Nacos Server会开启一个定时任务用来检查注册表的实例的健康情况,对于超过15秒没有收到Client心跳的实例会将其healthy设置为false(Client进行服务发现时不会获取到),如果实例超过30秒没有心跳,直接剔除实例(被剔除实例回复心跳则会重新注册)

各注册中心对比

服务端安装

根据SpringCloud Alibaba官方各版本对应下载Nacos版本

Nacos官方下载地址

运行nacos/bin下的脚本即可启动,注意,默认时集群模式启动,单机模式需要修改

# 调整此处
set MODE="cluster"

# 根据代码看可以选择standalone(单机)、cluster(集群)
if %MODE% == "standalone" (
    echo "nacos is starting with standalone"
	  set "NACOS_OPTS=-Dnacos.standalone=true"
    set "NACOS_JVM_OPTS=-Xms512m -Xmx512m -Xmn256m"
)

rem if nacos startup mode is cluster
if %MODE% == "cluster" (
    echo "nacos is starting with cluster"
	  if %EMBEDDED_STORAGE% == "embedded" (
	      set "NACOS_OPTS=-DembeddedStorage=true"
	  )

    set "NACOS_JVM_OPTS=-server -Xms2g -Xmx2g -Xmn1g -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=320m -XX:-OmitStackTraceInFastThrow -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=%BASE_DIR%\logs\java_heapdump.hprof -XX:-UseLargePages"
)

其余端口等信息在nacos/conf/application.properties中修改

启动成功后根据提示访问http://localhost:8848/nacos/index.html即可看到服务端后台

默认用户名和密码都是nacos

客户端安装

添加依赖

<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

项目启动报错

***************************
APPLICATION FAILED TO START
***************************

Description:

Parameter 0 of method ribbonServerList in com.alibaba.cloud.nacos.ribbon.NacosRibbonClientConfiguration required a bean of type 'com.netflix.client.config.IClientConfig' that could not be found.


Action:

Consider defining a bean of type 'com.netflix.client.config.IClientConfig' in your configuration.

Disconnected from the target VM, address: '127.0.0.1:62141', transport: 'socket'

这是个BUG,项目启动类放在了com包下造成的,需要防止到com.xxx下,也就是多加一个包就可以了

项目启动出现WARN

启动项目控制台出现WARNNo URLs will be polled as dynamic configuration sources.

原因是没有找到配置文件

解决办法,在项目resources下加一个config.properties空文件

服务相互调用

@Bean
@LoadBalanced // 开启请求解析和负载均衡
public RestTemplate restTemplate() {
    return new RestTemplate();
}

请求其他服务

@Resource
private RestTemplate restTemplate;

@RequestMapping("/test")
public String test() {
    System.out.println("订单");
    String res = restTemplate.getForObject("http://stock-service/stock/test", String.class);
    return "order" + res;
}

其中stock-service为服务名

nacos集群

集群搭建也是用的是下载的nacos包,然后需要修改一下内容,注意集群下注册中心的内容需要写到MySQL数据库中

配置文件conf/application.properties

# 端口
server.port=8848
# 开启数据库
spring.datasource.platform=mysql
# 数据库连接数量
db.num=1
# 数据库连接信息
db.url.0=jdbc:mysql://127.0.0.1:3306/nacos?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useUnicode=true&useSSL=false&serverTimezone=UTC
db.user.0=nacos
db.password.0=nacos

开启数据库后记得创建数据库及其表,表的创建脚本在conf/nacos-mysql.sql

然后复制一份conf/cluster.conf.examplecluster.conf,编辑集群的服务地址

#it is ip
#example
192.168.16.101:8847
192.168.16.102
192.168.16.103

编辑bin/startup,确保集群模式启动

export MODE="cluster"

其中的启动内存可以根据需求进行调整

JAVA_OPT="${JAVA_OPT} -server -Xms2g -Xmx2g -Xmn1g -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=320m"

其余服务器同理,一个服务器能启动后,其余可以直接拷贝过去

注意:搭建好集群后,服务端如果只向一个注册,如果宕机就无法注册,所以需要使用Nginx进行nacos的集群负载,nacos向Nginx的地址注册

简介
注册中心原理
服务注册
服务心跳
服务同步
服务发现
服务健康值
各注册中心对比
服务端安装
客户端安装
项目启动报错
项目启动出现WARN
服务相互调用
nacos集群