OpenShift下的JVM监控
去年写过一篇基于jmx监控的文章,这次在Openshift上实现,发现确实不少变化。主要重点问题在
1. prometheus jmx exporter的改进,不再需要运行一个独立的进程,不需要把数据输入到influxdb,
而是直接提供了prometheus数据。链接在
https://github.com/prometheus/jmx_exporter
2. OpenShift上采用prometheus Operator架构,内置了集群的监控指标,在此基础上如何集成客户化的监控数据。
接下来我们就看看具体的实现过程。
1. 针对应用镜像的修改
下载agent的jmx_prometheus_javaagent-0.12.0.jar
包,具体链接在
https://github.com/prometheus/jmx_exporter
以tomcat为例,构建一个镜像
[root@master jmx]# ls
catalina.sh config.yaml Dockerfile jmx_prometheus_javaagent-0.12..jar
Dockerfile
[root@master jmx]# cat Dockerfile
FROM registry.example.com/tomcat:-slim COPY *.* /usr/local/tomcat/bin/ CMD ["catalina.sh", "run"]
catalina.sh 是从镜像中拷贝出来的,修改了如下地方
CLASSPATH=/usr/local/tomcat/bin JAVA_OPTS="-javaagent:/usr/local/tomcat/bin/jmx_prometheus_javaagent-0.12.0.jar=8180:/usr/local/tomcat/bin/config.yaml $JAVA_OPTS $JSSE_OPTS"
因为缺省的8080和tomcat启动端口冲突,所以修改为8180
config.yaml, 最简单的配置,什么信息都获取
---
lowercaseOutputLabelNames: true
lowercaseOutputName: true
然后构建部署
docker build -t registry.example.com/tomcatjmx:-slim . docker push registry.example.com/tomcatjmx:-slim oc import-image tomcatjmx:-slim --from=registry.example.com/tomcatjmx:-slim --confirm --insecure=true
完成后在myproject的image下看到有个tomcatjmx:8-slim
在service下开放8180端口,修改yaml文件,加入8180端口
- name: -tcp
port:
protocol: TCP
targetPort:
然后应用镜像工作基本完成。
2.prometheus 添加target
OpenShift的 prometheus采用Operator进行部署,基于servicemonitor的模式对服务进行监控。
在OpenShift环境中内置了servicemonitor
[root@master jmx]# oc -n openshift-monitoring get servicemonitor
NAME AGE
alertmanager 175d
cluster-monitoring-operator 175d
etcd 6d
kube-apiserver 175d
kube-controllers 175d
kube-state-metrics 175d
kubelet 175d
node-exporter 175d
prometheus 175d
prometheus-operator 175d
service monitor通过namespace确定工作范围,同时基于Label对服务(Service)进行监控
我们如果需要对自己的服务进行监控,就需要建立一个客户化的Service monitor
[root@master ~]# cat myservicemonitor.yaml
apiVersion: monitoring.coreos.com/v1
kind: ServiceMonitor
metadata:
name: tomcatmonitor
labels:
k8s-app: tomcatmonitor
namespace: openshift-monitoring
spec:
namespaceSelector:
any: true
selector:
matchLabels:
app: tomcatjmx
endpoints:
- interval: 30s
path: /metrics
port: -tcp
比较核心的地方是selector, 决定对哪个服务进行监控,另外就是endpoint,针对哪个port获取指标。
创建后可以通过下面命令看到
[root@master ~]# oc -n openshift-monitoring get servicemonitor
NAME AGE
alertmanager 175d
cluster-monitoring-operator 175d
etcd 6d
kube-apiserver 175d
kube-controllers 175d
kube-state-metrics 175d
kubelet 175d
node-exporter 175d
prometheus 175d
prometheus-operator 175d
tomcatmonitor 1h
但这时候在prometheus的target上是看不到我们tomcatmonitor的,因为缺少了授权工作,添加RBAC的授权
oc adm policy add-cluster-role-to-user view system:serviceaccount:openshift-monitoring:prometheus-k8s oc adm policy add-role-to-user view system:serviceaccount:openshift-monitoring:prometheus-k8s -n myproject
完成后,在prometheus target界面上看到tomcatjmx服务已经启动
转去指标界面看到一系列指标
3. 集成grafana
这部分工作比较耗时,主要是要找到合适的图标导入,
我在
https://grafana.com/grafana/dashboards?search=jmx
上找了好几个,最后发现 https://grafana.com/grafana/dashboards/8878
比较合适。导入后展现结果,好处是可以直接选择project,service,然后选择相应的pod
heap和non-heap的指标
GC time
改进:
可以让servicemonitor监听所有打了jmx: jvm标签的服务。这样只要在服务上加上标签,就可以被监控。
至此工作完成. Enjoy!
OpenShift下的JVM监控的更多相关文章
- Java系列笔记(4) - JVM监控与调优
目录 参数设置收集器搭配启动内存分配监控工具和方法调优方法调优实例 光说不练假把式,学习Java GC机制的目的是为了实用,也就是为了在JVM出现问题时分析原因并解决之.通过学习,我觉得JVM ...
- jvm 监控
jvm监控可视化的有 jconsole .jmc .jvisualvm 其中jvisualvm开启一些监控会导致他自己关闭. 并且jdk下有很多工具可以进行jvm监控, jmap -histo:liv ...
- JVM监控与调优
目录 参数设置收集器搭配启动内存分配监控工具和方法调优方法调优实例 转:http://www.cnblogs.com/zhguang/p/java-jvm-gc.html光说不练假把式,学习J ...
- JVM监控命令详解(转)
JVM监控命令基本就是 jps.jstack.jmap.jhat.jstat 几个命令的使用就可以了 JDK本身提供了很多方便的JVM性能调优监控工具,除了集成式的VisualVM和jConsole外 ...
- [java] JVM监控与调优
原文出处:http://www.cnblogs.com/zhguang/p/java-jvm-gc.html 光说不练假把式,学习Java GC机制的目的是为了实用,也就是为了在JVM出现问题时分 ...
- JVM监控和调优常用命令工具总结
JVM监控和调优 在Java应用和服务出现莫名的卡顿.CPU飙升等问题时总是要分析一下对应进程的JVM状态以定位问题和解决问题并作出相应的优化,在这过程中Java自带的一些状态监控命令和图形化工具就非 ...
- Linux下Java性能监控
Linux下Java性能监控 一.JVM堆内存使用监控 获取thread dump的3种方法: 1)使用$JAVA_HOME/bin/jcosole中的MBean,到MBean>com.sun. ...
- Kubernetes下的应用监控解决方案
所谓应用监控,更多的是基于java jvm的监控,因为公司运行的中间件大部分都是基于tomcat,Springboot,SpringCloud,当然也必须支持WebLogic.在Kubernetes现 ...
- 无意间做了个 web 版的 JVM 监控端(前后端分离 React+Spring Boot)
之前写了JConsole.VisualVM 依赖的 JMX 技术,然后放出了一个用纯 JMX 实现的 web 版本的 JConsole 的截图,今天源码来了. 本来就是为了更多的了解 JMX,第一步就 ...
随机推荐
- 读取txt文件内容,并按一定长度分页显示
private List<string> SaveContentUpload(FileUpload file) { List<string> list_content = ne ...
- v-model绑定一个对象,组件内部分别负责不同字段的场景实现
我们知道v-model对于单个property双向数据绑定非常有用,保持父子组件之间的数据传递和同步,但也有很多场景下希望一个组件能够处理多个数据字段,这时就有一些小小技巧了. https://sim ...
- @property与@xxx.setter的用法
类中@property与@xxx.setter的方法介绍. 简单说,@property就是将定义的函数(方法)当作属性对象使用,不需要像调用函数那样去调用,而@xxx.setter是为@xxx的这样函 ...
- ASP.NET Core系列:JWT身份认证
1. JWT概述 JSON Web Token(JWT)是目前流行的跨域身份验证解决方案. JWT的官网地址:https://jwt.io JWT的实现方式是将用户信息存储在客户端,服务端不进行保存. ...
- linux线程绑定cpu
函数介绍 #define __USE_GNU #include <sched.h> void CPU_ZERO(cpu_set_t *set); void CPU_SET(int cpu, ...
- PMP备考-第二章-项目运行环境与项目经理
组织系统的三大因素:组织治理框架,管理要素和组织结构 组织治理和项目治理 组织治理 :组织中的重要决策制定框架,谁有权在什么时候用什么发放做出并推行什么重要决策. 项目治理 :组织为项目建立的高级别的 ...
- Writing Your Own Widget(自定义组件)
英文地址:http://dojotoolkit.org/reference-guide/1.10/quickstart/writingWidgets.html#quickstart-writingwi ...
- 简易解说拉格朗日对偶(Lagrange duality)(转载)
转载自https://www.cnblogs.com/90zeng/p/Lagrange_duality.html,本人觉得讲的非常好! 1.原始问题 假设是定义在上的连续可微函数(为什么要求连续可微 ...
- Uniform Buffer
Uniform Buffer 是一个很有用的缓存,可以将大量的需要传递至多个着色器的矩阵.向量数据等存储在uniform buffer中.这是一个公共的缓存,所以当多个着色器需要传递相同的数据时,可以 ...
- R 基于朴素贝叶斯模型实现手机垃圾短信过滤
# 读取数数据, 查看数据结构 df_raw <- read.csv("sms_spam.csv", stringsAsFactors=F) str(df_raw) leng ...