目录
前言
1. 生成Demo项目
2. 配置Docker环境
3. 配置k8s
3.1 编写deploy.yaml文件
3.2 启动调度
4. 验证
4.1 查看pod
4.2 访问系统
5. k8s配置文件参数详解
首页 Java java教程 如何部署java项目到k8s中

如何部署java项目到k8s中

May 15, 2023 pm 06:07 PM
java k8s

    前言

    Java项目在开发调试的过程中都需要进行各种环境的安装部署,在之前我们使用虚拟机部署时都是通过在机器上执行命令或者配置Jekins脚本自动化部署。但在容器环境下进行高可用的进行项目的安装部署就需要使用容器化技术跟k8s的调度执行了。

    一般在正式环境下我们都会有以下几部分构成容器化部署:

    • 容器环境

      • docker

      • Containerd

    • k8s集群

    • k8s管理系统

      • KubeSohere

      • dashboard(k8s自带的管理系统)

    • 镜像仓库

      • Docker hub

      • registry

      • harbor

    • 代码仓库

      • github

      • gitlab

    • 发布平台

      • Jekins

      • Devops

    • 负载

      • F5

      • nginx

      • Ingress

    但是组成这么一整套的资源比较大,不利于个人安装学习。所以本文就介绍在只有k8s集群的环境下部署java项目到容器环境中。

    1. 生成Demo项目

    生成一个java的Demo项目,在本机进行启动测试能访问web页面即可,如下图

    如何部署java项目到k8s中

    目录结构

    如何部署java项目到k8s中

    2. 配置Docker环境

    2.1 编写Dockerfile文件

    在上面的目录结构图里的file文件夹中有一个Dockerfile文件,代码如下

    #基础镜像 java打包需要依赖jdk
    FROM java:8
    #将虚拟机的war包,cp到docker容器内部
    COPY demo-0.0.1-SNAPSHOT.jar demo-0.0.1-SNAPSHOT.jar
    #容器开放的端口
    EXPOSE 8081
    #指定docker容器时区
    RUN ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && echo 'Asia/Beijing' >/etc/timezone
    # 脚本启动
    ENTRYPOINT ["sh","-c","java -server -Dfile.encoding=utf-8 -Xms1024m -Xms1536m -jar -Dserver.port=8081  -Dspring.profiles.active=prod demo-0.0.1-SNAPSHOT.jar"]
    登录后复制

    如果项目设置了分环境注意修改ENTRYPOINT 参数里的-Dspring.profiles.active=prod进行修改

    2.2 打包镜像

    配置好Dockerfile文件就需要打包镜像到容器集群中,由于没有镜像仓库所以我们打包需要在所有的容器节点中进行打包,否则在调度过程中如果调度到没有打包镜像的节点则拉取不到镜像就会如下图无法启动完成。

    如何部署java项目到k8s中

    如何部署java项目到k8s中

    demo项目打好的jar包Dockerfile文件上传到容器集群的所有节点上,然后执行以下命令:

    docker image build -t an/demo_server:v1.0.0 .
    登录后复制

    an/demo_server就是要打包的容器镜像名称,我们下面的配置k8s也是以此名称来找镜像进行调度的。

    使用docker images命令查看是否存在镜像

    如何部署java项目到k8s中

    3. 配置k8s

    3.1 编写deploy.yaml文件

    这个文件是给k8s调度使用的,里面配置了需要调度使用的实例数量版本端口号对外端口号对外协议等等等等,配置如下

    apiVersion: apps/v1
    kind: Deployment
    metadata:
      name: demo-server
    spec:
      replicas: 1
      selector:
        matchLabels:
          app: demo-server
      template:
        metadata:
          labels:
            app: demo-server
        spec:
          containers:
            - name: demo-server
              image: an/demo_server:v1.0.0
              ports:
                - containerPort: 8081
    ---
    apiVersion: v1
    kind: Service
    metadata:
      name: demo-server
    spec:
      selector:
        app: demo-server
      ports:
        - protocol: TCP
          port: 8081
          targetPort: 8081
          nodePort: 31001
      type: NodePort
    登录后复制

    replicas参数代表了调度的容器数量,目前是1个实例
    nodePort代表了对外映射的端口号,实际访问就是这个端口

    最下面的目录有参数详解,可以参考,这里简单解释一下

    3.2 启动调度

    将文件上传到k8s的master节点上执行以下命令进行调度

    kubectl apply -f deploy.yaml
    登录后复制

    4. 验证

    4.1 查看pod

    先执行命令:

    kubectl get all或kubectl get node
    登录后复制

    如下图我们的demo-server已经启动了,但是如何访问成了一个问题

    如何部署java项目到k8s中

    4.2 访问系统

    4.2.1 集群外部访问

    集群外部访问没有做负载的情况下需要先看容器分配到了那个节点上,在可视化系统里查看容器组的分配情况

    如何部署java项目到k8s中

    系统里看到k8s将这个系统调度到了node2节点,使用node2节点ip+端口,我们配的对外映射端口为31001,那访问地址就是:http://外部ip:31001,访问如下图则验证成功

    如何部署java项目到k8s中

    4.2.2 集群内部访问

    如果在集群内部访问有两种方式

    通过CLUSTER-IP:port访问
    使用命令kubectl get all可以查看到service的CLUSTER-IP

    如何部署java项目到k8s中

    通过pod Ip:port访问
    使用命令:kubectl get pods得到podname

    如何部署java项目到k8s中

    再使用命令:kubectl describe pod demo-server-8b47bd6b6-8bh6q查看pod详情里的pod IP

    如何部署java项目到k8s中

    5. k8s配置文件参数详解

    apiVersion: v1 # 【必须】版本号
    kind: Pod # 【必选】Pod
    metadata: # 【必选-Object】元数据
    name: String # 【必选】 Pod的名称
    namespace: String # 【必选】 Pod所属的命名空间
    labels: # 【List】 自定义标签列表
    	- name: String
    annotations: # 【List】 自定义注解列表
    	- name: String
    spec: # 【必选-Object】 Pod中容器的详细定义
    containers: # 【必选-List】 Pod中容器的详细定义
    	- name: String # 【必选】 容器的名称
    	image: String # 【必选】 容器的镜像名称
    	imagePullPolicy: [Always | Never | IfNotPresent] # 【String】 每次都尝试重新拉取镜像 | 仅使用本地镜像 | 如果本地有镜像则使用,没有则拉取
    	command: [String] # 【List】 容器的启动命令列表,如果不指定,则使用镜像打包时使用的启动命令
    	args: [String] # 【List】 容器的启动命令参数列表
    	workingDir: String # 容器的工作目录
    	volumeMounts: # 【List】 挂载到容器内部的存储卷配置
    		- name: String # 引用Pod定义的共享存储卷的名称,需使用volumes[]部分定义的共享存储卷名称
    		mountPath: Sting # 存储卷在容器内mount的绝对路径,应少于512个字符
    		readOnly: Boolean # 是否为只读模式,默认为读写模式
    	ports: # 【List】 容器需要暴露的端口号列表
    		- name: String  # 端口的名称
    		containerPort: Int # 容器需要监听的端口号
    		hostPort: Int # 容器所在主机需要监听的端口号,默认与containerPort相同。设置hostPort时,同一台宿主机将无法启动该容器的第二份副本
    		protocol: String # 端口协议,支持TCP和UDP,默认值为TCP
    	env: # 【List】 容器运行前需设置的环境变量列表
    		- name: String # 环境变量的名称
    		value: String # 环境变量的值
    	resources: # 【Object】 资源限制和资源请求的设置
    		limits: # 【Object】 资源限制的设置
    		cpu: String # CPU限制,单位为core数,将用于docker run --cpu-shares参数
    		memory: String # 内存限制,单位可以为MB,GB等,将用于docker run --memory参数
    		requests: # 【Object】 资源限制的设置
    		cpu: String # cpu请求,单位为core数,容器启动的初始可用数量
    		memory: String # 内存请求,单位可以为MB,GB等,容器启动的初始可用数量
    	livenessProbe: # 【Object】 对Pod内各容器健康检查的设置,当探测无响应几次之后,系统将自动重启该容器。可以设置的方法包括:exec、httpGet和tcpSocket。对一个容器只需要设置一种健康检查的方法
    		exec: # 【Object】 对Pod内各容器健康检查的设置,exec方式
    		command: [String] # exec方式需要指定的命令或者脚本
    		httpGet: # 【Object】 对Pod内各容器健康检查的设置,HTTGet方式。需要指定path、port
    		path: String
    		port: Number
    		host: String
    		scheme: String
    		httpHeaders:
    			- name: String
    			value: String
    		tcpSocket: # 【Object】 对Pod内各容器健康检查的设置,tcpSocket方式
    		port: Number
    		initialDelaySeconds: Number # 容器启动完成后首次探测的时间,单位为s
    		timeoutSeconds: Number  # 对容器健康检查的探测等待响应的超时时间设置,单位为s,默认值为1s。若超过该超时时间设置,则将认为该容器不健康,会重启该容器。
    		periodSeconds: Number # 对容器健康检查的定期探测时间设置,单位为s,默认10s探测一次
    		successThreshold: 0
    		failureThreshold: 0
    	securityContext:
    		privileged: Boolean
    restartPolicy: [Always | Never | OnFailure] # Pod的重启策略 一旦终止运行,都将重启 | 终止后kubelet将报告给master,不会重启 | 只有Pod以非零退出码终止时,kubelet才会重启该容器。如果容器正常终止(退出码为0),则不会重启。
    nodeSelector: object # 设置Node的Label,以key:value格式指定,Pod将被调度到具有这些Label的Node上
    imagePullSecrets: # 【Object】 pull镜像时使用的Secret名称,以name:secretkey格式指定
    	- name: String
    hostNetwork: Boolean # 是否使用主机网络模式,默认值为false。设置为true表示容器使用宿主机网络,不再使用docker网桥,该Pod将无法在同一台宿主机上启动第二个副本
    volumes: # 【List】 在该Pod上定义的共享存储卷列表
    	- name: String # 共享存储卷的名称,volume的类型有很多emptyDir,hostPath,secret,nfs,glusterfs,cephfs,configMap
    	emptyDir: {} # 【Object】 类型为emptyDir的存储卷,表示与Pod同生命周期的一个临时目录,其值为一个空对象:emptyDir: {}
    	hostPath: # 【Object】 类型为hostPath的存储卷,表示挂载Pod所在宿主机的目录
    		path: String # Pod所在主机的目录,将被用于容器中mount的目录
    	secret: # 【Object】类型为secret的存储卷,表示挂载集群预定义的secret对象到容器内部
    		secretName: String
    		items:
    		- key: String
    			path: String
    	configMap: # 【Object】 类型为configMap的存储卷,表示挂载集群预定义的configMap对象到容器内部
    		name: String
    		items:
    		- key: String
    			path: String
    登录后复制

    以上是如何部署java项目到k8s中的详细内容。更多信息请关注PHP中文网其他相关文章!

    本站声明
    本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

    热AI工具

    Undresser.AI Undress

    Undresser.AI Undress

    人工智能驱动的应用程序,用于创建逼真的裸体照片

    AI Clothes Remover

    AI Clothes Remover

    用于从照片中去除衣服的在线人工智能工具。

    Undress AI Tool

    Undress AI Tool

    免费脱衣服图片

    Clothoff.io

    Clothoff.io

    AI脱衣机

    Video Face Swap

    Video Face Swap

    使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

    热工具

    记事本++7.3.1

    记事本++7.3.1

    好用且免费的代码编辑器

    SublimeText3汉化版

    SublimeText3汉化版

    中文版,非常好用

    禅工作室 13.0.1

    禅工作室 13.0.1

    功能强大的PHP集成开发环境

    Dreamweaver CS6

    Dreamweaver CS6

    视觉化网页开发工具

    SublimeText3 Mac版

    SublimeText3 Mac版

    神级代码编辑软件(SublimeText3)

    热门话题

    Java教程
    1659
    14
    CakePHP 教程
    1416
    52
    Laravel 教程
    1310
    25
    PHP教程
    1258
    29
    C# 教程
    1233
    24
    突破或从Java 8流返回? 突破或从Java 8流返回? Feb 07, 2025 pm 12:09 PM

    Java 8引入了Stream API,提供了一种强大且表达力丰富的处理数据集合的方式。然而,使用Stream时,一个常见问题是:如何从forEach操作中中断或返回? 传统循环允许提前中断或返回,但Stream的forEach方法并不直接支持这种方式。本文将解释原因,并探讨在Stream处理系统中实现提前终止的替代方法。 延伸阅读: Java Stream API改进 理解Stream forEach forEach方法是一个终端操作,它对Stream中的每个元素执行一个操作。它的设计意图是处

    PHP:网络开发的关键语言 PHP:网络开发的关键语言 Apr 13, 2025 am 12:08 AM

    PHP是一种广泛应用于服务器端的脚本语言,特别适合web开发。1.PHP可以嵌入HTML,处理HTTP请求和响应,支持多种数据库。2.PHP用于生成动态网页内容,处理表单数据,访问数据库等,具有强大的社区支持和开源资源。3.PHP是解释型语言,执行过程包括词法分析、语法分析、编译和执行。4.PHP可以与MySQL结合用于用户注册系统等高级应用。5.调试PHP时,可使用error_reporting()和var_dump()等函数。6.优化PHP代码可通过缓存机制、优化数据库查询和使用内置函数。7

    PHP与Python:了解差异 PHP与Python:了解差异 Apr 11, 2025 am 12:15 AM

    PHP和Python各有优势,选择应基于项目需求。1.PHP适合web开发,语法简单,执行效率高。2.Python适用于数据科学和机器学习,语法简洁,库丰富。

    PHP与其他语言:比较 PHP与其他语言:比较 Apr 13, 2025 am 12:19 AM

    PHP适合web开发,特别是在快速开发和处理动态内容方面表现出色,但不擅长数据科学和企业级应用。与Python相比,PHP在web开发中更具优势,但在数据科学领域不如Python;与Java相比,PHP在企业级应用中表现较差,但在web开发中更灵活;与JavaScript相比,PHP在后端开发中更简洁,但在前端开发中不如JavaScript。

    PHP与Python:核心功能 PHP与Python:核心功能 Apr 13, 2025 am 12:16 AM

    PHP和Python各有优势,适合不同场景。1.PHP适用于web开发,提供内置web服务器和丰富函数库。2.Python适合数据科学和机器学习,语法简洁且有强大标准库。选择时应根据项目需求决定。

    Java程序查找胶囊的体积 Java程序查找胶囊的体积 Feb 07, 2025 am 11:37 AM

    胶囊是一种三维几何图形,由一个圆柱体和两端各一个半球体组成。胶囊的体积可以通过将圆柱体的体积和两端半球体的体积相加来计算。本教程将讨论如何使用不同的方法在Java中计算给定胶囊的体积。 胶囊体积公式 胶囊体积的公式如下: 胶囊体积 = 圆柱体体积 两个半球体体积 其中, r: 半球体的半径。 h: 圆柱体的高度(不包括半球体)。 例子 1 输入 半径 = 5 单位 高度 = 10 单位 输出 体积 = 1570.8 立方单位 解释 使用公式计算体积: 体积 = π × r2 × h (4

    PHP的影响:网络开发及以后 PHP的影响:网络开发及以后 Apr 18, 2025 am 12:10 AM

    PHPhassignificantlyimpactedwebdevelopmentandextendsbeyondit.1)ItpowersmajorplatformslikeWordPressandexcelsindatabaseinteractions.2)PHP'sadaptabilityallowsittoscaleforlargeapplicationsusingframeworkslikeLaravel.3)Beyondweb,PHPisusedincommand-linescrip

    PHP:许多网站的基础 PHP:许多网站的基础 Apr 13, 2025 am 12:07 AM

    PHP成为许多网站首选技术栈的原因包括其易用性、强大社区支持和广泛应用。1)易于学习和使用,适合初学者。2)拥有庞大的开发者社区,资源丰富。3)广泛应用于WordPress、Drupal等平台。4)与Web服务器紧密集成,简化开发部署。

    See all articles