• k8s的项目部署



    k8s的项目部署

    开发阶段

    ● 编写代码。
    ● 测试。
    ● 编写Dockerfile。

    持续集成

    ● 代码编译、打包。
    ● 制作镜像。
    ● 将镜像上传到镜像仓库。

    应用部署

    ● 环境准备。
    ● 创建Pod、Service、Ingress。

    运维

    ● 监控。
    ● 故障排查。
    ● 应用升级及优化。
    ● ……


    k8s中部署Java项目的流程

    ● ① 通过Dockerfile制作镜像。
    ● ② 将镜像推送到镜像仓库,比如阿里云镜像仓库等。
    ● ③ Pod控制器部署镜像。
    ● ④ 创建Service或Ingress对外暴露应用。
    ● ⑤ 对集群进行监控、升级等。


    k8s中部署Java项目

    制作镜像

    1. 准备java项目,然后打包得到对应的jar包 — 这一步演示过程省略
    2. 在项目的根目录下新建Dockerfile文件:
    FROM openjdk
    VOLUME /tmp
    COPY ./target/springboot2-1.0.jar springboot2-1.0.jar
    RUN bash -c "touch /springboot2-1.0.jar"
    # 声明时区
    RUN ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && echo 'Asia/Shanghai' >/etc/timezone
    #声明运行时容器提供服务端口,这只是一个声明,在运行时并不会因为这个声明应用就会开启这个端口的服务
    EXPOSE 8080
    ENTRYPOINT ["java","-jar","/springboot2-1.0.jar"]
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 制作镜像

    将整个项目通过ftp上传到k8s集群所在的服务器中(其实完全可以只上传jar包和Dockerfile文件)。

    在这里插入图片描述
    进入springboot2目录,然后使用docker build构建镜像:

    # springboot是镜像的名称
    docker build -t springboot2 .
    
    • 1
    • 2

    推送镜像

    阿里云创建命名空间:
    在这里插入图片描述
    在这里插入图片描述
    阿里云创建镜像仓库:
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    登录阿里云Docker Registry:

    sudo docker login --username=阿里云账号 registry.cn-hangzhou.aliyuncs.com
    
    • 1

    查看上传的Docker镜像的id:

    docker images
    
    • 1

    在这里插入图片描述
    给镜像打tag:

    sudo docker tag bc56e4a83ff7 registry.cn-hangzhou.aliyuncs.com/k8s-test-123/springboot2:latest
    
    • 1

    在这里插入图片描述
    推送镜像:

    sudo docker push registry.cn-hangzhou.aliyuncs.com/k8s-test-123/springboot2:latest
    
    • 1

    部署镜像暴露应用

    创建deployment.yaml文件,内容如下:

    apiVersion: apps/v1
    kind: Deployment
    metadata:
      labels:
        app: springboot2
      name: springboot2
    spec:
      replicas: 3
      selector:
        matchLabels:
          app: springboot2
      template:
        metadata:
          labels:
            app: springboot2
        spec:
          containers:
          - image: registry.cn-hangzhou.aliyuncs.com/k8s-test-123/springboot2:latest
            name: springboot2
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19

    创建Deployment:

    kubectl create -f deployment.yaml
    
    • 1

    查看Deployment和Pod:

    kubectl get deploy,pod
    
    • 1

    在这里插入图片描述
    创建service.yaml文件,内容如下:

    apiVersion: v1
    kind: Service
    metadata:
      labels:
        app: springboot2
      name: svc
    spec:
      ports:
      - port: 8080
        protocol: TCP
        targetPort: 8080
        nodePort: 30091
      selector:
        app: springboot2
      type: NodePort
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    创建Service:

    kubectl create -f service.yaml
    
    • 1

    查看Service:

    kubectl get service
    
    • 1

    在这里插入图片描述

  • 相关阅读:
    RocketMq(三)-springboot项目访问
    Qt 样式设置
    传统网站与数字化网站的对比
    阿里的iOS协程库 coobjc 源码解析(一)——元组和协程
    Samtec连接器技术前沿 | 全新对准功能确保测试和测量应用中的精确对准
    工具模板 | 用APOEM方法消除对用户行为的偏见
    python之value_counts()介绍
    计算机毕业设计——校园二手市场
    2023年9月12日
    Continual Learning of Large Language Models: A Comprehensive Survey
  • 原文地址:https://blog.csdn.net/m0_53157173/article/details/126713116