前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >kubernetes-21:生产环境应用skywalking探针到apollo配置中心

kubernetes-21:生产环境应用skywalking探针到apollo配置中心

作者头像
千里行走
发布2021-12-13 14:17:59
6800
发布2021-12-13 14:17:59
举报
文章被收录于专栏:千里行走

目录

(1).前置说明

(2).基础镜像

1.oraclejdk-docker-image

2.oraclejdk-skywalking-docker-image

3.apollo-skywalking-pro镜像

(3).apollo&skywalking生产级容器化

(4).关键配置

(5).特别注意

1.sk-agent和sky-oap一定要配置正确的时区

2.sk-oap的elasticsearch版本选择

3.制作apollo-skywalking-docker-image镜像注意sk-plugin选择

4.apollo-portal开启多副本要注意配置session亲和性

5.使用oraclejdk

6.修改支持的环境

(6).相关文章

(1).前置说明

本例相对于官方做了如下几处改动:

1.修改基础镜像为oracle-jdk,并增加redis-cli, telnet等常用工具包。

2.基础镜像增加skywalking-agent的支持,通过configmap中的配置参数来决定在启动apollo服务的时候是否开启链路追踪。

(2).基础镜像

1.oraclejdk-docker-image

第一层基础镜像。

使用oraclejdk8制作的镜像,包含telnet, redis-cli, mysql-client等工具包。

地址: https://github.com/hepyu/oraclejdk-docker-image

2.oraclejdk-skywalking-docker-image

第二层镜像,基于oraclejdk-docker-image镜像。

加入了skywalking-agent支持。

地址: https://github.com/hepyu/oraclejdk-skywalking-docker-image

3.apollo-skywalking-pro镜像

基于镜像oraclejdk-skywalking-docker-image制作。

(3).apollo&skywalking生产级容器化

笔者提供生产级的配置文件,位于:

https://github.com/hepyu/k8s-app-config/tree/master/product/standard/apollo-skywalking-pro

注意本例配置中pv默认是本地存储,生产环境需要改为云存储。

顺次执行:

zkubectl apply -f apollo-namespace.yaml cd apollo-configservice kubectl apply -f . cd apollo-adminservice kubectl apply -f . cd apollo-portal kubectl apply -f .

最终的生产效果:

原图文件位于:

https://github.com/hepyu/k8s-app-config/blob/master/product/standard/apollo-skywalking-pro/images/apollo-skywalking.png

(4).关键配置

skywalking的关键配置位于config/admin/portal下的config.yaml文件,通过环境变量SKYWALKING_AGENT来配置是否开启skywalking-agent探针;当然也可以在这里调整JVM启动参数。

代码语言:javascript
复制
当配置如下时表示关闭skywalking-agent探针:SKYWALKING_AGENT: ''
SERVICE_NAME: apollo-configservice
 APOLLO_CONFIG_SERVICE_NAME: apollo-configservice
 LOG_DIR: /opt/logs/apollo-config-server
 SERVER_PORT: '8080'
  SERVER_URL: http://APOLLO_CONFIG_SERVICE_NAME:SERVER_PORT
 TIME_ZONE: Asia/Shanghai
 SKYWALKING_AGENT: '-javaagent:/app/3rd/skywalking-agent/skywalking-agent.jar=agent.service_name=apollo-configservice-k8s,collector.backend_service=skywalking-c0-oap.skywalking:11800'
 #SKYWALKING_AGENT: ''
 JAVA_OPTS: >-
 -Xms1024m -Xmx1024m -Xss256k -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=256m -XX:NewSize=512m -XX:MaxNewSize=512m -XX:SurvivorRatio=8
 -server -XX:-ReduceInitialCardMarks
 -XX:ParallelGCThreads=4 -XX:MaxTenuringThreshold=9 -XX:+DisableExplicitGC -XX:+ScavengeBeforeFullGC -XX:SoftRefLRUPolicyMSPerMB=0
 -XX:+ExplicitGCInvokesConcurrent -XX:+HeapDumpOnOutOfMemoryError -XX:-OmitStackTraceInFastThrow
 -Duser.timezone=$TIME_ZONE -Dclient.encoding.override=UTF-8 -Dfile.encoding=UTF-8
 -Djava.security.egd=file:/dev/./urandom
    -Dserver.port=SERVER_PORT -Dlogging.file=LOG_DIR/SERVICE_NAME.log -XX:HeapDumpPath=LOG_DIR/
 $SKYWALKING_AGENT
 application-github.properties: |
 spring.datasource.url=jdbc:mysql://mysql-min.mysql-min:3306/DevApolloConfigDB?characterEncoding=utf8
 spring.datasource.username=apollo
 spring.datasource.password=admin
 spring.jpa.database-platform=org.hibernate.dialect.MySQL5Dialect
 eureka.service.url=http://apollo-configservice/eureka/

