k8S 发布spring boot的jar包

在Kubernetes(K8s)上部署Spring Boot应用(打包成jar文件)的基本步骤如下:

1. 准备Spring Boot应用的Jar包

确保你的Spring Boot应用已经成功构建,生成了可执行的jar包。

2. 创建Docker镜像

为你的Spring Boot应用创建一个Docker镜像。

  1. 创建Dockerfile:在Spring Boot应用的根目录创建一个Dockerfile。这个文件描述了如何构建你的Spring Boot应用的Docker镜像。

    示例Dockerfile:

    Dockerfile 复制代码
    FROM openjdk:8-jdk-alpine
    ARG JAR_FILE=target/*.jar
    COPY ${JAR_FILE} app.jar
    ENTRYPOINT ["java","-jar","/app.jar"]
  2. 构建Docker镜像:运行以下命令来构建Docker镜像:

    bash 复制代码
    docker build -t my-springboot-app:latest .
  3. 推送到镜像仓库:将构建好的镜像推送到Docker镜像仓库,如Docker Hub或私有仓库。

    bash 复制代码
    docker tag my-springboot-app:latest [YOUR_DOCKERHUB_NAME]/my-springboot-app:latest
    docker push [YOUR_DOCKERHUB_NAME]/my-springboot-app:latest

3. 在Kubernetes上部署Spring Boot应用

  1. 创建部署配置文件:创建一个Kubernetes部署文件(YAML),定义如何在K8s上运行你的Spring Boot应用。

    示例deployment.yaml:

    yaml 复制代码
    apiVersion: apps/v1
    kind: Deployment
    metadata:
      name: my-springboot-app
    spec:
      replicas: 1
      selector:
        matchLabels:
          app: my-springboot-app
      template:
        metadata:
          labels:
            app: my-springboot-app
        spec:
          containers:
          - name: my-springboot-app
            image: [YOUR_DOCKERHUB_NAME]/my-springboot-app:latest
            ports:
            - containerPort: 8080
  2. 创建服务配置文件:如果你的应用需要对外提供服务,创建一个服务配置文件(YAML)。

    示例service.yaml:

    yaml 复制代码
    apiVersion: v1
    kind: Service
    metadata:
      name: my-springboot-app-service
    spec:
      type: NodePort
      ports:
        - port: 8080
          nodePort: 30007
      selector:
        app: my-springboot-app
  3. 部署到Kubernetes集群

    bash 复制代码
    kubectl apply -f deployment.yaml
    kubectl apply -f service.yaml
  4. 验证部署:检查部署状态和服务是否正常运行。

    bash 复制代码
    kubectl get deployments
    kubectl get pods
    kubectl get service

4. 访问Spring Boot应用

如果一切设置正确,你的Spring Boot应用现在应该在Kubernetes集群中运行了。你可以通过配置的NodePort(如30007)访问你的应用。

请确保根据实际情况调整上述Dockerfile和Kubernetes配置文件中的参数,例如镜像名称、标签、端口等。这些步骤提供了基础的指南,但可能需要根据实际情况进行微调。

相关推荐
爱吃羊的老虎3 小时前
【JAVA】python转java:Spring Boot 入门
java·spring boot·python
_qingche5 小时前
H2 数据库到 MySQL 数据迁移
java·数据库·spring boot·mysql·spring·重构·kotlin
真上帝的左手5 小时前
11. 容器化 vs 虚拟化-K8s-工作负载实战
云原生·容器·kubernetes
码语智行7 小时前
系统启动时初始化数据功能分析
java·spring boot
invicinble7 小时前
推荐一下,遇到的几本比较好的书
spring boot
张忠琳8 小时前
【kubernetes v1.21】(controller-manager part 1)kube-controller-manager 核心架构与启动流程
云原生·架构·kubernetes
憧憬成为java架构高手的小白8 小时前
git工作流程简化版
java·spring boot·git
qq_452396239 小时前
第十五篇:《Docker 与 Kubernetes 集成:从 Swarm 到 K8s 的迁移》
docker·容器·kubernetes
HackTwoHub9 小时前
K8s综合渗透测试工具,集成信息搜集、权限逃逸、横向移动,一站式搞定全流程渗透测试工作
人工智能·安全·web安全·云原生·容器·kubernetes·系统安全
YDS8299 小时前
DeepSeek RAG&MCP + Agent智能体项目 —— 动态决策策略的接口对接
java·spring boot·ai·agent·spring ai·deepseek