小言_互联网的博客

【DockerCE】使用docker运行HertzBeat

410人阅读  评论(0)

HertzBeat是一款免Agent的监控平台,拥有强大自定义监控能力,可以对应用服务、数据库、中间件、操作系统、云原生等进行监控,配置告警阈值,以及告警通知(邮件微信钉钉飞书)。关于这个软件的介绍,我这里就不做过多的介绍了,感兴趣的可以去官网(https://hertzbeat.com/docs)去详细了解下。

今天我主要和大家分享下,如何使用docker来配置和运行HertzBeat。

HertzBeat将监控历史数据存储在时序数据库里面,官方文档给出了两款兼容的时序数据库软件,分别是IoTDB和TDengine,这里我使用的是TDengine。

首先,我们将所需的docker镜像下载到虚拟机(Docker已经提前安装,版本为20.10.21)。


   
  1. # docker pull tancloud/hertzbeat
  2. Using default tag: latest
  3. latest: Pulling from tancloud/hertzbeat
  4. 751ef25978b2: Pull complete
  5. 140e22108c7d: Pull complete
  6. 993077aca88e: Pull complete
  7. d1a940e1e4e8: Pull complete
  8. 4f368e97aba5: Pull complete
  9. 4f4fb700ef54: Pull complete
  10. Digest: sha256:ed3d981673ee34e2d462ba0dda415f62aeec2380ccd0f45a8f1e481d05b2c735
  11. Status: Downloaded newer image for tancloud/hertzbeat:latest
  12. docker.io/tancloud/hertzbeat:latest
  13. # docker pull tdengine/tdengine:2.4.0.12
  14. 2.4 .0 .12: Pulling from tdengine/tdengine
  15. 2f94e549220a: Pull complete
  16. 0c7809c5a70c: Pull complete
  17. 354dceb62d94: Pull complete
  18. ded68138e6c3: Pull complete
  19. a049546d9313: Pull complete
  20. c67be503641a: Pull complete
  21. 1f27396f6efc: Pull complete
  22. fe556ec02776: Pull complete
  23. Digest: sha256: 0209b13bc6bffaac98fb05df58a86b06d998877d786efcdf59e68299b538d8bd
  24. Status: Downloaded newer image for tdengine/tdengine: 2.4 .0 .12
  25. docker.io/tdengine/tdengine: 2.4 .0 .12

然后,我们通过下面的命令来运行TDengine数据库


   
  1. docker run -dti -p 6030 -6049: 6030 -6049 -p 6030 -6049: 6030 -6049/udp \
  2. -v /data/taosdata:/var/lib/taos \
  3. -e TZ=Asia/Shanghai \
  4. --name tdengine tdengine/tdengine: 2.4 .0 .12

数据库root用户的默认密码是taosdata,这里我将其修改为其他密码,通过docker exec进入容器内部执行下面的命令。


   
  1. # docker exec -it tdengine /bin/bash
  2. root@ 77a11dd2b845:~/TDengine-server -2.4 .0 .12 # taos
  3. taos> show databases;
  4. taos> CREATE DATABASE hertzbeat KEEP 90 DAYS 10 BLOCKS 6 UPDATE 1;
  5. Query OK, 0 of 0 row(s) in database ( 0.001995s)
  6. taos> alter user root pass 'YourPassword';
  7. Query OK, 0 of 0 row(s) in database ( 0.002024s)
  8. taos> quit
  9. root@ 77a11dd2b845:~/TDengine-server -2.4 .0 .12 # exit
  10. exit

备注:

CREATE DATABASE hertzbeat KEEP 90 DAYS 10 BLOCKS 6 UPDATE 1

创建一个名为 hertzbeat 的库,这个库的数据将保留90天(超过90天将被自动删除),每 10 天一个数据文件,内存块数为 6,允许更新数据

下面,我们修改HertzBeat的两个关键的配置文件,分别是application.yml和sureness.yml


   
  1. # application.yml
  2. # Licensed to the Apache Software Foundation (ASF) under one or more
  3. # contributor license agreements. See the NOTICE file distributed with
  4. # this work for additional information regarding copyright ownership.
  5. # The ASF licenses this file to You under the Apache License, Version 2.0
  6. # (the "License"); you may not use this file except in compliance with
  7. # the License. You may obtain a copy of the License at
  8. #
  9. # http://www.apache.org/licenses/LICENSE-2.0
  10. #
  11. # Unless required by applicable law or agreed to in writing, software
  12. # distributed under the License is distributed on an "AS IS" BASIS,
  13. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14. # See the License for the specific language governing permissions and
  15. # limitations under the License.
  16. server:
  17. port: 1157
  18. spring:
  19. application:
  20. name: ${HOSTNAME:@hertzbeat@}${PID}
  21. profiles:
  22. active: prod
  23. mvc:
  24. static-path-pattern: /**
  25. jackson:
  26. default-property-inclusion: ALWAYS
  27. web:
  28. resources:
  29. static-locations:
  30. - classpath:/dist/
  31. - classpath:../dist/
  32. # need to disable spring boot mongodb auto config, or default mongodb connection tried and failed..
  33. autoconfigure:
  34. exclude: org.springframework.boot.autoconfigure.mongo.MongoAutoConfiguration, org.springframework.boot.autoconfigure.data.mongo.MongoDataAutoConfiguration
  35. thymeleaf:
  36. prefix: classpath:/templates/
  37. check-template-location: true
  38. cache: true
  39. suffix: .html
  40. mode: HTML
  41. management:
  42. endpoints:
  43. web:
  44. exposure:
  45. include: '*'
  46. enabled-by-default: off
  47. sureness:
  48. auths:
  49. - digest
  50. - basic
  51. - jwt
  52. jwt:
  53. secret: 'CyaFv0bwq2Eik0jdrKUtsA6bx3sDJeFV643R
  54. LnfKefTjsIfJLBa2YkhEqEGtcHDTNe4CU6+9
  55. 8tVt4bisXQ13rbN0oxhUZR73M6EByXIO+SV5
  56. dKhaX0csgOCTlCxq20yhmUea6H6JIpSE2Rwp'
  57. ---
  58. spring:
  59. config:
  60. activate:
  61. on-profile: prod
  62. datasource:
  63. driver-class-name: org.h2.Driver
  64. username: sa
  65. password: 123456
  66. url: jdbc:h2:./data/hertzbeat;MODE=MYSQL
  67. hikari:
  68. max-lifetime: 120000
  69. jpa:
  70. hibernate:
  71. ddl-auto: update
  72. # Not Require, Please config if you need email notify
  73. # 非必填:不使用邮箱作为警告通知可以去掉spring.mail配置
  74. mail:
  75. # Attention: this is mail server address.
  76. # 请注意此为邮件服务器地址:qq邮箱为 smtp.qq.com qq企业邮箱为 smtp.exmail.qq.com
  77. host: smtp.exmail.qq.com
  78. username: example@tancloud.cn
  79. # Attention: this is not email account password, this requires an email authorization code
  80. # 请注意此非邮箱账户密码 此需填写邮箱授权码
  81. password: example
  82. port: 465
  83. default-encoding: UTF-8
  84. properties:
  85. mail:
  86. smtp:
  87. socketFactoryClass: javax.net.ssl.SSLSocketFactory
  88. ssl:
  89. enable: true
  90. debug: false
  91. warehouse:
  92. store:
  93. td-engine:
  94. enabled: true
  95. driver-class-name: com.taosdata.jdbc.rs.RestfulDriver
  96. url: jdbc:TAOS-RS://192.168.223.199:6041/hertzbeat
  97. username: root
  98. password: YourPassword
  99. iot-db:
  100. enabled: false
  101. host: 127.0.0.1
  102. rpc-port: 6667
  103. username: root
  104. password: root
  105. # org.apache.iotdb.session.util.Version: V_O_12 || V_0_13
  106. version: V_0_13
  107. # if iotdb version >= 0.13 use default queryTimeoutInMs = -1; else use default queryTimeoutInMs = 0
  108. query-timeout-in-ms: -1
  109. # 数据存储时间:默认'7776000000'(90天,单位为毫秒,-1代表永不过期)
  110. # data expire time, unit:ms, default '7776000000'(90 days, -1:never expire)
  111. expire-time: '7776000000'
  112. memory:
  113. enabled: true
  114. init-size: 1024
  115. redis:
  116. enabled: false
  117. host: 127.0.0.1
  118. port: 6379
  119. password: 123456
  120. alerter:
  121. # custom console url
  122. console-url: https://console.tancloud.cn
  123. # base of alert eval interval time, unit:ms. The next time is 2 times the previous time.
  124. alert-eval-interval-base: 600000
  125. # max of alert eval interval time, unit:ms
  126. max-alert-eval-interval: 86400000
  127. # system alert(available alert, reachable alert...) trigger times
  128. system-alert-trigger-times: 1

备注:

上面的配置文件,仅修改了warehouse块的td-engine配置(紫色部分)

td-engine:

enabled: true

driver-class-name: com.taosdata.jdbc.rs.RestfulDriver

url: jdbc:TAOS-RS://192.168.223.199:6041/hertzbeat

username: root

password: YourPassword


   
  1. # hertzbeat用户和用户权限配置-sureness.yml
  2. # Licensed to the Apache Software Foundation (ASF) under one or more
  3. # contributor license agreements. See the NOTICE file distributed with
  4. # this work for additional information regarding copyright ownership.
  5. # The ASF licenses this file to You under the Apache License, Version 2.0
  6. # (the "License"); you may not use this file except in compliance with
  7. # the License. You may obtain a copy of the License at
  8. #
  9. # http://www.apache.org/licenses/LICENSE-2.0
  10. #
  11. # Unless required by applicable law or agreed to in writing, software
  12. # distributed under the License is distributed on an "AS IS" BASIS,
  13. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14. # See the License for the specific language governing permissions and
  15. # limitations under the License.
  16. ## -- sureness.yml文本数据源 -- ##
  17. # 加载到匹配字典的资源,也就是需要被保护的,设置了所支持角色访问的资源
  18. # 没有配置的资源也默认被认证保护,但不鉴权
  19. # eg: /api/v1/source1===get===[admin] 表示 /api/v2/host===post 这条资源支持 admin 这一种角色访问
  20. # eg: /api/v1/source2===get===[] 表示 /api/v1/source2===get 这条资源不支持任何角色访问
  21. resourceRole:
  22. - /api/account/auth/refresh===post===[admin,user,guest]
  23. - /api/apps /**===get===[admin,user,guest]
  24. - /api/monitor/**===get===[admin,user,guest]
  25. - /api/monitor/**===post===[admin,user]
  26. - /api/monitor/**===put===[admin,user]
  27. - /api/monitor/**===delete==[admin]
  28. - /api/monitors/**===get===[admin,user,guest]
  29. - /api/monitors/**===post===[admin,user]
  30. - /api/monitors/**===put===[admin,user]
  31. - /api/monitors/**===delete===[admin]
  32. - /api/alert/**===get===[admin,user,guest]
  33. - /api/alert/**===post===[admin,user]
  34. - /api/alert/**===put===[admin,user]
  35. - /api/alert/**===delete===[admin]
  36. - /api/alerts/**===get===[admin,user,guest]
  37. - /api/alerts/**===post===[admin,user]
  38. - /api/alerts/**===put===[admin,user]
  39. - /api/alerts/**===delete===[admin]
  40. - /api/notice/**===get===[admin,user,guest]
  41. - /api/notice/**===post===[admin,user]
  42. - /api/notice/**===put===[admin,user]
  43. - /api/notice/**===delete===[admin]
  44. - /api/tag/**===get===[admin,user,guest]
  45. - /api/tag/**===post===[admin,user]
  46. - /api/tag/**===put===[admin,user]
  47. - /api/tag/**===delete===[admin]
  48. - /api/summary/**===get===[admin,user,guest]
  49. - /api/summary/**===post===[admin,user]
  50. - /api/summary/**===put===[admin,user]
  51. - /api/summary/**===delete===[admin]
  52. # 需要被过滤保护的资源,不认证鉴权直接访问
  53. # /api/v1/source3===get 表示 /api/v1/source3===get 可以被任何人访问 无需登录认证鉴权
  54. excludedResource:
  55. - /api/account/auth/**===*
  56. - /api/i18n/**===get
  57. - /api/apps/hierarchy===get
  58. - /actuator/**===get
  59. # web ui 前端静态资源
  60. - /===get
  61. - /dashboard/**===get
  62. - /monitors/**===get
  63. - /alert/**===get
  64. - /account/**===get
  65. - /setting/**===get
  66. - /passport/**===get
  67. - /**/*.html===get
  68. - /**/*.js===get
  69. - /**/*.css===get
  70. - /**/*.ico===get
  71. - /**/*.ttf===get
  72. - /**/*.png===get
  73. - /**/*.gif===get
  74. - /**/*.jpg===get
  75. - /**/*.svg===get
  76. - /**/*.json===get
  77. # swagger ui 资源
  78. - /swagger-resources /**===get
  79. - /v2/api-docs===get
  80. - /v3/api-docs===get
  81. # h2 database
  82. - /h2-console/**===*
  83. # 用户账户信息
  84. # 下面有 admin tom lili 三个账户
  85. # eg: admin 拥有[admin,user]角色,密码为hertzbeat
  86. # eg: tom 拥有[user],密码为hertzbeat
  87. # eg: lili 拥有[guest],明文密码为lili, 加盐密码为1A676730B0C7F54654B0E09184448289
  88. account:
  89. - appId: admin
  90. credential: hertzbeat
  91. role: [admin,user]
  92. - appId: tom
  93. credential: hertzbeat
  94. role: [user]
  95. - appId: guest
  96. credential: hertzbeat
  97. role: [guest]
  98. - appId: lili
  99. # 注意 Digest认证不支持加盐加密的密码账户
  100. # 加盐加密的密码,通过 MD5(password+salt)计算
  101. # 此账户的原始密码为 lili
  102. credential: 1A676730B0C7F54654B0E09184448289
  103. salt: 123
  104. role: [guest]

备注:这里没有做什么修改,密码是默认的。

account:

- appId: admin

credential: hertzbeat

在/data目录下创建上面两个文件,然后运行HertzBeat即可


   
  1. docker run -dti -p 1157: 1157 \
  2. -e LANG=zh_CN.UTF -8 \
  3. -e TZ=Asia/Shanghai \
  4. -v /data/hertzbeat/data:/opt/hertzbeat/data \
  5. -v /data/hertzbeat/logs:/opt/hertzbeat/logs \
  6. -v /data/application.yml:/opt/hertzbeat/config/application.yml \
  7. -v /data/sureness.yml:/opt/hertzbeat/config/sureness.yml \
  8. --restart=always \
  9. --name hertzbeat tancloud/hertzbeat:latest

运行成功后,我们可以使用docker ps查看tdengine数据库实例和HertzBeat实例的进程。


   
  1. # docker ps
  2. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
  3. 4bb57f02dedd tancloud/hertzbeat:latest "./bin/entrypoint.sh" 2 hours ago Up 2 hours 0.0.0.0:1157->1157/tcp, :::1157->1157/tcp hertzbeat
  4. 77a11dd2b845 tdengine/tdengine:2.4.0.12 "/tini -- /usr/bin/e…" 4 hours ago Up 4 hours 0.0.0.0:6030-6049->6030-6049/tcp, 0.0.0.0:6030-6049->6030-6049/udp, :::6030-6049->6030-6049/tcp, :::6030-6049->6030-6049/udp tdengine

访问HertzBeat管理页面:http://192.168.223.199:1157/

在仪表盘,我们可以看见配置的监控的总览

下面分享下相关监控的趋势图:

1)服务器可用性监控

2)网页可用性监控

3)端口可用性监控

4)系统资源使用监控

5)中间件监控

备注:Tomcat中间件监控,跨服务器监控,要在catalina.sh里面配置开启JMX,还需要在tomcat-user.xml里面配置监控用户。


   
  1. CATALINA_OPTS= "$CATALINA_OPTS -Dcom.sun.management.jmxremote -Djava.rmi.server.hostname=192.168.223.199 -Dcom.sun.management.jmxremote.port=9011 -Dcom.su
  2. n.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false"

   
  1. <role rolename= "manager"/>
  2. <user username= "monitor" password= "YourPassword" roles= "manager"/>

HertzBeat的配置信息如下:

监控告警测试:

模拟停掉Tomcat服务,然后再启动,就会出现下面的告警列表,看起来还是很清晰的。

在告警中心可以看见更加详细的告警信息记录:

总结,这款软件监控的对象还是很广的,监控配置也很简单。但是,监控数据的GUI展示和目前流行的Grafana相比,还是界面还是很简陋的,期待后期可以完善和提升。另外,软件的安全性也有待提升,因为明文密码配置在文件中,在生产环境中(尤其是大厂)肯定是不被安全所允许的。


转载:https://blog.csdn.net/cnskylee/article/details/128761948
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场