Apollo 简介

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

服务端基于Spring Boot和Spring Cloud开发,打包后可以直接运行,不需要额外安装Tomcat等应用容器。

Java客户端不依赖任何框架,能够运行于所有Java运行时环境,同时对Spring/Spring Boot环境也有较好的支持。

.Net客户端不依赖任何框架,能够运行于所有.Net运行时环境。

更多产品介绍参见Apollo配置中心介绍

Apollo配置中心架构剖析

https://mp.weixin.qq.com/s/-hUaQPzfsl9Lm3IqQW3VDQ

docker分布式部署(多环境)

官方分布式部署参见分布式部署指南https://github.com/ctripcorp/apollo/wiki/%E5%88%86%E5%B8%83%E5%BC%8F%E9%83%A8%E7%BD%B2%E6%8C%87%E5%8D%97

1.准备机器2台

l192.168.101.14

l192.168.101.15

实现效果:通过apollo管理本地环境zglocal和测试环境zgdev配置文件

1.创建数据库

创建ApolloConfigDB

通过各种MySQL客户端导入apolloconfigdb.sql即可,每个环境一个数据库,因为我们有两个环境zglocal和zgdev,所以需要新建两个数据库zg_apolloconfigdb_dev 和 zg_apolloconfigdb_local。导入的sql是同一份sql数据就行

创建ApolloPortalDB

通过各种MySQL客户端导入apolloportaldb.sql即可,因为Portal是配置管理界面,所以只需要一个就可以管理多个环境

效果如下:

2.docker安装apollo

// 安装启动zgdev环境ConfigService和AdminService

docker run -p 8080:8080 \

-e SPRING_DATASOURCE_URL="jdbc:mysql://192.168.101.20:3306/zg_apolloconfigdb_dev?characterEncoding=utf8" \

-e SPRING_DATASOURCE_USERNAME=root -e SPRING_DATASOURCE_PASSWORD=root@800 \

-e eureka_instance_ip_address=192.168.101.14 \

-d -v /tmp/logs:/opt/logs --name apollo-configservice-dev apolloconfig/apollo-configservice:1.7.1

docker run -p 8090:8090 \

-e SPRING_DATASOURCE_URL="jdbc:mysql://192.168.101.20:3306/zg_apolloconfigdb_dev?characterEncoding=utf8" \

-e SPRING_DATASOURCE_USERNAME=root -e SPRING_DATASOURCE_PASSWORD=root@800 \

-e eureka_instance_ip_address=192.168.101.14 \

-d -v /tmp/logs:/opt/logs --name apollo-adminservice-dev apolloconfig/apollo-adminservice:1.7.1

//安装启动zglocal环境ConfigService和AdminService

docker run -p 8080:8080 \

-e SPRING_DATASOURCE_URL="jdbc:mysql://192.168.101.20:3306/zg_apolloconfigdb_local?characterEncoding=utf8" \

-e SPRING_DATASOURCE_USERNAME=root -e SPRING_DATASOURCE_PASSWORD=root@800 \

-e EUREKA_INSTANCE_IP_ADDRESS=192.168.101.15 \

-d -v /tmp/logs:/opt/logs --name apollo-configservice-local apolloconfig/apollo-configservice:1.7.1

docker run -p 8090:8090 \

-e SPRING_DATASOURCE_URL="jdbc:mysql://192.168.101.20:3306/zg_apolloconfigdb_local?characterEncoding=utf8" \

-e SPRING_DATASOURCE_USERNAME=root -e SPRING_DATASOURCE_PASSWORD=root@800 \

-e EUREKA_INSTANCE_IP_ADDRESS=192.168.101.15  \

-d -v /tmp/logs:/opt/logs --name apollo-adminservice-local apolloconfig/apollo-adminservice:1.7.1

参数说明:

lSPRING_DATASOURCE_URL: 对应环境ApolloConfigDB的地址

