K8S部署监控的示例分析

K8S部署监控的示例分析,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

成都创新互联公司专业为企业提供富川网站建设、富川做网站、富川网站设计、富川网站制作等企业网站建设、网页设计与制作、富川企业网站模板建站服务,十年富川做网站经验,不只是建网站,更提供有价值的思路和整体网络服务。

kubernetes集群监控方案有许多种组合对其进行监控,但是在1.12版本后通常选择prometheus-operator + grafana 进行监控下面我们进行部署监控

1 下载项目

git clone https://github.com/coreos/kube-prometheus.git

是因为今年prometheus-operator项目搬到了coreos/kube-prometheus

2 排版

cd kube-prometheus/manifests/

mkdir -p operator node-exporter alertmanager grafana kube-state-metrics prometheus serviceMonitor adapter

mv *-serviceMonitor* serviceMonitor/
mv 0prometheus-operator* operator/
mv grafana-* grafana/
mv kube-state-metrics-* kube-state-metrics/
mv alertmanager-* alertmanager/
mv node-exporter-* node-exporter/
mv prometheus-adapter* adapter/
mv prometheus-* prometheus/

3 创建namespace

kubectl apply -f 00namespace-namespace.yaml

4 创建operator

kubectl apply -f operator/

查看pod
kubectl get pods  -n monitoring
等pod创建起来在进行下一步

5 创建其他CRD

kubectl apply -f adapter/
kubectl apply -f alertmanager/
kubectl apply -f node-exporter/
kubectl apply -f kube-state-metrics/
kubectl apply -f grafana/
kubectl apply -f prometheus/
kubectl apply -f serviceMonitor/

查看pod
kubectl get pods  -n monitoring
查看service
kubectl get svc  -n monitoring
发现全部是prometheus和grafana都是可以集群内部访问

6 使集群外可以访问prometheus 和 grafana

有两种方案可以实现此功能
1) nodeport方式
2)ingress-nginx方式

我么这边为了测试 选择nodeport方式

修改prometheus
# vim prometheus/prometheus-service.yaml 

apiVersion: v1
kind: Service
metadata:
  labels:
    prometheus: k8s
  name: prometheus-k8s
  namespace: monitoring
spec:
  ports:
  - name: web
    port: 9090
    targetPort: web
  type:
    NodePort
  selector:
    app: prometheus
    prometheus: k8s
  sessionAffinity: ClientIP
~  
增加nodeport

kubectl apply -f  prometheus/prometheus-service.yaml     


修改grafana
# vim grafana/grafana-service.yaml 

apiVersion: v1
kind: Service
metadata:
  labels:
    app: grafana
  name: grafana
  namespace: monitoring
spec:
  ports:
  - name: http
    port: 3000
    targetPort: http
  type:
    NodePort
  selector:
    app: grafana

kubectl apply -f grafana/grafana-service.yaml

查看sevice主要是查看nodeport端口我们可以访问


# kubectl get svc  -n monitoring

NAME                    TYPE        CLUSTER-IP       EXTERNAL-IP   PORT(S)             AGE
alertmanager-main       ClusterIP   10.99.60.117             9093/TCP            67m
alertmanager-operated   ClusterIP   None                     9093/TCP,6783/TCP   67m
grafana                 NodePort    10.105.159.125           3000:31746/TCP      67m
kube-state-metrics      ClusterIP   None                     8443/TCP,9443/TCP   67m
node-exporter           ClusterIP   None                     9100/TCP            67m
prometheus-adapter      ClusterIP   10.102.146.18            443/TCP             67m
prometheus-k8s          NodePort    10.107.201.125           9090:32040/TCP      67m
prometheus-operated     ClusterIP   None                     9090/TCP            67m
prometheus-operator     ClusterIP   None 
~

7 访问grafana web页面

http://masterip:31746

K8S部署监控的示例分析

K8S部署监控的示例分析

关于K8S部署监控的示例分析问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注创新互联行业资讯频道了解更多相关知识。


文章标题:K8S部署监控的示例分析
文章源于:http://myzitong.com/article/jsejoi.html