当前位置:首页 > 科技  > 软件

十分钟教你在 K8s 中部署一个前后端应用

来源: 责编: 时间:2024-01-15 09:21:37 272观看
导读大家好,我是蜗牛哥,好多开发人员,尤其是没接触过 k8s 的人员对如何在k8s中部署一个 前后端应用很模糊,不知如何下手,所以本篇讲一下如何快速在 k8s 部署一个前后端应用,让大家对k8s有个快速认识前置依赖k8s集群,如果没有安装

大家好,我是蜗牛哥,好多开发人员,尤其是没接触过 k8s 的人员对如何在k8s中部署一个 前后端应用很模糊,不知如何下手,所以本篇讲一下如何快速在 k8s 部署一个前后端应用,让大家对k8s有个快速认识HcA28资讯网——每日最新资讯28at.com

前置依赖

  • k8s集群,如果没有安装,请参考k8s安装手册
  • kubectl ,客户端部署需要依赖

应用镜像构建

应用镜像构建不用自己去执行,相关镜像已经推送到docker hub 仓库,如果要了解过程和细节,可以看一下,否则直接跳到k8syaml文件配置章节HcA28资讯网——每日最新资讯28at.com

Java应用镜像构建

代码地址:https://github.com/dongweizhao/backendHcA28资讯网——每日最新资讯28at.com

Java应用打包

调用sh package.sh会执行mvn的package命令,进行打包HcA28资讯网——每日最新资讯28at.com

编写Dockerfile

从target目录复制可执行jarHcA28资讯网——每日最新资讯28at.com

FROM openjdk:8-jreCOPY target/backend-0.0.1-SNAPSHOT.jar /app.jarENTRYPOINT java -jar ${JAVA_OPTS} /app.jar

镜像打包推送

执行sh push.sh 推送至dockerhub仓库,镜像地址:dweizhao/backend:latestHcA28资讯网——每日最新资讯28at.com

前端应用镜像构建

代码地址:https://github.com/dongweizhao/frontendHcA28资讯网——每日最新资讯28at.com

前端项目结构如下HcA28资讯网——每日最新资讯28at.com

采用百度低代码平台amis进行开发采用百度低代码平台amis进行开发HcA28资讯网——每日最新资讯28at.com

编写Dockerfile

拷贝前端工程dist目录至/frontend,并进行目录授权HcA28资讯网——每日最新资讯28at.com

from nginxcopy ./dist /frontendrun chown nginx.nginx /frontend -Rcopy nginx.conf /etc/nginx/conf.d/default.conf

编写nginx.conf文件

server{    listen 80;    server_name localhost;     root  /frontend;     index index.html index.htm;     location /login {             try_files $uri $uri/ /login.html;     }}

推送镜像

执行sh push.sh推送dockerhub仓库,镜像地址:dweizhao/frontend:latestHcA28资讯网——每日最新资讯28at.com

k8s yaml文件配置

以下是我们部署的服务在k8s 中路由示意图HcA28资讯网——每日最新资讯28at.com

图片图片HcA28资讯网——每日最新资讯28at.com

后端服务配置

backend-dp.yaml

由于我们服务是无状态服务,使用Deployment进行部署,Deployment拥有更加灵活强大的升级、回滚功能,并且支持滚动更新HcA28资讯网——每日最新资讯28at.com

apiVersion: apps/v1kind: Deploymentmetadata:  name:  backendspec:  selector:    matchLabels:      app:  backend  replicas: 1  template:    metadata:      labels:        # service 会根据此标签来查找此pod        app:  backend        version: latest    spec:      containers:        - name: backend          image: "dweizhao/backend:latest"          imagePullPolicy: Always

backend-svc.yaml

Service相当于Spring cloud中Ribbon的作用,提供了服务发现和负载均衡的功能,而不用关心具体服务实例有多少个,在 k8s的服务实例就是Pod,这里我们使用ClusterIP类型,因为是通过Ingress在集群内访问,通过 app:backend标签,来查找对应pod,所以 pod 的label必须包含app:backendHcA28资讯网——每日最新资讯28at.com

apiVersion: v1kind: Servicemetadata:  name: backendspec:  type: ClusterIP  ports:    - name: backend-http      port: 8080      targetPort: 8080      protocol: TCP  selector:    # 根据标签查找 pod    app: backend

前端服务配置

frontend-dp.yaml

前端镜像是一个 nginxHcA28资讯网——每日最新资讯28at.com

apiVersion: apps/v1kind: Deploymentmetadata:  name:  frontendspec:  selector:    matchLabels:      app:  frontend  replicas: 1  template:    metadata:      labels:        # service 会根据此标签来查找此pod        app:  frontend        version: latest    spec:      containers:        - name: frontend          image: "dweizhao/frontend:latest"          imagePullPolicy: Always

frontend-svc.yaml

apiVersion: v1kind: Servicemetadata:  name: frontendspec:  type: ClusterIP  ports:    - name: frontend-http      port: 80      targetPort: 80      protocol: TCP  selector:    # 根据标签查找 pod    app: frontend

Ingress配置

Ingress相当于nginx的作用,匹配url转发请求至ServiceHcA28资讯网——每日最新资讯28at.com

注意:k8s不同的版本,对应的Ingress apiVerson有点细微差别,所以要找到对应k8s版本的Ingress,我们的k8s版本为v1.25.13HcA28资讯网——每日最新资讯28at.com

