kubectl taint nodes node1 webserver:NoSchedule
kubectl taint nodes node2 mysql=true:NoSchedule
複製代碼
MySQL
容器空
,否則啓動 MYSQL 會失敗mkdir /var/lib/mysql
複製代碼
將 root 密碼存入 secret 內保存前端
kubectl create secret generic mysql-auth --from-literal=username=root --from-literal=password=root
複製代碼
vi deployment-cicd-mysql.yamlnode
apiVersion: apps/v1
kind: Deployment
metadata:
name: cicd-mysql
spec:
replicas: 1
selector:
matchLabels:
app: cicd-mysql
template:
metadata:
labels:
app: cicd-mysql
spec:
tolerations:
- key: "mysql"
operator: "Equal"
value: "true"
effect: "NoSchedule"
containers:
- name: cicd-mysql
image: mysql:5.7
imagePullPolicy: IfNotPresent
args:
- "--ignore-db-dir=lost+found"
ports:
- containerPort: 3306
volumeMounts:
- name: mysql-data
mountPath: "/var/lib/mysql"
env:
- name: MYSQL_ROOT_PASSWORD
valueFrom:
secretKeyRef:
name: mysql-auth
key: password
volumes:
- name: mysql-data
hostPath:
path: /var/lib/mysql
type: Directory
[root@master project]# kubectl apply -f deployment-cicd-mysql.yaml
deployment.apps/cicd-mysql created
//查看容器內的日誌 方便查看報錯
kubectl get pods
kubectl describe pods cicd-mysql-bcb77c759-bdrd8
kubectl logs cicd-mysql-6cbd4f95-g64hh
複製代碼
vi service-cicd-mysql.yamlmysql
apiVersion: v1
kind: Service
metadata:
name: service-cicd-mysql
spec:
selector:
app: cicd-mysql
ports:
- protocol: TCP
port: 3306
targetPort: 3306
type: NodePort
複製代碼
讓配置文件生效c++
kubectl apply -f service-cicd-mysql.yaml
複製代碼
鏈接數據庫初始化數據git
-h 爲任意節點的公網或內網 IPweb
mysql -h172.31.178.169 -P32636 -uroot -proot
mysql -h118.190.156.138 -P32636 -uroot -proot
create database cicd;
use cicd;
CREATE TABLE `users` (
`id` int(11) NOT NULL AUTO_INCREMENT COMMENT 'ID',
`name` varchar(255) NOT NULL COMMENT '姓名',
`age` int(11) NOT NULL COMMENT '年齡',
`sex` varchar(255) NOT NULL COMMENT '性別;1男 2女',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=9 DEFAULT CHARSET=utf8;
複製代碼
#!/bin/bash
time=$(date "+%Y%m%d%H%M%S")
npm install --registry=https://registry.npm.taobao.org
docker build -t 115.28.139.92:8082/cicd-backend:$time .
docker login -u $DOCKER_LOGIN_USERNAME -p $DOCKER_LOGIN_PASSWORD 115.28.139.92:8082
docker push 115.28.139.92:8082/cicd-backend:$time
複製代碼
vi mysql.config.yamlsql
apiVersion: v1
kind: ConfigMap
metadata:
name: mysql-config
data:
host: "service-cicd-mysql"
port: "3306"
database: "cicd"
kubectl apply -f mysql.config.yaml
複製代碼
vi mysql-auth.yamldocker
apiVersion: v1
kind: Secret
metadata:
name: mysql-auth
stringData:
username: root
password: root
type: Opaque
kubectl apply -f mysql.config.yaml
複製代碼
kubectl create secret docker-registry private-registry \
--docker-username=admin \
--docker-password=admin123 \
--docker-email=admin@example.org \
--docker-server=115.28.139.92:8082
複製代碼
vi cicd-backend.yamlshell
apiVersion: apps/v1
kind: Deployment
metadata:
name: cicd-backend
spec:
selector:
matchLabels:
app: cicd-backend
replicas: 1
template:
metadata:
labels:
app: cicd-backend
spec:
imagePullSecrets:
- name: private-registry
containers:
- name: cicd-backend
imagePullPolicy: Always
image: "115.28.139.92:8082/cicd-backend:20210321202052"
ports:
- containerPort: 7001
env:
- name: MYSQL_HOST
valueFrom:
configMapKeyRef:
name: mysql-config
key: host
- name: MYSQL_PORT
valueFrom:
configMapKeyRef:
name: mysql-config
key: port
- name: MYSQL_DATABASE
valueFrom:
configMapKeyRef:
name: mysql-config
key: database
- name: MYSQL_USER
valueFrom:
secretKeyRef:
name: mysql-auth
key: username
- name: MYSQL_PASSWORD
valueFrom:
secretKeyRef:
name: mysql-auth
key: password
kubectl apply -f cicd-backend.yaml
複製代碼
apiVersion: v1
kind: Service
metadata:
name: service-cicd-backend
spec:
selector:
app: cicd-backend
ports:
- protocol: TCP
port: 7001
targetPort: 7001
type: NodePort
kubectl apply -f service-cicd-backend.yaml
curl http://172.31.178.169:31300/user/list
複製代碼
yum -y install gcc gcc-c++ kernel-devel
複製代碼
#!/bin/sh -l
time=$(date "+%Y%m%d%H%M%S")
npm install --registry=https://registry.npm.taobao.org
npm run build
docker build -t 115.28.139.92:8082/cicd-frontend:$time .
docker login -u $DOCKER_LOGIN_USERNAME -p $DOCKER_LOGIN_PASSWORD 115.28.139.92:8082
docker push 115.28.139.92:8082/cicd-frontend:$time
複製代碼
vi cicd-frontend.yaml數據庫
apiVersion: apps/v1
kind: Deployment
metadata:
name: cicd-frontend
spec:
selector:
matchLabels:
app: cicd-frontend
replicas: 1
template:
metadata:
labels:
app: cicd-frontend
spec:
imagePullSecrets:
- name: private-registry
containers:
- name: cicd-frontend
image: 115.28.139.92:8082/cicd-frontend:20210321204724
kubectl apply -f cicd-frontend.yaml
複製代碼
vi service-cicd-frontend.yaml
apiVersion: v1
kind: Service
metadata:
name: service-cicd-frontend
spec:
selector:
app: cicd-frontend
ports:
- protocol: TCP
port: 80
targetPort: 80
type: NodePort
kubectl apply -f service-cicd-frontend.yaml
kubectl get svc
http://118.190.156.138:31753/
複製代碼
~/.kube/config
拷貝到 Content 中cat <<EOF > /etc/yum.repos.d/kubernetes.repo
[kubernetes]
name=Kubernetes
baseurl=http://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64
enabled=1
gpgcheck=0
repo_gpgcheck=0
gpgkey=http://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg
http://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg
EOF
yum install -y kubectl
複製代碼
k8s-config
=>Target 輸入k8s-config.yaml
kubectl set image
命令快速設置鏡像地址版本#!/bin/bash
time=$(date "+%Y%m%d%H%M%S")
npm install --registry=https://registry.npm.taobao.org
docker build -t 115.28.139.92:8082/cicd-backend:$time .
docker login -u $DOCKER_LOGIN_USERNAME -p $DOCKER_LOGIN_PASSWORD 115.28.139.92:8082
docker push 115.28.139.92:8082/cicd-backend:$time
+kubectl --kubeconfig=k8s-config.yaml set image deployment/cicd-backend cicd-backend=115.28.139.92:8082/cicd-backend:$time
複製代碼
deployment.apps/cicd-backend image updated
表示更新成功
webhook URL
地址webhookURL
和WebHook 密碼
強行刪除 pod
kubectl delete pod cicd-mysql-84795bc9d7-fpjmp --force --grace-period=0
複製代碼