专注于 JetBrains IDEA 全家桶,永久激活,教程
持续更新 PyCharm,IDEA,WebStorm,PhpStorm,DataGrip,RubyMine,CLion,AppCode 永久激活教程

Spring Boot部署到 Kubernetes

前言

阅读本文,你可以学习到以下几点:

  • 如何将本地应用部署到Kubernetes

前期准备

在阅读本文前,需具备以下条件

应用部署

应用打包成镜像

可通过前文学习如何将应用打包成镜像

推送到私有仓库

镜像打包成功之后,我们需要将镜像推送 私有仓库

# 登录私有仓库
[root@k8s-master k8s]$ docker login 10.8.135.104:5000

# 查看本地镜像列表
[root@k8s-master k8s]$ docker images
REPOSITORY TAG IMAGE ID CREATED SIZE k8s-owater/kubedocker 0.0.1-SNAPSHOT 5920a6f4995d About an hour ago 663MB # 打标签 [root@k8s-master k8s]$ docker tag 5920a6f4995d 10.8.135.104:5000/k8s-owater/kubedocker:0.0.1-SNAPSHOT # 推送到私有仓库 [root@k8s-master k8s]$ docker push 10.8.135.104:5000/k8s-owater/kubedocker:0.0.1-SNAPSHOT 
  • docker tag [IMAGE ID] [私有hub域名]/[项目名称]/[镜像名称]:[镜像版本]
  • docker push [私有hub域名]/[项目名称]/[镜像名称]:[镜像版本]
查看私有镜像仓库

由于博主的仓库有认证的,所以需要浏览器登录才能查看

69_1.png 查看私有镜像仓库

Kubernetes连接私有仓库

# 创建密钥
[root@k8s-master ~]$ kubectl create secret docker-registry docker-registry-secret --docker-server=IP:5000 --docker-username=[用户名] --docker-password=[密码]

  • docker-registry-secret: 指定密钥的键名称
  • docker-server: 指定 Docker 仓库地址
  • docker-username: 指定 Docker 仓库用户名
  • docker-password: 指定 Docker 仓库登录密码

可通过 kubectl get secrets 查看密钥

69_2.png 查看密钥

开始部署

创建 k8s-owater-pod.yaml,文件如下

apiVersion: v1
kind: Pod
metadata:
  name: k8s-test-pod
  labels:
 app: k8s-test-pod spec: containers: - name: k8s-test-pod image: 10.8.135.104:5000/k8s-owater/kubedocker:0.0.1-SNAPSHOT imagePullPolicy: Always restartPolicy: Always imagePullSecrets: - name: docker-registry-secret # 这里就是前文中创建的secret, 用来访问私库 

执行命令, 进行部署

[root@k8s-master ~]$ kubectl apply -f k8s-owater-pod.yaml

登录 dashboard 查看

69_3.png 登录 dashboard 查看

访问应用

到此,我们已经成功将应用部署到Kubernetes,此时我们去访问curl http://10.8.135.104:8080/api/user

需要如下命令绑定主机 8080端口和pod的8080端口

# 绑定端口
[root@k8s-master ~]$ kubectl port-forward --address 0.0.0.0 k8s-owater 8080:8080

69_4.png

此时你可能会发觉当你退出时,也就将无法访问应用,是的,这种方式是不适合生产环境,只适合开发调试,下篇将给大家细说如何暴露接口访问

部署集群模式

我们已经成功部署单机模式,但生产环境中,基本上都是需要做集群模式。此时我们需要通过 Deployment 方式去部署,配置文件如下

apiVersion: apps/v1
kind: Deployment
metadata:
  name: k8s-owater
  labels:
 app: k8s-owater spec: replicas: 3 # 副本数量 template: metadata: name: k8s-owater labels: app: k8s-owater env: test spec: containers: - name: k8s-owater image: 10.8.135.104:5000/k8s-owater/kubedocker:0.0.1-SNAPSHOT imagePullPolicy: Always ports: - name: http-port containerPort: 8080 imagePullSecrets: - name: docker-registry-secret restartPolicy: Always selector: matchLabels: app: k8s-owater 

通过如下命令部署

[root@k8s-master ~]$ kubectl apply -f k8s-owater-deployment.yaml

69_5.png 部署集群模式

OK,集群部署好了,那问题来了,怎么访问集群呢,此时你会发觉pod已经不是前面的 k8s-owater 了,port-forward方式只能暴露某个pod

# 查看当前pod
[root@k8s-master ~]$ kubectl get pod
NAME                          READY   STATUS    RESTARTS   AGE
k8s-owater-6b689cc98c-gvxgx   1/1     Running   0          13m
k8s-owater-6b689cc98c-wbpv5   1/1     Running   0          11m
k8s-owater-6b689cc98c-x8n5v 1/1 Running 0 13m 

动态调整规模

Kubernetes 在集群能力表现的非常强大,我们可能动态的调整集群规模,你只需要调整,它将自动给你创建新的pod。 而且当某个pod挂了,它也会自动给你创建新的pod,可以自己通过删除pod体验

69_6.png 动态调整规模69_7.png 动态调整规模

文章永久链接:https://tech.souyunku.com/41883

未经允许不得转载:搜云库技术团队 » Spring Boot部署到 Kubernetes

JetBrains 全家桶,激活、破解、教程

提供 JetBrains 全家桶激活码、注册码、破解补丁下载及详细激活教程,支持 IntelliJ IDEA、PyCharm、WebStorm 等工具的永久激活。无论是破解教程,还是最新激活码,均可免费获得,帮助开发者解决常见激活问题,确保轻松破解并快速使用 JetBrains 软件。获取免费的破解补丁和激活码,快速解决激活难题,全面覆盖 2024/2025 版本!

联系我们联系我们