[TOC]
快速搭建 grafana 可视化平台
项目地址: https://github.com/grafana/grafana/
官方地址: https://grafana.com
安装部署
步骤 01.资源清单(granana.ini)与 (Deployment)部署资源清单。
[TOC]
项目地址: https://github.com/grafana/grafana/
官方地址: https://grafana.com
安装部署
步骤 01.资源清单(granana.ini)与 (Deployment)部署资源清单。
[TOC]
项目地址: https://github.com/grafana/grafana/
官方地址: https://grafana.com
安装部署
步骤 01.资源清单(granana.ini)与 (Deployment)部署资源清单。1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104tee grafana.ini <<'EOF'
[server]
domain = devops.weiyigeek.top
root_url = %(protocol)s://%(domain)s:%(http_port)s/grafana/
serve_from_sub_path = true
EOF
tee grafana-deploy.yaml <<'EOF'
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: grafana-pvc
namespace: dashboard
spec:
accessModes:
- ReadWriteOnce
resources:
requests:
storage: 2Gi
---
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
app: grafana
name: grafana
namespace: dashboard
spec:
selector:
matchLabels:
app: grafana
template:
metadata:
labels:
app: grafana
spec:
securityContext:
fsGroup: 472
supplementalGroups:
- 0
containers:
- name: grafana
image: grafana/grafana:9.0.2
imagePullPolicy: IfNotPresent
ports:
- containerPort: 3000
name: http-grafana
protocol: TCP
readinessProbe:
failureThreshold: 3
httpGet:
path: /robots.txt
port: 3000
scheme: HTTP
initialDelaySeconds: 10
periodSeconds: 30
successThreshold: 1
timeoutSeconds: 2
livenessProbe:
failureThreshold: 3
initialDelaySeconds: 30
periodSeconds: 10
successThreshold: 1
tcpSocket:
port: 3000
timeoutSeconds: 1
resources:
requests:
cpu: 512m
memory: 1024Mi
volumeMounts:
- mountPath: /var/lib/grafana
name: grafana-pv
- mountPath: /etc/grafana/grafana.ini
name: ge-config
subPath: grafana.ini
volumes:
- name: grafana-pv
persistentVolumeClaim:
claimName: grafana-pvc
- name: ge-config
configMap:
name: ge-config
items:
- key: grafana.ini
path: grafana.ini
---
apiVersion: v1
kind: Service
metadata:
name: grafana
namespace: dashboard
spec:
ports:
- port: 3000
protocol: TCP
targetPort: http-grafana
selector:
app: grafana
sessionAffinity: None
type: LoadBalancer
EOF
步骤 02.创建 grafana.ini 的 configmap 以及部署 grafana 到集群中1
2kubectl create configmap ge-config --from-file=grafana.ini --namespace dashboard
kubectl create -f grafana-deploy.yaml --namespace dashboard
步骤 03.部署情况与日志情况查看。1
2
3kubectl logs -f --tail 50 -n dashboard -l app=grafana
# 关键日志:
# logger=http.server t=2022-07-14T07:24:25.409774065Z level=info msg="HTTP Server Listen" address=[::]:3000 protocol=http subUrl=/grafana socket=
步骤 04.配置 grafana ingress 的资源清单我们便可通过域名+grafana目录
的方式进行访问。1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
annotations:
ingressclass.kubernetes.io/is-default-class: "true"
nginx.ingress.kubernetes.io/client-body-buffer-size: 50m
nginx.ingress.kubernetes.io/proxy-body-size: 50m
nginx.ingress.kubernetes.io/proxy-buffer-size: 50m
nginx.ingress.kubernetes.io/proxy-buffering: "on"
nginx.ingress.kubernetes.io/proxy-buffers-number: "4"
nginx.ingress.kubernetes.io/proxy-connect-timeout: 60s
nginx.ingress.kubernetes.io/proxy-read-timeout: 120s
nginx.ingress.kubernetes.io/proxy-send-timeout: 120s
nginx.ingress.kubernetes.io/rewrite-target: /$2
labels:
app: devops
ref: devops
url: devops.weiyigeek.top
name: devops-weiyigeek
namespace: dashboard
spec:
ingressClassName: nginx
rules:
- host: devops.weiyigeek.top
http:
paths:
- backend:
service:
name: grafana
port:
number: 3000
path: /grafana(/|$)(.*)
pathType: ImplementationSpecific
tls:
- hosts:
- devops.weiyigeek.top
secretName: weiyigeek.top
温馨提示: 在进行前面操作完毕后我们便可通过https://devops.weiyigeek.top/grafana/login
域名地址进行访问,默认密码 admin。
描述: 使用K8S快速搭建vsftpd服务,一键部署测试环境,此处使用的是[fauria/vsftpd][https://hub.docker.com/r/fauria/vsftpd]镜像基于Centos 7的vsftpd Docker镜像,支持被动模式和虚拟用户。
此Docker容器实现了一个vsftpd服务器,具有以下特性:
Centos 7基础图像。
vsftpd 3.0版本
支持虚拟用户
支持被动模式(Passive mode)
记录到文件或STDOUT。
资源清单:1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117tee deploy-vsftpd.yaml <<'EOF'
# ftp-pvc.yaml
# storageClassName 存储按自己环境修改,此次使用 nfs-local,你可以通过如下命令查看
# kubectl get storageclasses.storage.k8s.io
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: vsftpd-pvc
namespace: default
spec:
storageClassName: nfs-local
accessModes:
- ReadWriteMany
resources:
requests:
storage: 10Gi
---
apiVersion: apps/v1
kind: Deployment
metadata:
name: vsftpd
namespace: default
spec:
replicas: 1
selector:
matchLabels:
app: vsftpd
template:
metadata:
labels:
app: vsftpd
spec:
# 将创建的的PVC绑定到ftp-pv-storage
volumes:
- name: ftp-pv-storage
persistentVolumeClaim:
claimName: vsftpd-pvc
containers:
- name: ftp-container
image: fauria/vsftpd
# 除21端口外 此处的端口要与下方设置的被动模式最大端口和最小端口匹配,例如设置随机端口范围为 31110-31115。因为此处容器内的随机端口要与映射后的一致,所以设置为30000以上,在k8s设置端口范围内
ports:
- containerPort: 31110
protocol: TCP
- containerPort: 31111
protocol: TCP
- containerPort: 31112
protocol: TCP
- containerPort: 31113
protocol: TCP
- containerPort: 31114
protocol: TCP
- containerPort: 31115
protocol: TCP
- containerPort: 21
protocol: TCP
volumeMounts:
- mountPath: "/home/vsftpd"
name: ftp-pv-storage
env:
- name: FTP_USER
value: "weiyigeek"
- name: FTP_PASS
value: "password"
# 随机最大端口与最小端口,要与上面设置的匹配
- name: PASV_MIN_PORT
value: "31110"
- name: PASV_MAX_PORT
value: "31115"
- name: PASV_ENABLE
value: "yes"
# 服务器传回的IP地址,一般为对外公网地址,即客户端连接ftp所用的地址。
- name: PASV_ADDRESS
value: "10.20.176.215"
#- name: PASV_ADDRESS
# valueFrom:
# fieldRef:
# fieldPath: status.hostIP
---
# ftp-service.yaml
apiVersion: v1
kind: Service
metadata:
name: vsftpd-service
labels:
app: vsftpd-service
namespace: default
spec:
type: NodePort
# 除21端口映射外,其他端口需保持一致
ports:
- name: ftp-21
nodePort: 30021
port: 21
- name: ftp-31110
nodePort: 31110
port: 31110
- name: ftp-31111
nodePort: 31111
port: 31111
- name: ftp-31112
nodePort: 31112
port: 31112
- name: ftp-31113
nodePort: 31113
port: 31113
- name: ftp-31114
nodePort: 31114
port: 31114
- name: ftp-31115
nodePort: 31115
port: 31115
selector:
app: vsftpd
EOF
kubectl apply -f deploy-vsftpd.yaml
kubectl get deploy,svc,pod,pvc
你好看友,欢迎关注博主微信公众号哟! ❤
这将是我持续更新文章的动力源泉,谢谢支持!(๑′ᴗ‵๑)
温馨提示: 未解锁的用户不能粘贴复制文章内容哟!
方式1.请访问本博主的B站【WeiyiGeek】首页关注UP主,
将自动随机获取解锁验证码。
Method 2.Please visit 【My Twitter】. There is an article verification code in the homepage.
方式3.扫一扫下方二维码,关注本站官方公众号
回复:验证码
将获取解锁(有效期7天)本站所有技术文章哟!
@WeiyiGeek - 为了能到远方,脚下的每一步都不能少
欢迎各位志同道合的朋友一起学习交流,如文章有误请在下方留下您宝贵的经验知识,个人邮箱地址【master#weiyigeek.top】
或者个人公众号【WeiyiGeek】
联系我。
更多文章来源于【WeiyiGeek Blog - 为了能到远方,脚下的每一步都不能少】, 个人首页地址( https://weiyigeek.top )
专栏书写不易,如果您觉得这个专栏还不错的,请给这篇专栏 【点个赞、投个币、收个藏、关个注、转个发、赞个助】,这将对我的肯定,我将持续整理发布更多优质原创文章!。
最后更新时间:
文章原始路径:_posts/系统运维/快速部署/K8S快速部署常用服务.md
转载注明出处,原文地址:https://blog.weiyigeek.top/2022/2-25-668.html
本站文章内容遵循 知识共享 署名 - 非商业性 - 相同方式共享 4.0 国际协议