apiVersion: networking.k8s.io/v1kind: Ingressmetadata:  name: test-ingressspec:  ingressClassName: nginx  rules:    - host: k8sdemo.com      http:        paths:        - path: /          pathType: Prefix          backend:            service:              name: frontend              port:                number: 80        #backend开头的 url,转发到后端服务 ,否则都转发到前端服务                      - path: /backend          pathType: Prefix          backend:            service:              name: backend              port:                number: 8080

k8s部署

部署使用kubectl进行部署,如果没有请先安装,安装完成以后,把以上yaml文件保存至本地HcA28资讯网——每日最新资讯28at.com

创建命名空间

kubectl create namespace k8sdemo

部署

部署系统至k8sdemo空间下HcA28资讯网——每日最新资讯28at.com

kubectl create namespace k8sdemo && kubectl apply -f backend-dp.yaml -f backend-svc.yaml -f frontend-dp.yaml -f frontend-svc.yaml -f ingress.yaml -n k8sdemo

图片图片HcA28资讯网——每日最新资讯28at.com

查看系统状态

#查看pod 启动状态kubectl get pods -n k8sdemo# 查看服务状态kubectl get svc -n k8sdemo# 查看Ingress状态kubectl get ingress -n k8sdemo

图片图片HcA28资讯网——每日最新资讯28at.com

图片图片HcA28资讯网——每日最新资讯28at.com

图片图片HcA28资讯网——每日最新资讯28at.com

host 解析

在 hosts 文件中,对k8sdemo.com域名映射,映射到k8s 的任意node节点上即可,假设IP为172.18.2.53,配置如下HcA28资讯网——每日最新资讯28at.com

172.18.2.53 k8sdemo.com

测试

在浏览器访问k8sdemo.com,如果出现以下结果则部署成功,可以看到正确请求到数据,这个数据为backend提供HcA28资讯网——每日最新资讯28at.com

图片图片HcA28资讯网——每日最新资讯28at.com

总结

以上我们只是简单演示了下,如何在 k8s 中快速部署一个前后端应用,让你对在 k8s 操作有一个快速认识,但是此应用如果要在生产使用还要在做些配置,比如探针配置,因为后端服务的启动,可能是个假启动,必须要配置探针探活之后,才能让 service访问,否则导致请求异常,同时应用有些文件如果需要持久化,还需要配置存储卷等操作HcA28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-60974-0.html十分钟教你在 K8s 中部署一个前后端应用

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: Python计算质数的多种方法

下一篇: 为什么各大物联网云厂商都使用MQTT协议?

标签:
  • 热门焦点
  • Raft算法:保障分布式系统共识的稳健之道

    1. 什么是Raft算法?Raft 是英文”Reliable、Replicated、Redundant、And Fault-Tolerant”(“可靠、可复制、可冗余、可容错”)的首字母缩写。Raft算法是一种用于在分布式系统
  • K6:面向开发人员的现代负载测试工具

    K6 是一个开源负载测试工具,可以轻松编写、运行和分析性能测试。它建立在 Go 和 JavaScript 之上,它被设计为功能强大、可扩展且易于使用。k6 可用于测试各种应用程序,包括 Web
  • 一文看懂为苹果Vision Pro开发应用程序

    译者 | 布加迪审校 | 重楼苹果的Vision Pro是一款混合现实(MR)头戴设备。Vision Pro结合了虚拟现实(VR)和增强现实(AR)的沉浸感。其高分辨率显示屏、先进的传感器和强大的处理能力
  • 十个简单但很有用的Python装饰器

    装饰器(Decorators)是Python中一种强大而灵活的功能,用于修改或增强函数或类的行为。装饰器本质上是一个函数,它接受另一个函数或类作为参数,并返回一个新的函数或类。它们通常用
  • 共享单车的故事讲到哪了?

    来源丨海克财经与共享充电宝相差不多,共享单车已很久没有被国内热点新闻关照到了。除了一再涨价和用户直呼用不起了。近日多家媒体再发报道称,成都、天津、郑州等地多个共享单
  • 年轻人的“职场羞耻感”,无处不在

    作者:冯晓亭 陶 淘 李 欣 张 琳 马舒叶来源:燃次元“人在职场,应该选择什么样的着装?”近日,在网络上,一个与着装相关的帖子引发关注,在该帖子里,一位在高级写字楼亚洲金
  • iQOO Neo8 Pro抢先上架:首发天玑9200+ 安卓性能之王

    经过了一段时间的密集爆料,昨日iQOO官方如期对外宣布:将于5月23日推出全新的iQOO Neo8系列新品,官方称这是一款拥有旗舰级性能调校的作品。随着发布时
  • OPPO K11搭载高性能石墨散热系统:旗舰同款 性能凉爽释放

    日前OPPO官方宣布,将于7月25日14:30举办新品发布会,届时全新的OPPO K11将正式与大家见面,将主打旗舰影像,和同档位竞品相比,其最大的卖点就是将配备索尼
  • 中关村论坛11月25日开幕,15位诺奖级大咖将发表演讲

    11月18日,记者从2022中关村论坛新闻发布会上获悉,中关村论坛将于11月25至30日在京举行。本届中关村论坛由科学技术部、国家发展改革委、工业和信息化部、国务
Top