准備
事先准備好k8s集群,打包你的項目並上傳到docker倉庫
yaml文件
k8s的yaml文件可以自己手動寫(不推薦),也可以通過kubectl create生成,這里不多說了,網上相關的文章多的是。。。下面是我的yaml文件。
test-deployment.yaml
---
apiVersion: apps/v1
kind: Deployment
metadata:
name: test-k8s
namespace: default
labels:
cloud-service-module: test
app: test-k8s
spec:
replicas: 3
selector:
matchLabels:
cloud-service-module: test
app: test-k8s
template:
metadata:
labels:
app: test-k8s
cloud-service-module: test
spec:
restartPolicy: Always
containers:
- name: test-k8s
image: "test-k8s" # 這里填你自己項目的鏡像地址
imagePullPolicy: "IfNotPresent"
envFrom:
- configMapRef:
name: test-k8s-configmap
ports:
- name: tomcat
containerPort: 8080
readinessProbe:
tcpSocket:
port: 8080
initialDelaySeconds: 5
periodSeconds: 10
test-configmap.yaml
---
apiVersion: v1
kind: ConfigMap
metadata:
name: test-configmap
data:
# 我這里寫的是項目所需要的環境變量
test_ip: 172.20.151.111
test_port: "5555" # 注意這里的value如果是數字需要加上雙引號,否則會報錯
test-service.yaml
apiVersion: v1
kind: Service
metadata:
name: test-service
namespace: default
labels:
cloud-service-module: test
cloud-service-type: java
cloud-service-category: backend
spec:
type: ClusterIP
ports:
- name: tomcat
port: 8080
targetPort: 8080
部署
登陸docker倉庫
在你的k8s集群上需要先登錄項目鏡像所在的倉庫,如果不執行該操作,創建pod的時候鏡像會拉取失敗!!
docker login --username=xxx [你的倉庫地址]
看到下圖就是登陸成功
注意,登錄docker倉庫可能會出現如下問題
Error response from daemon: Get https://xxx: dial tcp xxx:443: connect: connection refused
解決方案
vi /usr/lib/systemd/system/docker.service
#添加--insecure-registry=mysql.gift
ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock --insecure-registry=mysql.gift
#執行命令
systemctl daemon-reload
systemctl restart docker
#查看是否成功
ps -ef|grep docker
[root@k8s-node1 ~]# ps -ef|grep docker
root 7730 1 0 09:26 ? 00:00:20 /usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock --insecure-registry=xxx
重新登錄docker倉庫問題解決
創建pod
分別執行命令:
kubectl apply -f test-service.yaml
kubectl apply -f test-configmap.yaml
kubectl apply -f test-deployment.yaml
最后通過kubectl get pod,svc
命令驗證是否部署成功
至此,我們的Java項目就部署成功了!