SpringCloud Alibaba项目实战之nacos-server服务搭建过程


Posted in Java/Android onJune 21, 2021
目录
  • 1、Nacos简介
    • 1.1、什么是Nacos
    • 1.2、Nacos基本原理
  • 2、Nacos-Server服务部署
    • 2.1、standalone 模式
    • 2.2、cluster 模式

源码地址:https://gitee.com/fighter3/eshop-project.git

持续更新中……

大家好,我是三分恶。

这一节我们来学习SpringCloud Alibaba体系中一个非常重要的组件——Nacos。

 

1、Nacos简介

Nacos官方网站:https://nacos.io/zh-cn/

 

1.1、什么是Nacos

Nacos是阿里巴巴开源的一个动态服务发现、配置管理和服务管理平台。

Nacos英文全称Dynamic Naming and Configuration Service,Na为naming/nameServer即注册中心,co为configuration即注册中心,service是指该注册/配置中心都是以服务为核心。

SpringCloud Alibaba项目实战之nacos-server服务搭建过程

Nacos 无缝支持一些主流的开源生态,使用Nacos,可以简化服务发现、配置管理、服务治理及管理。

如果要把Nacas和SpringCloud Netflix的组件对标的话,那么:

Nacos = Eureka/Consule + Config + Admin

 

1.2、Nacos基本原理

Nacos作为注册中心分为server与client。

SpringCloud Alibaba项目实战之nacos-server服务搭建过程

Server采用Java编写,为client提供注册发现服务与配置服务。而client可以用多语言实现,client与微服务嵌套在一起,nacos提供sdk和openApi,如果没有sdk也可以根据openApi手动写服务注册与发现和配置拉取的逻辑。

1.2.1、注册中心原理

SpringCloud Alibaba项目实战之nacos-server服务搭建过程

服务注册方法:服务注册的策略的是每5秒向nacos server发送一次心跳,心跳带上了服务名,服务ip,服务端口等信息。同时 nacos server也会向client 主动发起健康检查,支持tcp/http检查。如果15秒内无心跳且健康检查失败则认为实例不健康,如果30秒内健康检查失败则剔除实例。

1.2.2、配置中心原理

SpringCloud Alibaba项目实战之nacos-server服务搭建过程

 

2、Nacos-Server服务部署

Nacos 依赖 Java 环境来运行。如果是从代码开始构建并运行Nacos,还需要配置 Maven环境。我们直接使用发行版,需要保证JDK版本在1.8以上。

Nacos Server 有两种运行模式:

  • standalone
  • cluster

 

2.1、standalone 模式

我们使用win10来进行Nacos Server的standalone 模式的部署。

下载nacos-server

从https://github.com/alibaba/nacos/releases 下载nacos-server发行版。

官方推荐的版本是1.4.2或2.0.1。

SpringCloud Alibaba项目实战之nacos-server服务搭建过程

按照官方推荐,我们来尝(踩)鲜(坑)最新的发行版2.0.1,下载压缩包,下载完成后解压

SpringCloud Alibaba项目实战之nacos-server服务搭建过程

启动nacos-server服务

进入%path%\nacos\bin文件夹,执行cmd命令startup.cmd -m standalone,其中-m standalone指定为单机模式,否则以cluster集群模式启动。

SpringCloud Alibaba项目实战之nacos-server服务搭建过程

可以看到Nacos Server的地址,访问 http://192.168.31.39:8848/nacos/index.html

需要登录,初始账号/密码是 nacos/nacos

SpringCloud Alibaba项目实战之nacos-server服务搭建过程

登录之后可以看到Nacos的控制台。

SpringCloud Alibaba项目实战之nacos-server服务搭建过程

Linux下部署Nacos-Server服务也是类似,同样是先解压发行压缩包,然后执行启动脚本启动:

startup.sh -m standalone

这种默认情况下,我们的数据写入了了嵌入式数据库。不太方便观察数据存储的情况,nacos也提供了支持mysql数据源的能力。

注意:以下操作我在2.0.1版本失败了,所以以下操作是基于1.4.2版本。

MySQL数据库版本要求5.5以上。

1.创建数据库库,使用初始化文件nacos-mysql.sql初始化

SpringCloud Alibaba项目实战之nacos-server服务搭建过程

2.修改conf/application.properties文件,增加支持mysql数据源配置(目前只支持mysql),修改mysql数据源的url、用户名和密码。

spring.datasource.platform=mysql

### Count of DB:
db.num=1

### Connect URL of DB:
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=root
db.password.0=root

### Connection pool configuration: hikariCP
db.pool.config.connectionTimeout=30000
db.pool.config.validationTimeout=10000
db.pool.config.maximumPoolSize=20
db.pool.config.minimumIdle=2

使用命令startup.cmd -m standalone启动Nacos Server

SpringCloud Alibaba项目实战之nacos-server服务搭建过程

 

2.2、cluster 模式

开发和测试,我们直接用standalone 模式,OK,没什么问题。但是生产环境,为了保证Nacos的高可用,我们就得使用 cluster模式。

cluster 模式必须要用 MySQL,MySQL数据导入和上面一致,然后改两个配置文件:

conf/cluster.conf
conf/application.properties

大致如下:

cluster.conf,填入要运行 Nacos Server 机器的 ip

192.168.100.155
192.168.100.156
192.168.100.157   

