自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

十分鐘教你在 K8s 中部署一個(gè)前后端應(yīng)用

開(kāi)發(fā) 后端
讓你對(duì)在 K8s 操作有一個(gè)快速認(rèn)識(shí),但是此應(yīng)用如果要在生產(chǎn)使用還要在做些配置,比如探針配置,因?yàn)楹蠖朔?wù)的啟動(dòng),可能是個(gè)假啟動(dòng),必須要配置探針探活之后,才能讓 service 訪問(wèn),否則導(dǎo)致請(qǐng)求異常,同時(shí)應(yīng)用有些文件如果需要持久化,還需要配置存儲(chǔ)卷等操作。

大家好,我是蝸牛哥,好多開(kāi)發(fā)人員,尤其是沒(méi)接觸過(guò) k8s 的人員對(duì)如何在k8s中部署一個(gè) 前后端應(yīng)用很模糊,不知如何下手,所以本篇講一下如何快速在 k8s 部署一個(gè)前后端應(yīng)用,讓大家對(duì)k8s有個(gè)快速認(rèn)識(shí)

前置依賴

  • k8s集群,如果沒(méi)有安裝,請(qǐng)參考k8s安裝手冊(cè)
  • kubectl ,客戶端部署需要依賴

應(yīng)用鏡像構(gòu)建

應(yīng)用鏡像構(gòu)建不用自己去執(zhí)行,相關(guān)鏡像已經(jīng)推送到docker hub 倉(cāng)庫(kù),如果要了解過(guò)程和細(xì)節(jié),可以看一下,否則直接跳到k8syaml文件配置章節(jié)

Java應(yīng)用鏡像構(gòu)建

代碼地址:https://github.com/dongweizhao/backend

Java應(yīng)用打包

調(diào)用sh package.sh會(huì)執(zhí)行mvn的package命令,進(jìn)行打包

編寫Dockerfile

從target目錄復(fù)制可執(zhí)行jar

FROM openjdk:8-jre
COPY target/backend-0.0.1-SNAPSHOT.jar /app.jar
ENTRYPOINT java -jar ${JAVA_OPTS} /app.jar

鏡像打包推送

執(zhí)行sh push.sh 推送至dockerhub倉(cāng)庫(kù),鏡像地址:dweizhao/backend:latest

前端應(yīng)用鏡像構(gòu)建

代碼地址:https://github.com/dongweizhao/frontend

前端項(xiàng)目結(jié)構(gòu)如下

采用百度低代碼平臺(tái)amis進(jìn)行開(kāi)發(fā)采用百度低代碼平臺(tái)amis進(jìn)行開(kāi)發(fā)

編寫Dockerfile

拷貝前端工程dist目錄至/frontend,并進(jìn)行目錄授權(quán)

from nginx
copy ./dist /frontend
run chown nginx.nginx /frontend -R
copy 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;
     }
}

推送鏡像

執(zhí)行sh push.sh推送dockerhub倉(cāng)庫(kù),鏡像地址:dweizhao/frontend:latest

k8s yaml文件配置

以下是我們部署的服務(wù)在k8s 中路由示意圖

圖片圖片

后端服務(wù)配置

backend-dp.yaml

由于我們服務(wù)是無(wú)狀態(tài)服務(wù),使用Deployment進(jìn)行部署,Deployment擁有更加靈活強(qiáng)大的升級(jí)、回滾功能,并且支持滾動(dòng)更新

apiVersion: apps/v1
kind: Deployment
metadata:
  name:  backend
spec:
  selector:
    matchLabels:
      app:  backend
  replicas: 1
  template:
    metadata:
      labels:
        # service 會(huì)根據(jù)此標(biāo)簽來(lái)查找此pod
        app:  backend
        version: latest
    spec:
      containers:
        - name: backend
          image: "dweizhao/backend:latest"
          imagePullPolicy: Always

backend-svc.yaml

Service相當(dāng)于Spring cloud中Ribbon的作用,提供了服務(wù)發(fā)現(xiàn)和負(fù)載均衡的功能,而不用關(guān)心具體服務(wù)實(shí)例有多少個(gè),在 k8s的服務(wù)實(shí)例就是Pod,這里我們使用ClusterIP類型,因?yàn)槭峭ㄟ^(guò)Ingress在集群內(nèi)訪問(wèn),通過(guò) app:backend標(biāo)簽,來(lái)查找對(duì)應(yīng)pod,所以 pod 的label必須包含app:backend

apiVersion: v1
kind: Service
metadata:
  name: backend
spec:
  type: ClusterIP
  ports:
    - name: backend-http
      port: 8080
      targetPort: 8080
      protocol: TCP
  selector:
    # 根據(jù)標(biāo)簽查找 pod
    app: backend

前端服務(wù)配置

frontend-dp.yaml

前端鏡像是一個(gè) nginx

apiVersion: apps/v1
kind: Deployment
metadata:
  name:  frontend
