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配置文件中的参数,例如镜像名称、标签、端口等。这些步骤提供了基础的指南,但可能需要根据实际情况进行微调。

相关推荐
虹梦未来36 分钟前
【开发心得】在SpringBoot体系中正确使用redisConfig
java·spring boot·spring
雨奔1 小时前
Kubernetes 对象标识详解:Name、UID、Label
云原生·容器·kubernetes
user_admin_god2 小时前
OpenCode入门到入坑
java·人工智能·spring boot·语言模型
地瓜伯伯3 小时前
SpringBoot项目整合Elasticsearch启动失败的常见错误总结
spring boot·elasticsearch·spring cloud
霸道流氓气质4 小时前
SpringBoot中集成LangChain4j+阿里百炼平台实现AI对话记忆功能、对话隔离、对话持久化到Redis功能
人工智能·spring boot·redis
人道领域5 小时前
【黑马点评日记02】Redis缓存优化:商户查询性能提升百倍
java·spring boot·spring·servlet·tomcat·intellij-idea
SL-staff5 小时前
2026企业文档选型白皮书:功能、技术栈、私有化部署与采购建议
spring cloud·docker·微服务·kubernetes·开源·私有化部署·企业文档
四斤年华6 小时前
关于SpringBoot在MultipartFile上java.nio.file.NoSuchFileException: /tmp/undertow
java·spring boot·nio
cool32006 小时前
4D实验八:Dubbo微服务 + 注册中心
前端·kubernetes
希望永不加班6 小时前
SpringBoot 中 AOP 实现接口限流
java·spring boot·后端·spring