修改NACOS_PATH/conf/application.properties,加入 MySQL 配置

db.num=1
db.url.0=jdbc:mysql://localhost:3306/nacos_config?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true
db.user=root
db.password=root

Nacos采用的一个Leader节点,多个Follower节点的集群架构,数据一致性算法采用的是Raft。

SpringCloud Alibaba项目实战之nacos-server服务搭建过程

至于实战,由于机器资源资源原因,这里就不再演示。

SpringCloud Alibaba项目实战之nacos-server服务搭建过程

下一节,我们会把服务注册到Nacos注册中心,敬请期待!

"简单的事情重复做,重复的事情认真做,认真的事情有创造性地做!"——

我是三分恶,可以叫我老三/三分/三哥/三子,一个能文能武的全栈开发,咱们下期见!

参考:

【1】:Nacos 文档

【2】:什么是Nacos?Nacos注册配置中心介绍

【3】:Spring Cloud实战 | 第一篇:Windows搭建Nacos服务

【4】:nacos 实战(史上最全)

【5】:Nacos部署环境

以上就是SpringCloud Alibaba项目实战之nacos-server服务搭建过程的详细内容,更多关于SpringCloud Alibaba nacos-server搭建的资料请关注三水点靠木其它相关文章!

Java/Android 相关文章推荐
Java方法重载和方法重写的区别到底在哪?
Jun 11 Java/Android
Java新手教程之ArrayList的基本使用
Jun 20 Java/Android
使用feign服务调用添加Header参数
Jun 23 Java/Android
Java基础之this关键字的使用
Jun 30 Java/Android
解析mybatis-plus中的resultMap简单使用
Nov 23 Java/Android
利用Sharding-Jdbc进行分库分表的操作代码
Jan 22 Java/Android
JAVA长虹键法之建造者Builder模式实现
Apr 10 Java/Android
JAVA 线程池(池化技术)的实现原理
Apr 28 Java/Android
MyBatis核心源码深度剖析SQL语句执行过程
May 20 Java/Android
Java中生成微信小程序太阳码的实现方案
Jun 01 Java/Android
ConditionalOnProperty配置swagger不生效问题及解决
Jun 14 Java/Android
Spring boot实现上传文件到本地服务器
Aug 14 Java/Android
java中重写父类方法加不加@Override详解
Jun 21 #Java/Android
Java并发编程之Executor接口的使用
深入理解以DEBUG方式线程的底层运行原理
浅谈什么是SpringBoot异常处理自动配置的原理
SpringAop日志找不到方法的处理
详解SpringBoot异常处理流程及原理
Java新手教程之ArrayList的基本使用
You might like
模仿OSO的论坛(三)
2006/10/09 PHP
加速XP搜索功能堪比vista
2007/03/22 PHP
php 启动报错如何解决
2014/01/17 PHP
PHP使用mysqldump命令导出数据库
2015/04/14 PHP
PHP中文字符串截断无乱码解决方法
2016/10/10 PHP
javascript与CSS复习(三)
2010/06/29 Javascript
js实现向右横向滑出的二级菜单效果
2015/08/27 Javascript
jQuery-1.9.1源码分析系列(十)事件系统之事件包装
2015/11/20 Javascript
jQuery中使用animate自定义动画的方法
2016/05/29 Javascript
Jquery Easyui进度条组件Progress使用详解(8)
2020/03/26 Javascript
js Canvas绘制圆形时钟效果
2017/02/17 Javascript
微信小程序左右滑动切换页面详解及实例代码
2017/02/28 Javascript
nodejs入门教程四:URL相关模块用法分析
2017/04/24 NodeJs
详解使用Vue Router导航钩子与Vuex来实现后退状态保存
2017/09/11 Javascript
vue2.0 路由不显示router-view的解决方法
2018/03/06 Javascript
快速解决vue-cli在ie9+中无效的问题
2018/09/04 Javascript
express启用https使用小记
2019/05/21 Javascript
Vue实现回到顶部和底部动画效果
2019/07/31 Javascript
Vue 按照创建时间和当前时间显示操作(刚刚,几小时前,几天前)
2020/09/10 Javascript
Nuxt 项目性能优化调研分析
2020/11/07 Javascript
微信小程序实现页面左右滑动
2020/11/16 Javascript
python自定义解析简单xml格式文件的方法
2015/05/11 Python
Python中处理字符串之isalpha()方法的使用
2015/05/18 Python
深入浅析ImageMagick命令执行漏洞
2016/10/11 Python
python利用Guetzli批量压缩图片
2017/03/23 Python
Python 逐行分割大txt文件的方法
2017/10/10 Python
利用Python如何实现数据驱动的接口自动化测试
2018/05/11 Python
python安装twisted的问题解析
2018/08/21 Python
Flask框架中request、请求钩子、上下文用法分析
2019/07/23 Python
HTML5之消息通知的使用(Web Notification)
2018/10/30 HTML / CSS
ManoMano英国:欧洲第一家专注于DIY和园艺市场的电商平台
2020/03/12 全球购物
会计专业大学生职业生涯规划范文
2014/01/11 职场文书
优秀公益广告词大全
2014/03/19 职场文书
锦旗赠语
2015/06/23 职场文书
nginx搭建图片服务器的过程详解(root和alias的区别)
2021/03/31 Servers
mongoDB数据库索引快速入门指南
2022/03/23 MongoDB