当前位置:   article > 正文

CentOS7安装部署Apollo分布式配置管理系统

apollo centos容器部署

Apollo简介

Apollo(阿波罗)是携程框架部门研发的分布式配置中心,能够集中化管理应用不同环境,不同分配的配置,配置修改后能够实时推送到应用端,并且具有规范的权限,流程治理等特性,适用于微服务配置管理场景。

Apollo背景

随着程序功能的日益复杂,程序的配置日益增多:各种功能的开关、参数的配置、服务器的地址……
对程序配置的期望值也越来越高:配置修改后实时生效,灰度发布,分环境、分集群管理配置,完善的权限、审核机制……
在这样的大环境下,传统的通过配置文件、数据库等方式已经越来越无法满足开发人员对配置管理的需求。
Apollo配置中心应运而生!

准备工作

首先将系统内的软件包升级到最新版(这步非必操作)yum -y upgrade

1.配置jdk环境

安装之前先检查一下系统有没有自带open-jdk

  1. rpm -qa |grep java
  2. rpm -qa |grep jdk
  3. rpm -qa |grep gcj

如果没有输入信息表示没有安装。

接着检索包含java的列表

yum list java*

检索1.8的列表

yum list java-1.8*

安装1.8.0的所有文件

yum install java-1.8.0-openjdk* -y

使用命令检查是否安装成功

java -version

到此安装结束了。这样安装有一个好处就是不需要对path进行设置,自动就设置好了

2.配置mysql数据库

注意:Mysql的版本要5.6.5以上,Apollo的表结构对timestamp使用了多个default声明,所以需要5.6.5以上版本。
我是基于mysql5.7版本进行部署的,这里就不介绍如何部署了,具体可以参考我的另外一篇文章https://www.jianshu.com/p/ad87325b49e3

下载Apollo源码包

首先到官网下载源码包

创建目录

  1. --进入目录
  2. cd /usr/local/
  3. --创建存储目录,用于存放apollo安装包的地方
  4. mkdir software
  5. cd software
  6. --用于将存储解压apollo的源码包的地方
  7. mkdir apollo

这里可以通过两种方式下载(两种方式看个人喜好)

1.先在windows中下载完源码包之后,通过ftp工具上传到linux目录中(推荐,下载速度可能稍微快点)
2.直接在linux里面通过wget命令下载到目录里

  1. wget https://github.com/ctripcorp/apollo/releases/download/v1.7.0/apollo-adminservice-1.7.0-github.zip
  2. wget https://github.com/ctripcorp/apollo/releases/download/v1.7.0/apollo-configservice-1.7.0-github.zip
  3. wget https://github.com/ctripcorp/apollo/releases/download/v1.7.0/apollo-portal-1.7.0-github.zip

我这里就直接通过ftp工具,上传源码包到指定目录了

解压源码包

  1. cd /usr/local/software
  2. unzip apollo-adminservice-1.7.0-github.zip -d /usr/local/software/apollo/apollo-adminservice
  3. unzip apollo-configservice-1.7.0-github.zip -d /usr/local/software/apollo/apollo-configservice
  4. unzip apollo-portal-1.7.0-github.zip -d /usr/local/software/apollo/apollo-portal

如果报错: -bash: unzip: 未找到命令

yum -y install unzip

创建Apollo数据库

Apollo服务端共需要两个数据库:ApolloPortalDB和ApolloConfigDB,数据库、表的创建和样例数据都分别准备了sql文件,只需要导入数据库即可。
注意:如果你本地已经创建过Apollo数据库,请注意备份数据。这里准备的sql文件会清空Apollo相关的表。

https://github.com/nobodyiam/apollo-build-scripts/tree/master/sql

修改配置数据库连接信息

注意:填入的用户需要具备对ApolloPortalDB和ApolloConfigDB数据的读写权限且用户名和密码后面不要有空格!

  1. --进入目录
  2. cd /usr/local/software/apollo
  3. ############################################ apollo-adminservice ############################################
  4. vim apollo-adminservice/config/application-github.properties
  5. # DataSource
  6. spring.datasource.url = jdbc:mysql://192.168.137.16:3306/ApolloConfigDB?characterEncoding=utf8
  7. spring.datasource.username = 用户名
  8. spring.datasource.password = 密码(如果没有密码,留空即可)
  9. ############################################ apollo-configservice ############################################
  10. vim apollo-configservice/config/application-github.properties
  11. # DataSource
  12. spring.datasource.url = jdbc:mysql://192.168.137.16:3306/ApolloConfigDB?characterEncoding=utf8
  13. spring.datasource.username = 用户名
  14. spring.datasource.password = 密码(如果没有密码,留空即可)
  15. ############################################ apollo-portal ############################################
  16. vim apollo-portal/config/application-github.properties
  17. # DataSource
  18. spring.datasource.url = jdbc:mysql://192.168.137.16:3306/ApolloPortalDB?characterEncoding=utf8
  19. spring.datasource.username = 用户名
  20. spring.datasource.password = 密码(如果没有密码,留空即可)

如果报错-bash: vim: 未找到命令

yum -y install vim 安装插件 或者 直接使用内置的 vi命令也行

修改apollo-configservice服务地址

分别是不同环境下的服务地址,这里只配置了(开发-dev)环境下的地址

  1. vim apollo-portal/config/apollo-env.properties
  2. local.meta=http://192.168.137.5:8080
  3. dev.meta=http://192.168.137.5:8080
  4. fat.meta=http://fill-in-fat-meta-server:8080
  5. uat.meta=http://fill-in-uat-meta-server:8080
  6. lpt.meta=${lpt_meta}
  7. pro.meta=http://fill-in-pro-meta-server:8080

修改数据库数据

ApolloConfigDB库的ServerConfig表eureka.service.url中value值为http://192.168.137.16:8080/eureka/

启动Apollo配置中心

脚本会在本地启动3个服务,分别使用8070, 8080, 8090端口,请确保这3个端口当前没有被使用。

接着创建启动脚本

  1. --------------------------------- 启动脚本---------------------------------
  2. vim start.sh
  3. #!/bin/bash
  4. /usr/local/software/apollo/apollo-configservice/scripts/startup.sh
  5. /usr/local/software/apollo/apollo-adminservice/scripts/startup.sh
  6. /usr/local/software/apollo/apollo-portal/scripts/startup.sh
  7. --------------------------------- 停止脚本---------------------------------
  8. vim shutdown.sh
  9. #!/bin/bash
  10. /usr/local/software/apollo/apollo-adminservice/scripts/shutdown.sh
  11. /usr/local/software/apollo/apollo-configservice/scripts/shutdown.sh
  12. /usr/local/software/apollo/apollo-portal/scripts/shutdown.sh

启动出现权限不足

解决方案->赋予权限

  1. chmod 777 ./start.sh
  2. chmod 777 ./shutdown.sh

执行启动脚本

./start.sh

当看到如下输出后,就说明启动成功了!

访问Apollo配置中心

http://192.168.137.15:8070

默认账号密码:
账号:apollo
密码:admin

Apollo内置Eureka访问地址

http://192.168.137.16:8080/

到此Apollo单机版部署就结束了

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Gausst松鼠会/article/detail/536403
推荐阅读
相关标签
  

闽ICP备14008679号