Nacos服务配置中心
目前,基于微服务框架的大量使用,我们对于各个独立的微服务的配置也增多,所有的配置文件都放在项目中,如果需要修改配置文件内容,则需要登陆服务器重启服务,这些问题都可以引入配置中心来解决。
目前已有的配置中心
- Apollo:数据保存在mysql中,支持命名空间和分发更新配置
- springcloud config:必须使用git保存配置信息
- Nacos
Nacos
Nacos是阿里巴巴集团开源的一个易于使用的平台,专为动态服务发现,配置和服务管理而设计。
Nacos 的关键特性包括:
- 服务发现和服务健康监测
- 动态配置服务
- 动态 DNS 服务
- 服务及其元数据管理
使用 Nacos 简化服务发现、配置管理、服务治理及管理的解决方案,让微服务管理、共享、组合更加容易
部署过程
- 在docker中部署nacos
可以坐在本地服务器或阿里云服务器上通过运行nacos文件夹里的docker-compose.yaml文件,在docker容器中注册nacos
version: "3"
services:
nacos:
image: nacos/nacos-server:latest
container_name: nacos-standalone
environment:
- PREFER_HOST_MODE=hostname
- MODE=standalone
volumes:
- ./standalone-logs/:/home/nacos/logs
- ./init.d/custom.properties:/home/nacos/init.d/custom.properties
ports:
- 8848:8848
prometheus:
container_name: prometheus
image: prom/prometheus:latest
volumes:
- ./prometheus/prometheus-standalone.yaml:/etc/prometheus/prometheus.yml
ports:
- 9090:9090
depends_on:
- nacos
restart: on-failure
grafana:
container_name: grafana
image: grafana/grafana:latest
ports:
- 3000:3000
restart: on-failure
- 之后可通过8848端口访问nacos管理界面
3.将各个微服务的配置类application.yml中相同配置提取出来,在nacos中配置all-service.yml作为公共配置
4.在nacos中配置各个微服务的模块,如shop-user-dev.yml,配置模块的端口
5.配置gateway.yml,作为nacos服务配置中心
- 将各个模块application.yml注释后,配置新的配置bootstrap.yml
spring:
application:
name: shop-user
cloud:
nacos:
config:
server-addr: localhost:8848
file-extension: yml
shared-configs[0]:
data-id: all-service.yml
refresh: true
profiles:
active: dev # 环境标识
保存发布,然后启动springboot服务,根据gateway.yml的端口7000和各个模块名进行访问模块资源,如
http://localhost:7000/shop-user/swagger-ui.html
配置自动刷新
在配置的类增加@RefreshScope就可以实现自动刷新配置,当nacos中的配置修改后,项目无需重启就可以自动生效,这个在实际生产环境中是很有用的,有时候你需要修改线上的配置,如果没有配置中心,你需要重启服务
配置中心一般用于管理复杂的配置,比如在分布式项目中的配置管理,虽然配置中心可以简化配置,但如果是很小的项目就没有必要把配置单独出来,其实就放在项目中还方便一些