lSPRING_DATASOURCE_USERNAME: 对应环境ApolloConfigDB的用户名

lSPRING_DATASOURCE_PASSWORD: 对应环境ApolloConfigDB的密码

lEUREKA_INSTANCE_IP_ADDRESS: 对应的网络策略,如果实际部署的机器有多块网卡(如docker),或者存在某些网卡的IP是Apollo客户端和Portal无法访问的(如网络安全限制),那么我们就需要在apollo-configservice和apollo-adminservice中做相关限制以避免Eureka将这些网卡的IP注册到Meta Server,所以这里我们要使用我们宿主机的ip注册到到Eureka注册中心,而不是默认的容器ip

//安装启动Portal

docker run -p 8070:8070 \

-e SPRING_DATASOURCE_URL="jdbc:mysql://192.168.101.20:3306/zg_apolloportaldb?characterEncoding=utf8" \

-e SPRING_DATASOURCE_USERNAME=root -e SPRING_DATASOURCE_PASSWORD=root@800 \

-d -v /tmp/logs:/opt/logs --name apollo-portal apolloconfig/apollo-portal:1.7.1

参数说明:

lSPRING_DATASOURCE_URL: 对应环境ApolloPortalDB的地址

lSPRING_DATASOURCE_USERNAME: 对应环境ApolloPortalDB的用户名

lSPRING_DATASOURCE_PASSWORD: 对应环境ApolloPortalDB的密码

lAPOLLO_PORTAL_ENVS(可选): 对应ApolloPortalDB中的apollo.portal.envs配置项,如果没有在数据库中配置的话,可以通过此环境参数配置

lDEV_META/PRO_META(可选): 配置对应环境的Meta Service地址,以${ENV}_META命名,需要注意的是如果配置了ApolloPortalDB中的apollo.portal.meta.servers配置,则以apollo.portal.meta.servers中的配置为准

启动后效果:

3.修改配置参数

3.1修改Portal容器参数

执行命令进入容器

docker exec -it apollo-portal sh

cd /apollo-portal/config

vi apollo-env.properties修改环境参数,如图:

3.2修改数据库参数

调整ApolloConfigDB配置

不管是apollo-configservice还是apollo-adminservice都需要向eureka服务注册,所以需要配置eureka服务地址。 按照目前的实现,apollo-configservice本身就是一个eureka服务,所以只需要填入apollo-configservice的地址即可,如有多个,用逗号分隔(注意不要忘了/eureka/后缀)。

调整ApolloPortalDB配置

配置项统一存储在ApolloPortalDB.ServerConfig表中,也可以通过管理员工具 - 系统参数页面进行配置,无特殊说明则修改完一分钟实时生效。

进行这些调整后重启这几个docker服务即可,访问Portal界面

通过系统信息查看是否zglocal和zgdev环境的apollo-configservice还是apollo-adminservice是否允许正常

