乐趣区

关于k8s:K8S部署Java项目实战

筹备

当时筹备好 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 我的项目就部署胜利了!

参考文章:https://blog.csdn.net/java_w/…

退出移动版