Apollo config server for Aditum. Aditum Apollo配置中心.
使用Ctrip-Apollo配置中心,进行微服务的配置管理,将Apollo部署在云服务器上,通过网络进行配置访问获取.
本地快速部署 (用于本地开发和测试)
预计需要以下镜像和容器:
docker images #展示镜像
docker ps #展示运行容器
docker ps -a #展示所有容器
docker build ...... #根据dockerfile创建镜像
docker run ........ #根据镜像创建容器并设定初始配置
docker exec -it name bash #进入相关容器的命令行交互,例如进行mysql容器
docker logs name #查看容器运行日志
docker rm 容器名 #删除容器
docker rmi 镜像名 #删除镜像
docker start 容器名 #启动未启动的容器
docker stop 容器名 #关闭启动的容器
......
-
拉取mysql镜像,当前默认版本为8.0.11
-
启动容器,注意,为了方便操作,应该指定端口映射为 3306->3306;同时指定默认密码
-
进行配置更改,允许远程访问,并设置默认密码格式(mysql8更改了默认格式,导致Navicat连接不上)
mysql_secure_installation
使用mysql8的相关命令进行授权和密码默认格式修改。注意,不要使用低版本的语言,会失败,从网上搜索mysql8的授权和默认密码格式修改方式即可。
- 使用Navicat等工具访问主机ip:3306进行验证,若报错,根据错误信息搜索进行解决。
注意: 配置防火墙,放通相关端口,一是使用云服务器配置界面,二是进入iptables手动修改。
思考: 直接使用docker部署mysql服务,是可行的。但若是删除容器,那么数据也就损失了,解决方式是通过外挂数据卷,docker中仅保留外部数据的引用。 对于mysql的docker化,同程旅游进行了大规模实践,可通过搜索引擎搜索他们的实践经验。(为了方便,我没有使用外挂数据卷,留待日后使用)
前提,配置好mysql数据库中的apollo必需数据库,连接到mysql容器,然后执行官方提供的sql文件即可。
-
下载官方Release包:共三个zip文件
-
修改三个包中的配置信息,/config/目录下的配置文件,若三个服务都在本地,那么直接将ip设为本机的ip地址(不能是localhost)
因为三个包分别部署为三个docker容器,而docker容器的localhost指向的是容器内部,所以必须将localhost修改为外部地址
- 使用主机地址代替localhost(方便)
- 使用容器地址代替localhost
-
修改配置文件中的mysql地址,同理,若mysql容器在本地,那么将ip直接设为主机ip即可
-
下载三个包的相关dockerfile,并修改其中的版本信息
以上内容全部在docker/apollo中
-
将三个包上传到服务器,每个包包含一个zip和一个dockerfile
-
进入相应目录,执行dockerfile构建命令(在相应的dockerfile文件的注释部分有)
-
三个容器构建完成,可以使用apollo服务
注意:同理,数据库中eureka注册链接(ApolloConfigDB.ServerConfig)默认为localhost,需要修改为主机ip地址
- 引入pom依赖
<dependency>
<groupId>com.ctrip.framework.apollo</groupId>
<artifactId>apollo-client</artifactId>
<version>1.2.0</version>
</dependency>
- 启用客户端注解
@EnableApolloConfig
-
设置配置项
app.id信息是应用的信息,对一个应用而言是不会变的,所以放在META-INF/app.properties下面
env信息是机器的属性,不是应用的属性,所以是放在机器上的server.properties或者是通过-D传入
meta server信息是apollo-core.jar的配置属性,我们建议是直接打进包里,这样使用方使用的时候就不需要做额外配置了。apollo-env.properties也支持外置化,不过配置内容是dev.meta=xxx
namespace是代码的一部分,这个就看你怎么弄了,写死在代码中也可以,放在application.yml中也可以
(1) 在resources下建立META-INF/app.properties文件,写入 app.id=AditumConfig
(2) 在server.properties中指定开发环境
通过配置文件
最后一个推荐的方式是通过配置文件来指定env=YOUR-ENVIRONMENT
对于Mac/Linux,文件位置为/opt/settings/server.properties
对于Windows,文件位置为C:\opt\settings\server.properties
文件内容形如:
env=DEV
(3) 在application.yml启动文件中写入apollo配置信息:
apollo:
# config server 地址(若外网访问会解析成内网地址,需使用-D参数跳过)
meta: http://47.106.11.84:8080
bootstrap:
enabled: true
# 使用公共命名空间和微服务私有命名空间
namespaces: application
注意: 若远程访问云主机,则外网地址会被解析成内网地址无法访问,需使用JVM启动参数:
[-Dapollo.configService=http://47.106.11.84:8080]
避免进行内网解析
- 配置文件:
通过 ${配置项key:获取失败的默认值} 进行使用,例如
server:
port: ${port:10001}
- java程序:
使用 @Value('${配置项key:获取失败的默认值}')进行访问,例如
/**
* Apollo 配置获取客户端
*/
@Configuration
@EnableApolloConfig
public class ApolloConfigBean {
@Value("${timeout:20}")
private int timeout;
public int getTimeout() {
return timeout;
}
@Override
public String toString() {
return "ApolloConfigBean{" +
"timeout=" + timeout +
'}';
}
}