docker apollo配置中心分布式部署的更多相关文章

  1. 基于winserver的Apollo配置中心分布式&集群部署实践(正确部署姿势)

    基于winserver的Apollo配置中心分布式&集群部署实践(正确部署姿势)   前言 前几天对Apollo配置中心的demo进行一个部署试用,现公司已决定使用,这两天进行分布式部署的时候 ...

  2. Win10上部署Apollo配置中心

    基于Docker在Win10上部署Apollo配置中心 https://www.jianshu.com/p/a1215056ce75 http://nobodyiam.com/2016/07/09/i ...

  3. .NET Core 下使用 Apollo 配置中心

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

  4. Apollo配置中心

    背景: 当前我们项目,所有的配置基本都是通过本地properties 文件进行配置的,比如ip地址.端口.消息中间件和数据库连接的各种参数,当我们需要切换环境或调整参数的时候,我们必须手动的修改这些配 ...

  5. spring boot2.1读取 apollo 配置中心1

    第一篇:搭建apollo配置中心 为什么选择apollo,我做了一些对比:   Diamond Disconf Apollo Spring Cloud Config 数据持久性 mysql mysql ...

  6. Apollo配置中心转

    尊重原创,本文转自:https://www.cnblogs.com/FlyAway2013/p/8811385.html 前我们项目,所有的配置基本都是通过本地properties 文件进行配置的,比 ...

  7. 携程 Apollo 配置中心传统 .NET 项目集成实践

    官方文档存在的问题 可能由于 Apollo 配置中心的客户端源码一直处于更新中,导致其相关文档有些跟不上节奏,部分文档写的不规范,很容易给做对接的新手朋友造成误导. 比如,我在参考如下两个文档使用传统 ...

  8. Spring Boot 2.0 整合携程Apollo配置中心

    原文:https://www.jianshu.com/p/23d695af7e80 Apollo(阿波罗)是携程框架部门研发的分布式配置中心,能够集中化管理应用不同环境.不同集群的配置,配置修改后能够 ...

  9. (转)实验文档3:在kubernetes集群里集成Apollo配置中心

    使用ConfigMap管理应用配置 拆分环境 主机名 角色 ip HDSS7-11.host.com zk1.od.com(Test环境) 10.4.7.11 HDSS7-12.host.com zk ...

随机推荐

  1. Cyclic Nacklace HDU - 3746

    CC这个月底总是很郁闷,昨天他查了他的信用卡,没有任何意外,只剩下99.9元了.他很苦恼,想着如何度过这最后的几天.受"HDU CakeMan"企业家精神的启发,他想卖一些小东西来 ...

  2. PowerShell随笔9--- call

    很多时候我们需要在一个脚本文件执行另外一个脚本文件,比如我们有一个Test.ps1文件 我们有以下2种方法: Invoke-Expression (&) 我们可以看到,Test.ps1中的代码 ...

  3. ABP设置管理模块: Abp.SettingUi

    开源地址: https://github.com/EasyAbp/Abp.SettingUi 一直想宣传一下SettingUi, 因为 懒 工作比较忙, 所以才拖到今天. 关于ABP就不需要我再多废口 ...

  4. 关于TCP状态TIME_WAIT的理解

    1.TIME_WAIT的作用: TIME_WAIT状态存在的理由:1)可靠地实现TCP全双工连接的终止 在进行关闭连接四次挥手协议时,最后的ACK是由主动关闭端发出的,如果这个最终的ACK丢失,服务器 ...

  5. Zabbix 部署配置

    监控基本概述 主要的监控工具 1.CACTI:网络监控,Cacti是一套基于PHP,MySQL,SNMP 及 RRDTool 开发的网络流量监测图形分析工具 2.NAGIOS:系统监控,很久之前使用的 ...

  6. kubernetes实战-配置中心(二)交付apollo配置中心到k8s

    apollo官网:官方地址 apollo架构图: apollo需要使用数据库,这里使用mysql,注意版本需要在5.6以上: 本次环境mysql部署在10.4.7.11上,使用mariadb:10.1 ...

  7. SpringSecurity认证流程

    SpringSecurity配置 SecurityConfig.java @Override protected void configure(HttpSecurity http) throws Ex ...

  8. 网络安全-WEB基础,burpsuite,WEB漏洞

    1. web基础 HTTP: GET POST REQUEST RESPONSE... JDK robots.txt 网页源代码/注释 目录扫描--御剑,dirmap 端口信息--nmap 备份文件- ...

  9. C# 类 (10) - 命名空间NameSpace

    NameSpace 命名空间是一系列 类型的集合,比如很多方法,很多类,集合在一个空间(myspace)里,谁想用就先 using myspace,然后直接用不using myspace的话,想用里面 ...

  10. CSS 解决Float后塌陷问题

    当父级元素没有设定高度时候,而子集元素设定float类型时候,此时父级元素不能靠子集元素撑起来,所以就形成了塌陷: 示例分析 **1.Float之前的效果** <!DOCTYPE html> ...