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

相关推荐
❀͜͡傀儡师1 小时前
Spring Boot函数式编程:轻量级路由函数替代传统Controller
java·spring boot·后端
Mr.朱鹏1 小时前
超时订单处理方案实战指南【完整版】
java·spring boot·redis·spring·rabbitmq·rocketmq·订单
Coder_Boy_1 小时前
SpringAI与LangChain4j的智能应用-(实践篇4)
java·人工智能·spring boot·langchain
忍冬行者1 小时前
kubeadm安装的k8s集群涉及etcd数据库的参数优化
数据库·kubernetes·etcd
用户3521802454752 小时前
🎉Spring Boot 3 + 多数据源 + Druid:监控页面 + 控制台 SQL 日志,终于搞定啦!
spring boot·微服务
while(1){yan}2 小时前
计算器和登录界面(实现前后端互通)
spring boot·spring·servlet·java-ee·tomcat·maven
xiaoshujiaa3 小时前
Java大厂面试实录:谢飞机硬刚互联网医疗微服务架构,Spring Cloud+Redis+Kafka全踩坑
spring boot·redis·微服务·kafka·flyway·java面试·互联网医疗
一 乐3 小时前
养老院信息|基于springboot + vue养老院信息管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端
xiaoshujiaa3 小时前
微服务与大数据场景下的Java面试实录:从Spring Cloud到Flink的层层拷问
大数据·spring cloud·微服务·flink·kubernetes·java面试·resilience4j
木二_3 小时前
附055.Kubernetes部署Zabbix实战
云原生·容器·kubernetes·zabbix·监控