spec:
  selector:
    matchLabels:
      app:  frontend
  replicas: 1
  template:
    metadata:
      labels:
        # service 會(huì)根據(jù)此標(biāo)簽來(lái)查找此pod
        app:  frontend
        version: latest
    spec:
      containers:
        - name: frontend
          image: "dweizhao/frontend:latest"
          imagePullPolicy: Always

frontend-svc.yaml

apiVersion: v1
kind: Service
metadata:
  name: frontend
spec:
  type: ClusterIP
  ports:
    - name: frontend-http
      port: 80
      targetPort: 80
      protocol: TCP
  selector:
    # 根據(jù)標(biāo)簽查找 pod
    app: frontend

Ingress配置

Ingress相當(dāng)于nginx的作用,匹配url轉(zhuǎn)發(fā)請(qǐng)求至Service

注意:k8s不同的版本,對(duì)應(yīng)的Ingress apiVerson有點(diǎn)細(xì)微差別,所以要找到對(duì)應(yīng)k8s版本的Ingress,我們的k8s版本為v1.25.13

apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
  name: test-ingress
spec:
  ingressClassName: nginx
  rules:
    - host: k8sdemo.com
      http:
        paths:
        - path: /
          pathType: Prefix
          backend:
            service:
              name: frontend
              port:
                number: 80
        #backend開(kāi)頭的 url,轉(zhuǎn)發(fā)到后端服務(wù) ,否則都轉(zhuǎn)發(fā)到前端服務(wù)              
        - path: /backend
          pathType: Prefix
          backend:
            service:
              name: backend
              port:
                number: 8080

k8s部署

部署使用kubectl進(jìn)行部署,如果沒(méi)有請(qǐng)先安裝,安裝完成以后,把以上yaml文件保存至本地

創(chuàng)建命名空間

kubectl create namespace k8sdemo

部署

部署系統(tǒng)至k8sdemo空間下

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

圖片圖片

查看系統(tǒng)狀態(tài)

#查看pod 啟動(dòng)狀態(tài)
kubectl get pods -n k8sdemo
# 查看服務(wù)狀態(tài)
kubectl get svc -n k8sdemo
# 查看Ingress狀態(tài)
kubectl get ingress -n k8sdemo

圖片圖片

圖片圖片

圖片圖片

host 解析

在 hosts 文件中,對(duì)k8sdemo.com域名映射,映射到k8s 的任意node節(jié)點(diǎn)上即可,假設(shè)IP為172.18.2.53,配置如下

172.18.2.53 k8sdemo.com

測(cè)試

在瀏覽器訪問(wèn)k8sdemo.com,如果出現(xiàn)以下結(jié)果則部署成功,可以看到正確請(qǐng)求到數(shù)據(jù),這個(gè)數(shù)據(jù)為backend提供

圖片圖片

總結(jié)

以上我們只是簡(jiǎn)單演示了下,如何在 k8s 中快速部署一個(gè)前后端應(yīng)用,讓你對(duì)在 k8s 操作有一個(gè)快速認(rèn)識(shí),但是此應(yīng)用如果要在生產(chǎn)使用還要在做些配置,比如探針配置,因?yàn)楹蠖朔?wù)的啟動(dòng),可能是個(gè)假啟動(dòng),必須要配置探針探活之后,才能讓 service訪問(wèn),否則導(dǎo)致請(qǐng)求異常,同時(shí)應(yīng)用有些文件如果需要持久化,還需要配置存儲(chǔ)卷等操作

責(zé)任編輯:武曉燕 來(lái)源: 架構(gòu)成長(zhǎng)指南
相關(guān)推薦

2024-01-29 13:03:02

2022-10-12 23:02:49

Calcite異構(gòu)數(shù)據(jù)框架

2023-09-24 22:47:42

Kubernetes親和性

2023-09-27 22:33:40

KubernetesK8S

2009-10-09 14:45:29

VB程序

2025-02-10 12:05:15

2020-12-17 06:48:21

SQLkafkaMySQL

2019-04-01 14:59:56

負(fù)載均衡服務(wù)器網(wǎng)絡(luò)

2023-12-25 08:05:35

2023-12-28 08:01:17

SpringAPI數(shù)據(jù)

2021-03-03 11:36:57

Java 8Java 15Java

2021-09-07 09:40:20

Spark大數(shù)據(jù)引擎

2022-06-16 07:31:41

Web組件封裝HTML 標(biāo)簽

2024-06-19 09:58:29

2023-04-12 11:18:51

甘特圖前端

2024-01-29 00:20:00

GolangGo代碼

2015-12-11 14:35:40

內(nèi)存監(jiān)控運(yùn)維

2015-09-06 09:22:24

框架搭建快速高效app

2012-07-10 01:22:32

PythonPython教程

2024-05-13 09:28:43

Flink SQL大數(shù)據(jù)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)