Apollo
Apollo(Github主页)是携程框架部门研发的配置管理平台,能够集中化管理应用不同环境、不同集群的配置,配置修改后能够实时推送到应用端,并且具备规范的权限、流程治理等特性
Apollo(阿波罗)是携程框架部门研发的分布式配置中心,能够集中化管理应用不同环境、不同集群的配置,配置修改后能够实时推送到应用端,并且具备规范的权限、流程治理等特性,适用于微服务配置管理场景。
服务端基于Spring Boot和Spring Cloud开发,打包后可以直接运行,不需要额外安装Tomcat等应用容器。
Java客户端不依赖任何框架,能够运行于所有Java运行时环境,同时对Spring/Spring Boot环境也有较好的支持。
.Net客户端不依赖任何框架,能够运行于所有.Net运行时环境。
(摘自Apollo的github)
编译源码
- 下载github源码
git clone https://github.com/ctripcorp/apollo.git
下载完成
$ git clone https://github.com/ctripcorp/apollo.git
Cloning into 'apollo'...
remote: Counting objects: 86952, done.
Receiving objects: 6% (5218/86952), 1.46 MiB | 28.00 KiB/s
Receiving objects: 6% (5220/86952), 1.46 MiB | 28.00 KiB/s
remote: Total 86952 (delta 0), reused 0 (delta 0), pack-reused 86951
Receiving objects: 100% (86952/86952), 39.25 MiB | 27.00 KiB/s, done.
Resolving deltas: 100% (68109/68109), done.
-
导入eclipse
Package Explorer -->右键选择-->Maven-->Existing Maven Projects
准备环境
- JDK需要1.8+
$ java -version
java version "1.8.0_121"
Java(TM) SE Runtime Environment (build 1.8.0_121-b13)
Java HotSpot(TM) 64-Bit Server VM (build 25.121-b13, mixed mode)
- mysql需要5.6.5+,使用sql查询:select version();
- 执行数据库初始化脚本 ,数据库脚本在 /apollo/scripts/sql 目录下:apolloconfigdb.sql、apolloportaldb.sql 两个文件中;
- 修改数据库配置信息:/apollo/scripts/build.sh 文件中
编译项目
运行 /apollo/scripts/build.sh 编译项目
项目部署
- 部署apollo-configservice
将apollo-configservice/target/目录下的apollo-configservice-x.x.x-github.zip上传到服务器上,解压后执行scripts/startup.sh即可。如需停止服务,执行scripts/shutdown.sh.
注意:记得在startup.sh中按照实际的环境设置一个JVM内存和参数
- 部署apollo-adminservice
将apollo-adminservice/target/目录下的apollo-adminservice-x.x.x-github.zip上传到服务器上,解压后执行scripts/startup.sh即可。如需停止服务,执行scripts/shutdown.sh.
注意:记得在startup.sh中按照实际的环境设置一个JVM内存和参数
- 部署apollo-portal
将apollo-portal/target/目录下的apollo-portal-x.x.x-github.zip上传到服务器上,解压后执行scripts/startup.sh即可。如需停止服务,执行scripts/shutdown.sh.
注意:记得在startup.sh中按照实际的环境设置一个JVM内存和参数
- 部署apollo-client
apollo-client客户端jar包中会包含meta server信息,无法上传一个统一的jar包到中央仓库,所以需要自己打包并上传到自己公司的Maven私服。
build.sh生成的jar包,使用maven命令传到私服中。
访问portal,创建应用并添加配置
- portal访问地址:IP+Port ;IP是部署apollo-portal的机器IP,portal是start.sh中设置的SERVER_PORT,若portal与configservice部署在一台机器上,可修改portal的端口为8070;
portal的默认用户名/密码是apollo/admin