上传文件至 ''
This commit is contained in:
parent
3e99ca1e20
commit
6606eeead4
211
基于Kubernetes集群构建MongoDB.md
Normal file
211
基于Kubernetes集群构建MongoDB.md
Normal file
@ -0,0 +1,211 @@
|
||||
<h1><center>基于Kubernetes集群构建MongoDB</center></h1>
|
||||
|
||||
作者:行癫(盗版必究)
|
||||
|
||||
------
|
||||
|
||||
## 一:基础环境
|
||||
|
||||
1.Kubernetes集群正常运行
|
||||
|
||||
data:image/s3,"s3://crabby-images/b2a14/b2a14ab0074f60452325fa0be3893f86bc56f432" alt="image-20231122095145370"
|
||||
|
||||
2.Harbor私有仓库正常运行
|
||||
|
||||
data:image/s3,"s3://crabby-images/d01d0/d01d02b9c20f5c7f98533b4b0c3f9700ebe88fe2" alt="image-20231122095408602"
|
||||
|
||||
## 二:MongoDB项目部署
|
||||
|
||||
MongoDB项目对应Kubernetes的yaml文件:
|
||||
|
||||
```yaml
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: Namespace
|
||||
metadata:
|
||||
name: mongodb
|
||||
|
||||
---
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
labels:
|
||||
k8s.kuboard.cn/layer: web
|
||||
k8s.kuboard.cn/name: mongodb
|
||||
name: mongodb
|
||||
namespace: mongodb
|
||||
spec:
|
||||
progressDeadlineSeconds: 600
|
||||
replicas: 1
|
||||
revisionHistoryLimit: 10
|
||||
selector:
|
||||
matchLabels:
|
||||
k8s.kuboard.cn/layer: web
|
||||
k8s.kuboard.cn/name: mongodb
|
||||
strategy:
|
||||
rollingUpdate:
|
||||
maxSurge: 25%
|
||||
maxUnavailable: 25%
|
||||
type: RollingUpdate
|
||||
template:
|
||||
metadata:
|
||||
creationTimestamp: null
|
||||
labels:
|
||||
k8s.kuboard.cn/layer: web
|
||||
k8s.kuboard.cn/name: mongodb
|
||||
spec:
|
||||
containers:
|
||||
- env:
|
||||
- name: MONGO_INITDB_ROOT_USERNAME
|
||||
value: root
|
||||
- name: MONGO_INITDB_ROOT_PASSWORD
|
||||
value: xingdian
|
||||
image: mongo
|
||||
#image: 10.9.12.201/xingdian/mongo
|
||||
imagePullPolicy: IfNotPresent
|
||||
name: mongodb
|
||||
ports:
|
||||
- containerPort: 27017
|
||||
name: sss
|
||||
protocol: TCP
|
||||
resources: {}
|
||||
terminationMessagePath: /dev/termination-log
|
||||
terminationMessagePolicy: File
|
||||
volumeMounts:
|
||||
- mountPath: /data/db
|
||||
name: volume-4ztti
|
||||
dnsPolicy: ClusterFirst
|
||||
restartPolicy: Always
|
||||
schedulerName: default-scheduler
|
||||
terminationGracePeriodSeconds: 30
|
||||
volumes:
|
||||
- name: volume-4ztti
|
||||
nfs:
|
||||
path: /data/mongodb
|
||||
server: 10.9.12.250
|
||||
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
labels:
|
||||
k8s.kuboard.cn/layer: web
|
||||
k8s.kuboard.cn/name: mongodb
|
||||
name: mongodb
|
||||
namespace: mongodb
|
||||
spec:
|
||||
clusterIP: 10.108.206.134
|
||||
clusterIPs:
|
||||
- 10.108.206.134
|
||||
externalTrafficPolicy: Cluster
|
||||
internalTrafficPolicy: Cluster
|
||||
ipFamilies:
|
||||
- IPv4
|
||||
ipFamilyPolicy: SingleStack
|
||||
ports:
|
||||
- name: 3cmrmd
|
||||
nodePort: 30150
|
||||
port: 27017
|
||||
protocol: TCP
|
||||
targetPort: 27017
|
||||
selector:
|
||||
k8s.kuboard.cn/layer: web
|
||||
k8s.kuboard.cn/name: mongodb
|
||||
sessionAffinity: None
|
||||
type: NodePort
|
||||
```
|
||||
|
||||
MongoDB-Express项目对应Kubernetes的yaml文件:
|
||||
|
||||
```
|
||||
---
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
labels:
|
||||
k8s.kuboard.cn/layer: web
|
||||
k8s.kuboard.cn/name: mongodb-express
|
||||
name: mongodb-express
|
||||
namespace: mongodb
|
||||
spec:
|
||||
progressDeadlineSeconds: 600
|
||||
replicas: 1
|
||||
revisionHistoryLimit: 10
|
||||
selector:
|
||||
matchLabels:
|
||||
k8s.kuboard.cn/layer: web
|
||||
k8s.kuboard.cn/name: mongodb-express
|
||||
strategy:
|
||||
rollingUpdate:
|
||||
maxSurge: 25%
|
||||
maxUnavailable: 25%
|
||||
type: RollingUpdate
|
||||
template:
|
||||
metadata:
|
||||
creationTimestamp: null
|
||||
labels:
|
||||
k8s.kuboard.cn/layer: web
|
||||
k8s.kuboard.cn/name: mongodb-express
|
||||
spec:
|
||||
containers:
|
||||
- env:
|
||||
- name: ME_CONFIG_MONGODB_ADMINUSERNAME
|
||||
value: root
|
||||
- name: ME_CONFIG_MONGODB_ADMINPASSEORD
|
||||
value: xingdian
|
||||
- name: ME_CONFIG_MONGODB_URL
|
||||
value: 'mongodb://root:xingdian@10.9.12.206:30150/'
|
||||
#注意这里是连接mongodb的url,其中root是用户,xingdian是密码
|
||||
image: 10.9.12.201/xingdian/mongo-express
|
||||
#image: mongodb-express
|
||||
imagePullPolicy: IfNotPresent
|
||||
name: mongodb-express
|
||||
ports:
|
||||
- containerPort: 8081
|
||||
name: qq
|
||||
protocol: TCP
|
||||
terminationMessagePath: /dev/termination-log
|
||||
terminationMessagePolicy: File
|
||||
dnsPolicy: ClusterFirst
|
||||
restartPolicy: Always
|
||||
schedulerName: default-scheduler
|
||||
terminationGracePeriodSeconds: 30
|
||||
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
labels:
|
||||
k8s.kuboard.cn/layer: web
|
||||
k8s.kuboard.cn/name: mongodb-express
|
||||
name: mongodb-express
|
||||
namespace: mongodb
|
||||
resourceVersion: '36330826'
|
||||
spec:
|
||||
clusterIP: 10.110.224.114
|
||||
clusterIPs:
|
||||
- 10.110.224.114
|
||||
externalTrafficPolicy: Cluster
|
||||
internalTrafficPolicy: Cluster
|
||||
ipFamilies:
|
||||
- IPv4
|
||||
ipFamilyPolicy: SingleStack
|
||||
ports:
|
||||
- name: berrtc
|
||||
nodePort: 30151
|
||||
port: 8081
|
||||
protocol: TCP
|
||||
targetPort: 8081
|
||||
selector:
|
||||
k8s.kuboard.cn/layer: web
|
||||
k8s.kuboard.cn/name: mongodb-express
|
||||
sessionAffinity: None
|
||||
type: NodePort
|
||||
```
|
||||
|
||||
1.浏览器访问MongoDB管理界面
|
||||
|
||||
data:image/s3,"s3://crabby-images/5ee6c/5ee6ca94b0215d970c6a8883b5dc056ce6409743" alt="image-20231122100003032"
|
||||
|
||||
## 三:MongoDB使用
|
||||
|
Loading…
Reference in New Issue
Block a user