淘东电商项目(10) -Apollo分布式配置中心管理application.yml

简介: 淘东电商项目(10) -Apollo分布式配置中心管理application.yml

引言

在上一节《淘东电商项目(09) -Maven私服的上传与下载详解》,主要讲解了如何上传jar包到Maven私服以及如何从Maven私服下载jar包。

代码已提交至Github(版本号:89dc5fb93f251f2c1c2d6f8b7c4362c721da685a),有兴趣的同学可以下载来看看:https://github.com/ylw-github/taodong-shop

本文继续讲解分布式基础设施环境的搭建,主要讲解Apollo分布式配置中心,以及如何把微服务的配置文件application.yml全部托管到Apollo。

本文目录结构:

l____引言

l____ 1. Apollo搭建与配置

l________ 1.1 Apollo搭建配置

l________ 1.2 Apollo启动

l____ 2. Apollo管理application.yml

l________ 2.1 Apollo创建项目

l________ 2.2 application.yml托管到Apollo

l________ 2.3 项目集成Apollo

l____ 3. 其它

l____总结

1. Apollo环境搭建与配置

1.1 Apollo搭建配置

《分布式系列课程》里,我曾写过关于Apollo环境搭建的教程,大家可以参考《分布式配置中心Apollo安装与详解》

因为我是直接把文章中的Apollo的系统完整克隆出来的,所以要修改里面的服务器地址(旧的ip是192.168.162.131,新的地址是192.168.162.135),修改的地方有:

  • ApolloConfigDB数据库里面的ServerConfig表中的eureka.service.url字段
  • 编辑Apollo解压目录下demo.sh文件,内容如下:

1.2 Apollo启动

1.启动MySQL数据库(版本5.7以上)

2.启动Apollo配置中心,启动脚本在安装目录下的demo.sh文件:

./demo.sh start

启动成功如下图:

3.登录账号:apollo,密码:admin

4.登录成功

2. Apollo管理application.yml

2.1 Apollo创建项目

step1.登录Apollo,创建项目(这里的项目其实就是每个部门管理的微服务),以微信微服务为例子:

step2.输入部门的id、微服务名称、负责人等信息

step3.

2.2 application.yml托管到Apollo

step1.首先转换微信服务项目(taodong-shop-service-weixin)的applicatoin.yml为apollo识别的格式(properties),转换网站:http://www.toyaml.com/index.html

step2.打开Apollo文本模式:

step3.复制转换后的内容到Apollo中的app-service-weixin项目,复制内容如下(为了方便测试,我把Eureka注册中心改为Apollo的注册中心地址了eureka.client.service-url.defaultZone=http://192.168.162.135:8080/eureka):

server.port=8200
spring.application.name=taodong-shop-service-weixin
eureka.client.service-url.defaultZone=http://localhost:8100/eureka
swagger.base-package=com.ylw.taodong
swagger.title=淘东电商项目-微信服务接口
swagger.description=该项目“基于SpringCloud2.x构建微服务电商项目。
swagger.version=1.1
swagger.terms-of-service-url=www.xxx.com
swagger.contact.name=杨林伟
swagger.contact.email=xxxxxx@qq.com

step4.点击勾保存,可以看到Table视图下,配置文件都自动生成了。

step5. 点击发布,可以看到下面的状态都变为已发布了:

2.3 项目集成Apollo

step1.删除微信微服务的application.yml

step2.新增maven依赖(增加到服务模块的pom.xml文件taodong-shop-service):

<dependency>
  <groupId>com.ctrip.framework.apollo</groupId>
  <artifactId>apollo-client</artifactId>
  <version>1.0.0</version>
</dependency>
<dependency>
  <groupId>com.ctrip.framework.apollo</groupId>
  <artifactId>apollo-core</artifactId>
  <version>1.0.0</version>
</dependency>

step3.在resources文件夹目录下创建 application.properties文件,并填写apollo相关的配置信息:

app.id=app-service-weixin
apollo.meta=http://192.168.162.135:8080

step4.项目启动开启阿波罗配置文件@EnableApolloConfig:

@SpringBootApplication
@EnableEurekaClient
@EnableSwagger2Doc
@EnableApolloConfig
public class AppWeiXin {
    public static void main(String[] args) {
        SpringApplication.run(AppWeiXin.class, args);
    }
}

step5.启动项目,发现没有报错,控制台的内容与配置的信息apollo配置中心的内容都一致:

3. 其它

1.为什么要使用分布式配置中心?

答:统一管理微服务配置文件,可以实现动态化刷新配置文件。


2.为什么我们要使用阿波罗不使用SpringCloudConfig?

答:阿波罗配置文件存放在数据库中,SpringCloudConfig存放在Git里面。


3.如果关闭了Apollo配置中心,还能读取到内容吗?

答:还是可以读取到的,内容会缓存到项目本地项目文/classes/config-cache/app-service-weixin+default+application.properties


4.如果Apollo配置了服务器访问端口,不重启,能生效吗?

答:不可以,因为只会Apollo发布了配置信息之后,微服务会监听到配置信息的改变,刷新到JVM。但是项目在启动的时候就从配置文件获取到了端口,而非JVM,所以即使变化了,也不能在不重启的情况下直接改变端口号。

总结

目录
相关文章
|
19天前
|
UED 存储 数据管理
深度解析 Uno Platform 离线状态处理技巧:从网络检测到本地存储同步,全方位提升跨平台应用在无网环境下的用户体验与数据管理策略
【8月更文挑战第31天】处理离线状态下的用户体验是现代应用开发的关键。本文通过在线笔记应用案例,介绍如何使用 Uno Platform 优雅地应对离线状态。首先,利用 `NetworkInformation` 类检测网络状态;其次,使用 SQLite 实现离线存储;然后,在网络恢复时同步数据;最后,通过 UI 反馈提升用户体验。
33 0
|
1月前
|
Java 测试技术 Spring
分布式之配置中心
分布式之配置中心
34 1
|
3月前
|
机器学习/深度学习 人工智能 自然语言处理
人工智能平台PAI产品使用合集之如何配置cluster系统自动生成分布式参数
阿里云人工智能平台PAI是一个功能强大、易于使用的AI开发平台,旨在降低AI开发门槛,加速创新,助力企业和开发者高效构建、部署和管理人工智能应用。其中包含了一系列相互协同的产品与服务,共同构成一个完整的人工智能开发与应用生态系统。以下是对PAI产品使用合集的概述,涵盖数据处理、模型开发、训练加速、模型部署及管理等多个环节。
|
3月前
|
网络安全 数据安全/隐私保护
分布式系统详解--框架(Hadoop-Ssh免密登陆配置)
分布式系统详解--框架(Hadoop-Ssh免密登陆配置)
36 0
|
4月前
|
Cloud Native Java 开发工具
云原生 阿里云分布式文件系统 对象存储OSS 服务配置
【1月更文挑战第8天】云原生 阿里云分布式文件系统 对象存储OSS 服务配置
|
4月前
|
安全
考虑极端天气线路脆弱性的配电网分布式电源和储能优化配置模型
考虑极端天气线路脆弱性的配电网分布式电源和储能优化配置模型
|
4月前
|
调度
互动环境下分布式电源与电动汽车充电站的优化配置方法研究-全文复现matlab
互动环境下分布式电源与电动汽车充电站的优化配置方法研究-全文复现matlab
单向/双向V2G环境下分布式电源与电动汽车充电站联合配置方法(matlab代码)
单向/双向V2G环境下分布式电源与电动汽车充电站联合配置方法(matlab代码)
|
4月前
|
调度
考虑充电负荷空间可调度特性的分布式电源与电动汽车充电站联合配置方法(matlab代码)
考虑充电负荷空间可调度特性的分布式电源与电动汽车充电站联合配置方法(matlab代码)
|
4月前
|
存储 分布式计算 Hadoop
[绝对要收藏]配置hadoop完全分布式环境
[绝对要收藏]配置hadoop完全分布式环境
40 0