手把手教你实现Kubernetes Gitops

云计算 云原生
在这篇博文中,介绍了使用 Docker 将 Spring Boot 应用程序容器化并将其部署到 Kubernetes 集群的过程。这种方法有助于管理应用程序的生命周期、简化部署并确保跨不同环境的行为一致。

介绍

容器化已成为管理和部署应用程序的流行方法,提供了一种跨不同环境一致地打包、分发和运行应用程序的简便方法。在这篇博文中,将介绍使用 Docker 将 Spring Boot 应用程序容器化并将其部署到 Kubernetes 集群的过程。还将提供代码示例和分步说明,以简化流程。

先决条件

  1. Java 开发工具包 (JDK) 8 或更高版本
  2. Maven 或 Gradle
  3. Docker
  4. Kubernetes 集群(例如,Minikube、EKS 或 GKE)

第 1 步:创建 Spring Boot 应用程序

首先,使用 Spring Initializr Web 服务创建一个简单的 Spring Boot 应用程序。可以通过访问https://start.spring.io/并选择所需的选项,或者通过在 Spring Boot CLI 中使用以下命令来执行此操作:

$ spring init --dependencies=web my-spring-boot-app

此命令创建一个 Spring Boot 应用程序,该web应用程序在名为my-spring-boot-app。

第 2 步:构建应用程序

切换到应用程序目录并使用 Maven 或 Gradle 构建应用程序。

Maven:

$ cd my-spring-boot-app 
$ ./mvnw clean install

Gradle:

$ cd my-spring-boot-app 
$ ./gradlew clean build

第 3 步:创建 Dockerfile

在应用程序目录的根目录中,创建一个名为Dockerfile以下内容的文件:

FROM openjdk:8-jdk-alpine 
EXPOSE 8080 
ARG JAR_FILE=target/*.jar 
COPY ${JAR_FILE} app.jar 
ENTRYPOINT ["java", "-jar", "/app.jar"]

这个 Dockerfile 指定基础镜像,公开应用程序端口,将构建的 JAR 文件复制到容器,并定义运行应用程序的入口点。

第 4 步:构建 Docker 镜像

使用以下命令构建 Docker 镜像:

$ docker build -t my-spring-boot-app:latest

第 5 步:将 Docker 镜像推送到注册表

将 Docker 映像推送到注册表,例如 Docker Hub、Google Container Registry 或 Amazon Elastic Container Registry。替换<your-dockerhub-username>为您的 Docker Hub 用户名。

$ docker tag my-spring-boot-app:latest <your-dockerhub-username>/my-spring-boot-app:latest 
$ docker push <your-dockerhub-username>/my-spring-boot-app:latest

第 6 步:创建 Kubernetes 部署

创建一个名为deployment.yaml以下内容的文件:

apiVersion: apps/v1
kind: Deployment
metadata:
  name: my-spring-boot-app
spec:
  replicas: 3
  selector:
    matchLabels:
      app: my-spring-boot-app
  template:
    metadata:
      labels:
        app: my-spring-boot-app
    spec:
      containers:
      - name: my-spring-boot-app
        image: <your-dockerhub-username>/my-spring-boot-app:latest
        ports:
        - containerPort: 8080

此配置定义了一个 Kubernetes 部署,其中包含 Spring Boot 应用程序的三个副本。

第 7 步:创建 Kubernetes 服务

创建一个名为service.yaml以下内容的文件:

apiVersion: v1
kind: Service
metadata:
  name: my-spring-boot-app
spec:
  selector:
    app: my-spring-boot-app
  ports:
    - protocol: TCP
      port: 80
      targetPort: 8080
  type: LoadBalancer

此配置定义了一个 Kubernetes 服务,该服务在端口 80 上公开 Spring Boot 应用程序并负载平衡副本之间的流量。

第 8 步:部署到 Kubernetes

使用以下命令将 Kubernetes 配置应用到您的集群:

$ kubectl apply -f deployment.yaml 
$ kubectl apply -f service.yaml

第 9 步:访问应用程序

等待将外部 IP 地址分配给服务。使用以下命令检查服务的外部 IP:

$ kubectl get svc my-spring-boot-app

外部 IP 可用后,在浏览器或任何 HTTP 客户端中使用 IP 地址和端口 80 访问应用程序。

结论

在这篇博文中,介绍了使用 Docker 将 Spring Boot 应用程序容器化并将其部署到 Kubernetes 集群的过程。这种方法有助于管理应用程序的生命周期、简化部署并确保跨不同环境的行为一致。Docker 和 Kubernetes 等容器化和编排技术已成为现代应用程序开发和部署的重要工具。

责任编辑:武晓燕 来源: Java学研大本营
相关推荐

2011-01-06 10:39:25

.NET程序打包

2009-11-09 14:57:37

WCF上传文件

2021-07-14 09:00:00

JavaFX开发应用

2011-01-10 14:41:26

2011-05-03 15:59:00

黑盒打印机

2011-04-21 10:32:44

MySQL双机同步

2021-03-12 10:01:24

JavaScript 前端表单验证

2020-05-15 08:07:33

JWT登录单点

2022-07-27 08:16:22

搜索引擎Lucene

2022-03-14 14:47:21

HarmonyOS操作系统鸿蒙

2022-01-08 20:04:20

拦截系统调用

2022-12-07 08:42:35

2021-02-26 11:54:38

MyBatis 插件接口

2011-02-22 13:46:27

微软SQL.NET

2021-12-28 08:38:26

Linux 中断唤醒系统Linux 系统

2011-02-22 14:36:40

ASP.NETmsdnC#

2016-05-12 11:54:39

2015-07-15 13:18:27

附近的人开发

2022-07-28 16:06:08

app分身

2011-10-06 14:32:43

点赞
收藏

51CTO技术栈公众号