百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

微服务平台建设方案-配置中心

liuian 2025-01-15 15:16 35 浏览

书接上回,这篇文章先介绍Nacos的部署和配置中心的使用,并提供了演示代码

1.1 Nacos部署

Nacos 支持三种部署方式:

  • 单机模式 - 用于测试和单机试用;
  • 集群模式 - 用于生产环境,确保高可用;
  • 多集群模式 - 用于多数据中心场景;

1.1.1 单机模式

1.准备环境,Nacos 依赖Java 环境运行,安装JDK 1.8+版本;

2.下载安装包,目前最新版本是1.2.1,根据情况选择下载,下载地址https://github.com/alibaba/nacos/releases

下载后进入下载文件目录执行tar -xvzf nacos-server-1.2.1.tar.gz 解压文件

解压完成,cd nacos/bin

如果是linux/mac/Unix 操作系统运行 sh startup.sh -m standalone

如果是Windows操作系统运行cmd startup.cmd -m standalone

3.运行成功后打开浏览器访问 http://127.0.0.1:8848/nacos

4.输入用户名,密码登录。默认用户名,密码都是nacos

可以进行配置管理、服务管、集群管理、权限控制、命名空间管理

当前是单机部署,因此集群管理中只有一个节点

5.这种部署方式使用的是嵌入式的数据库进行的数据存储,如果想部署到Mysql 数据库,需要下面具体步骤:

① 安装Mysql 数据库,版本要求5.6.5+ (注意不支持mysql8.0, 可以自己修改源码),Mysql 的安装这里就不详细介绍了;

② 进入到nacos 安装目录下到conf目录, 可以看到conf 目录里有个nacos-mysql.sql 文件, 这个是nacos 数据库初始化脚本;

③ 运行mysql, 创建用户nacos_user,并创建数据库nacos。然后给nacos_user 授于访问nacos 数据库到权限。

我这里为了省事,赋予了nacos_user 所有到权限。

④ 切换到刚刚创建到nacos 数据库,然后执行source nacos-mysql.sql; 初始化数据库。

到此,数据库初始化安装完成。

⑤ 退出mysql,回到nacos 部署目录下到conf 目录,运行vim application.properties修改application.properties 文件,增加mysql 数据源配置。

我这里只修改了spring.datasource.platform (目前只支持mysql)、 数据库的数量 db.num(根据你的情况设置数据库数量)、数据库地址db.url.0 (注意这0,如果你有多个数据库可以添加多个数据库地址 db.url.1 、db.url.2)、用户名db.user、密码db.password

修改完成后,保存退出。

⑥ 回到nacos/bin 目录,sh shutdown.sh 停掉nacos服务,然后再次运行 sh startup.sh -m standalone 启动nacos服务,这样所有数据就会写到mysql 中了。

至此,nacos mysql 支持部署完成

6.修改nacos 登录密码,nacos 默认的密码是nacos ,你可以自己修改。打开浏览器输入http://127.0.0.1:8848/nacos 输入用户名,密码登录。登录后,就可以在权限控制中的用户列表里修改密码、创建用户等操作了。

1.1.2 集群模式

集群模式部署与单机没有什么区别,只是需要修改每个nacos服务的conf/cluster.conf 文件,添加上所有节点的ip及端口

多数据库配置参考单机模式中的修改application.properties 步骤。

配置好后,运行 sh startup.sh 命令,则nacos 以集群模式启动。

1.2 Nacos配置中心

写了一个小Demo 获取配置中心的配置内容,项目的结构如下图:

aiyun-bobby-support module 下是所有支撑层服务,现在只创建了配置服务aiyun-bobby-config , 以后再加其他服务。aiyun-bobby-demo 是测试代码

1.2.1 配置服务代码

  • 在Pom.xml 中添加下面的Starter
  • 在bootstrap.properties 中添加nacos 服务地址,注意一定要带上端口号,即使是80端口也要带上。Ip 地址也可以是域名。sping.cloud.nacos.config.file-extension要与配置中心配置的Data ID扩展名一致
  • aiyun-bobby-demo 添加aiyun-bobby-config 依赖
  • aiyun-bobby-demo 的application.yml 添加spring.application.name 这个name的值要与配置中心的Data ID 的值一样(去掉扩展名)
  • 运行代码,可以看到程序从远程到配置中心获取了配置值,这里我通过两种方式获取到配置信息,一种是@Value() ,另外一种方法是applicationContext.getEnvironment().getProperty();
  • 这里再说下Data ID,Data ID 的格式是 ${prefix}-${spring.profive.active}.${file-extension}

${prefix} 默认是spring.application.name的值

${spring.profive.active} 就是当前启用的profile,

${file-extension} 就是 sping.cloud.nacos.config.file-extension的值

当项目启动的时候spring-cloud-starter-alibaba-nacos-config 这个starter 会加载

${prefix}-${spring.profive.active}.${file-extension} 和${prefix}.${file-extension}

两个Data ID,获取配置信息。

我的配置中心配置了两个Data ID, demo-dev.yaml 和demo.yaml配置内容见下图:

演示代码地址:https://github.com/3280516588/aiyun-bobby

另外说一句:如果程序无法获取配置中心的配置信息,尝试重启下nacos服务。

相关推荐

Docker 47 个常见故障的原因和解决方法

【作者】曹如熙,具有超过十年的互联网运维及五年以上团队管理经验,多年容器云的运维,尤其在Docker和kubernetes领域非常精通。Docker是一种相对使用较简单的容器,我们可以通过以下几种方式...

电脑30个快问快答,解决常见电脑问题

1.强行关机/停电对电脑有影响吗?答:可能损坏硬盘(机械硬盘风险高)、未保存数据丢失,偶尔一次影响小,但频繁操作会缩短硬件寿命。2.C盘满影响速度吗?答:会!系统运行需C盘空间缓存临时数据,空间不...

使用Tcpdump包抓取分析数据包的详细用法

TcpDump可以将网络中传送的数据包的“头”完全截获下来提供分析。它支持针对网络层、协议、主机、网络或端口的过滤,并提供and、or、not等逻辑语句来帮助你去掉无用的信息。tcpdump就是一种...

电脑启动不了(BootDevice Not Found Hard Disk-3F0)解决方案

HP品牌机,开机启动不了,黑屏,开机取下主板电池恢复BIOS后,开机显示找不到启动盘。一、按F2键进入BIOS,出现硬盘内存检测界面的话,直接退出。就会出现这个界面,光标键向下,选择BIOSSetu...

电脑开机黑屏别慌!快码住!起底维修老师傅不能说的秘密

按下开机键却只收获黑屏大礼包?那些神秘的英文提示、刺耳的蜂鸣声,其实是电脑在给你发送求救信号!从按下电源到进入桌面的12秒里,你的电脑经历了史诗级的硬件自检与系统加载,今天我们就破译这段“摩斯电码”。...

电脑启动故障为何总要先看BIOS?新手必读的关键知识解析

最近在帮朋友们解答电脑无法正常开机的问题时,发现大家经常收到一句高频建议:“先检查BIOS”。对不少普通用户而言,BIOS依然是个神秘的存在。那么,BIOS到底是什么?电脑出现哪些故障会与它相关呢?本...

Windows 11 KB5053598更新:安全补丁还是系统噩梦?

2025年3月11日,微软发布了Windows1124H2的强制性更新KB5053598,作为“周二补丁日”(PatchTuesday)的一部分。然而,这款本应提升系统安全性的更新却引发了广泛的...

飞牛OS入门安装遇到问题,如何解决?

之前小编尝试了用旧电脑装飞牛OS安装之前特意查了一些硬件要求飞牛OS目前支持主流的x86架构硬件主机需能连网线飞牛OS暂时不支持只有无线网卡的安装貌似很多小伙伴在一开始安装就卡住了那今天咱们汇总分...

几种常见的电脑开机黑屏显示白色英文字母解决方法

当电脑开机出现黑屏并显示白色英文字母时,通常表示系统启动过程中遇到了错误。以下是几种常见原因及对应的解决方法,按照排查顺序整理:一、检查外接设备与硬件连接可能原因:外接U盘、移动硬盘等未拔出,或内部硬...

电脑启动出现问题,为什么都要先检查BIOS?

【ZOL中关村在线原创技巧应用】最近在回答问题的时候,总会发现很多朋友都在问“电脑无法正常开机怎么办?”这样类似的问题,而许多DIY大佬的回复总会出现一条高频建议“先检查BIOS”。但对于许多普通用户...

教你怎么用JavaScript检测当前浏览器是无头浏览器

什么是无头浏览器(headlessbrowser)?无头浏览器是指可以在图形界面情况下运行的浏览器。我可以通过编程来控制无头浏览器自动执行各种任务,比如做测试,给网页截屏等。为什么叫“无头”浏览器?...

12个高效的Python爬虫框架,你用过几个?

实现爬虫技术的编程环境有很多种,Java、Python、C++等都可以用来爬虫。但很多人选择Python来写爬虫,为什么呢?因为Python确实很适合做爬虫,丰富的第三方库十分强大,简单几行代码便可实...

运维的报表之路,用 node.js 轻松发送 grafana 报表

在运维过程中,无论是监控还是报表,都会有一些通过邮件发送图表的需求,由于开源的zabbix,grafana和kibana等并不完全具有“想发送哪儿就发送哪儿”的图片生成功能,在grafana...

C#基于浏览器内核的高级爬虫(c#爬取网页内容)

基于C#.NET+PhantomJS+Sellenium的高级网络爬虫程序。可执行Javascript代码、触发各类事件、操纵页面Dom结构、甚至可以移除不喜欢的CSS样式。很多网站都用Ajax动态加...

如何优化一个秒杀项目?(秒杀实现思路)

问题1:使用jmeter性能压测,定位瓶颈代码步骤流程:线程组--->Http请求--->查看结果树--->聚合报告tips:host的文件--->优先调用映射,减少DNS的时...