(5).特别注意

1.sk-agent和sky-oap一定要配置正确的时区

都要配置: TIME_ZONE: Asia/Shanghai

因为skywalking的默认时区是UTC0,大陆的APP的服务的时区是UTC8,如果sk-agent和sk-oap的时区不一致时,sk-ui不会显示数据/拓扑。

2.sk-oap的elasticsearch版本选择

尽量选择sk使用的版本,比如sk6.4.0用的是es6.3.2那我们搭建es时就要选择这个版本。避免es版本差异带来的各种奇怪问题。

3.制作apollo-skywalking-docker-image镜像注意sk-plugin选择

参照官方/社区的issue:https://github.com/ctripcorp/apollo/issues/2448

我们的目的是:

a. 监控Apollo-Config、Admin、Portal之间的调用以及拓扑

b. 监控Apollo-Client 与 Config之间的调用及拓扑

第一种情况:Portal与Config/Admin之间采用RestTemplate/HttpClient 发起调用,这个插件在Skywalking支持列表。

第二种情况,Apollo-Client 采用的是 HttpURLConnection 发起Http请求。和 HttpClient 有些区别,默认插件不支持。需要使用可选插件:bootstrap-plugins/apm-jdk-http-plugin-6.4.0.jar,将这个jar包拷贝到plugins目录下。

4.apollo-portal开启多副本要注意配置session亲和性

config/admin/portal的负载均衡都需要配置:sessionAffinity: ClientIP;

如果你还是用的ingress代理apollo-portal,那么ingress也需要配置亲和性保证session的正确传递:

nginx.ingress.kubernetes.io/affinity: cookie

ingress的亲和性配置参见文件:

https://github.com/hepyu/k8s-app-config/blob/master/product/standard/apollo-pro/apollo-portal/apollo-portal-ingress.yaml

如果不配置亲和性,apollo-portal开启多副本后将出现无法登陆的现象。

5.使用oraclejdk

因为apollo官方的镜像里没有调试工具,如jstat等,很不方便。

6.修改支持的环境

在apolloPortalDB的ServerConfig表中存放了支持的环境:pro,uat,fat,dev,如果只配置了pro,需要把其余的3个删除,否则portal会一直报错:

''' Env is down. env: UAT, failed times: 39, meta server address: http://apollo.meta '''

(6).相关文章

1.官方地址容器化配置地址:

https://github.com/ctripcorp/apollo/tree/master/scripts/apollo-on-kubernetes/kubernetes

2.官方apollo容器化步骤(Step by Step):

https://github.com/ctripcorp/apollo/blob/master/scripts/apollo-on-kubernetes/README.md

3.笔者apollo容器化步骤(Step by Step):

https://www.toutiao.com/i6698673592915198478/

相对于官方文档增加了镜像仓库推送/db初始化的更加详细的操作,根据笔者的习惯整理了步骤,同时也作为笔者自己的笔记/备份

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-12-08,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 千里行走 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
容器镜像服务
容器镜像服务(Tencent Container Registry,TCR)为您提供安全独享、高性能的容器镜像托管分发服务。您可同时在全球多个地域创建独享实例,以实现容器镜像的就近拉取,降低拉取时间,节约带宽成本。TCR 提供细颗粒度的权限管理及访问控制,保障您的数据安全。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档