Apollo配置中心实战:从零到一的Docker化部署与核心配置详解
1. 为什么选择Apollo配置中心在微服务架构中配置管理一直是个让人头疼的问题。记得我第一次尝试用传统properties文件管理配置时光是同步不同环境的配置就浪费了大半天时间。后来接触到Apollo才发现原来配置管理可以这么优雅。Apollo作为携程开源的分布式配置中心最吸引我的就是它的实时推送能力。想象一下你正在线上系统排查问题突然发现某个参数需要紧急调整。传统方式需要重启服务而用Apollo只需要在控制台点几下修改就能立即生效。这个特性在我们处理线上事故时简直救命。它的权限管理也做得相当细致。我们团队曾经因为误操作导致测试环境配置被覆盖用了Apollo后每个配置变更都需要走审批流程再也没出现过类似问题。特别是灰度发布功能可以先把新配置推给部分实例验证确认没问题再全量发布大大降低了配置变更的风险。2. 部署前的准备工作2.1 硬件与软件需求在开始部署前建议准备以下环境Docker环境推荐使用Docker 20.10版本。我在CentOS 7上实测时发现老版本Docker经常会出现网络问题MySQL数据库需要5.7版本建议提前创建好两个数据库ApolloConfigDB和ApolloPortalDB至少4GB内存三个核心服务全开的话内存占用在3GB左右2.2 数据库初始化Apollo需要两个独立的数据库ApolloConfigDB存储每个环境的配置数据ApolloPortalDB存储门户相关数据初始化脚本可以在官方GitHub找到。有个小技巧执行SQL前记得修改默认字符集为utf8mb4避免后续出现中文乱码问题。我遇到过因为emoji表情导致配置保存失败的情况就是字符集不兼容造成的。# 下载初始化SQL wget https://raw.githubusercontent.com/apolloconfig/apollo/master/scripts/sql/apolloconfigdb.sql wget https://raw.githubusercontent.com/apolloconfig/apollo/master/scripts/sql/apolloportaldb.sql # 导入数据库 mysql -h your_mysql_host -u username -p ApolloConfigDB apolloconfigdb.sql mysql -h your_mysql_host -u username -p ApolloPortalDB apolloportaldb.sql3. Docker化部署全流程3.1 获取官方镜像Apollo官方提供了三个核心服务的Docker镜像apollo-configserviceapollo-adminserviceapollo-portal建议直接使用官方镜像省去自己构建的麻烦docker pull apolloconfig/apollo-configservice:latest docker pull apolloconfig/apollo-adminservice:latest docker pull apolloconfig/apollo-portal:latest3.2 启动ConfigServiceConfigService是配置读取的核心服务启动时需要特别注意数据库连接配置docker run -d \ -p 8080:8080 \ -e SPRING_DATASOURCE_URLjdbc:mysql://mysql_host:3306/ApolloConfigDB?useSSLfalse \ -e SPRING_DATASOURCE_USERNAMEusername \ -e SPRING_DATASOURCE_PASSWORDpassword \ -e EUREKA_INSTANCE_IP-ADDRESSyour_server_ip \ --name apollo-configservice \ apolloconfig/apollo-configservice这里有个坑要注意如果部署在云服务器上EUREKA_INSTANCE_IP-ADDRESS一定要设置为公网IP否则其他服务无法正确注册。3.3 启动AdminServiceAdminService负责配置管理启动方式类似docker run -d \ -p 8090:8090 \ -e SPRING_DATASOURCE_URLjdbc:mysql://mysql_host:3306/ApolloConfigDB?useSSLfalse \ -e SPRING_DATASOURCE_USERNAMEusername \ -e SPRING_DATASOURCE_PASSWORDpassword \ -e EUREKA_SERVICE_URLhttp://your_configservice_ip:8080/eureka/ \ --name apollo-adminservice \ apolloconfig/apollo-adminservice3.4 启动Portal服务Portal是管理界面需要连接PortalDBdocker run -d \ -p 8070:8070 \ -e SPRING_DATASOURCE_URLjdbc:mysql://mysql_host:3306/ApolloPortalDB?useSSLfalse \ -e SPRING_DATASOURCE_USERNAMEusername \ -e SPRING_DATASOURCE_PASSWORDpassword \ -e APOLLO_PORTAL_ENVSdev,prod \ -e DEV_METAhttp://your_configservice_ip:8080 \ -e PROD_METAhttp://prod_configservice_ip:8080 \ --name apollo-portal \ apolloconfig/apollo-portal多环境配置是Portal的关键功能。APOLLO_PORTAL_ENVS定义了环境列表每个环境需要指定对应的meta地址。我们项目中有个最佳实践为每个环境创建独立的ConfigDB避免配置互相干扰。4. 核心配置详解4.1 数据库连接优化生产环境中数据库连接池配置直接影响性能。建议通过以下环境变量调整-e SPRING_DATASOURCE_HIKARI_MAXIMUM-POOL-SIZE20 -e SPRING_DATASOURCE_HIKARI_MINIMUM-IDLE5 -e SPRING_DATASOURCE_HIKARI_CONNECTION-TIMEOUT30000我曾经遇到过连接泄漏问题后来发现是默认连接池配置太小。调整后性能提升了3倍多。4.2 多环境管理在Portal的apollo-env.properties中配置多环境dev.metahttp://dev-config:8080 fat.metahttp://fat-config:8080 uat.metahttp://uat-config:8080 prod.metahttp://prod-config:8080每个环境需要独立的ConfigService集群。我们团队的做法是为每个环境部署一套ConfigServiceAdminService共享同一个Portal。4.3 自定义命名空间Apollo支持多种配置格式propertiesxmlyamljson创建命名空间时可以选择格式。我们项目中使用yaml比较多结构更清晰# 示例yaml配置 spring: datasource: url: jdbc:mysql://localhost:3306/db username: root password: 1234565. 常见问题排查5.1 服务注册失败如果AdminService无法注册到ConfigService检查以下几点EUREKA_SERVICE_URL是否正确网络是否互通防火墙是否放行8080端口5.2 配置不生效客户端获取不到最新配置时检查客户端meta地址是否配置正确查看Portal中配置是否已发布检查客户端缓存目录权限5.3 性能调优高并发场景下建议调整增加ConfigService实例数配置Redis缓存调整客户端轮询间隔# 客户端配置 apollo.refresh-interval5 apollo.long-poll-timeout600006. 生产环境最佳实践经过多个项目的实战总结出以下经验权限控制为不同团队创建独立角色避免误操作配置审计重要配置变更要走审批流程监控告警对接Prometheus监控配置变更定期备份数据库配置需要定期备份客户端容灾配置本地缓存策略防止配置中心不可用最后提醒一点Apollo虽然强大但也不要滥用。像数据库密码这类敏感信息建议还是用专业的密钥管理服务。配置中心更适合管理业务参数和环境变量。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2488303.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!