spring boot是一个开发java应用程序的框架,而nacos是一个用于配置管理和服务发现的开源平台。
在spring boot项目中使用nacos作为配置中心,可以实现动态配置管理和实时更新配置的能力。
一、nacos服务端配置命名空间和yml文件
注意:建议大家以自己的名字全拼命名,防止大家搞混
yml 与properties文件区别?
yml(yaml)和properties文件是两种常见的配置文件格式,用于存储应用程序或系统的配置信息。
它们有以下区别:
- 语法结构:yml使用缩进和冒号来表示层级关系,而properties文件使用键值对的形式表示配置项。
- 可读性:yml文件使用缩进和结构化的语法,因此更易于阅读和理解。相比之下,properties文件使用简单的键值对结构,可读性较差。
- 复杂性:yml文件支持更复杂的数据结构,如列表、嵌套对象等,可以更灵活地表示配置信息。properties文件只支持简单的键值对,不支持复杂数据结构。
- 扩展性:yml文件可以轻松地添加注释,以及处理更复杂的配置需求。properties文件不支持注释,且在处理复杂配置时可能变得冗长和难以维护。
- 应用场景:yml文件适用于需要更复杂结构和层级关系的配置信息,例如spring boot应用程序的配置文件。properties文件适用于简单的键值对配置,常用于java应用程序的配置文件。
二、创建springboot项目
在idea中左上角选择【file】,右击选择【new】,右击选择【project】
此处我们要建立的是springboot项目,在左边的列表中选择【spring initializer】,填写项目的名称,配置jdk版本,此处根据自己的实际需要进行配置即可,完成之后点击【next】
展开【web】下拉列表,勾选上【spring web】,完成后点击【finish】
项目创建成功之后我们会发现会有很多文件夹和文件,我们只需要留下【pom.xml】文件即可,其余文件我们暂时用不到可以先删除
在父pom.xml中添加spring boot,spring cloud,spring cloud alibaba三个依赖
<dependencymanagement> <dependencies> <!--spring boot,spring cloud,spring cloud alibaba--> <!--选用官网稳定的版本--> <dependency> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-dependencies</artifactid> <version>2.3.12.release</version> <type>pom</type> <scope>import</scope> </dependency> <dependency> <groupid>org.springframework.cloud</groupid> <artifactid>spring-cloud-dependencies</artifactid> <version>hoxton.sr12</version> <type>pom</type> <scope>import</scope> </dependency> <dependency> <groupid>com.alibaba.cloud</groupid> <artifactid>spring-cloud-alibaba-dependencies</artifactid> <version>2.1.2.release</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencymanagement>
修改父pom.xml中配置的springboot版本
可能会出现版本不兼容的问题,我们在这里将springboot版本修改为【2.3.12.release】
三、创建子服务
这时候我们要新建两个子服务
点击项目名【nacosinstance】右击选择【new】,右击选择【module】
要创建两个子服务都是普通的maven项目,所以这里我们选择【maven】就可以,完成后点击【next】
输入新创建服务的名称和地址,完成后点击【finish】
此时项目中就多了一个名叫order-service的服务,我们为新添加的服务配置nacos依赖,点击进入oser-service服务的【pom.xml】文件
<dependencies> <!-- nacos服务注册/发现--> <dependency> <groupid>com.alibaba.cloud</groupid> <artifactid>spring-cloud-starter-alibaba-nacos-discovery</artifactid> </dependency> <!--nacos配置中心来做配置管理--> <dependency> <groupid>com.alibaba.cloud</groupid> <artifactid>spring-cloud-starter-alibaba-nacos-config</artifactid> </dependency> <dependency> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-starter-web</artifactid> </dependency> </dependencies>
在order-service子服务的src文件夹中,选择【resources】右击新建一个yml配置文件,并进行nacos的配置
server: port: 9000 servlet: context-path: /order-service spring: cloud: nacos: discovery: server-addr: 152.136.111.77:5555 namespace: 10ecded1-361f-45d7-a009-ad2355304ff5 config: server-addr: 152.136.111.77:5555 namespace: 10ecded1-361f-45d7-a009-ad2355304ff5 prefix: order file-extension: yml application: name: order
四、controller编写
在order-service服务中按照下图的格式新建两个文件,分别为启动类和请求类
在【ordercontroller】类中编写请求的逻辑代码
package order.controller; import org.springframework.stereotype.controller; import org.springframework.web.bind.annotation.getmapping; import org.springframework.web.bind.annotation.requestmapping; import org.springframework.web.bind.annotation.restcontroller; @restcontroller @requestmapping("/placeorder") @controller public class ordercontroller { @getmapping("/order") public string placeorder(){ return "已下单"; } }
在【orderserviceapplication】类中编写程序启动逻辑
package order; import org.springframework.boot.springapplication; import org.springframework.boot.autoconfigure.springbootapplication; import org.springframework.cloud.client.discovery.enablediscoveryclient; @springbootapplication @enablediscoveryclient public class orderserviceapplication { public static void main(string[] args) { springapplication.run(orderserviceapplication.class, args); } }
五、tomcat启动程序
配置成功
此时,我们再次在浏览器中打开nacos服务端,点击【服务列表】,我们配置的order-service服务就注册成功啦!!
总结
通过以上步骤,就可以在spring boot项目中使用nacos作为配置中心,并实现动态配置管理。
在nacos中更新配置后,应用程序将自动获取最新的配置值。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。
发表评论