一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

一文透析Nginx-ingress 控制器如何實(shí)現(xiàn)的

Linux愛好者 ? 來源:掘金 ? 作者: dakesolo ? 2021-09-01 14:44 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

主機(jī)nginx

一般nginx做主機(jī)反向代理(網(wǎng)關(guān))有以下配置

upstream order{

server 192.168.1.10:5001;

server 192.168.1.11:5001;

}

server {

listen 80;

server_name order.example.com;

access_log /var/log/nginx/order.example.com-access.log;

error_log /var/log/nginx/order.example.com-error.log;

location / {

proxy_pass_header Server;

proxy_set_header Host $http_host;

proxy_set_header X-Real-IP $remote_addr;

proxy_set_header X-Scheme $scheme;

proxy_pass http://order;

}

}

復(fù)制代碼

其中192.168.1.10:5001,192.168.1.10:5001我們把他們稱為Endpoint,就是所謂的具體的服務(wù),比如order訂單服務(wù)。

pod nginx-ingress

nginx-ingress也是一種代理,是一個(gè)pod,外部的數(shù)據(jù)統(tǒng)一經(jīng)過(必經(jīng))這個(gè)pod,然后通過該pod內(nèi)部的nginx方向代理到各各服務(wù)(Endpoint)。nginx-ingress是ingress控制器插件的一種,這些插件有很多,比如istio-ingressgateway。

1、Pod

nginx-ingress pod有兩個(gè)功能,controller和nginx:

controller:和kubernetes api通訊實(shí)時(shí)更新nginx配置(就是ingress yaml資源了)

nginx:正常的反向代理

復(fù)制代碼

與主機(jī)nginx的區(qū)別是,該pod nginx-ingress是運(yùn)行在pod里。主機(jī)在定義反向代理配置文件時(shí),需要監(jiān)聽一個(gè)對外開放的端口,比如上邊的80端口。那么pod中的nginx端口是如何配置的呢?我們在github上找到了nginx-ingress的deployment.yaml

https://raw.githubusercontent.com/kubernetes/ingress-nginx/master/deploy/static/mandatory.yaml

復(fù)制代碼

其中一段

apiVersion: apps/v1

kind: Deployment

metadata:

name: nginx-ingress-controller

namespace: ingress-nginx

labels:

app.kubernetes.io/name: ingress-nginx

app.kubernetes.io/part-of: ingress-nginx

spec:

replicas: 1

selector:

matchLabels:

app.kubernetes.io/name: ingress-nginx

app.kubernetes.io/part-of: ingress-nginx

template:

metadata:

labels:

app.kubernetes.io/name: ingress-nginx

app.kubernetes.io/part-of: ingress-nginx

annotations:

prometheus.io/port: “10254”

prometheus.io/scrape: “true”

spec:

# wait up to five minutes for the drain of connections

terminationGracePeriodSeconds: 300

serviceAccountName: nginx-ingress-serviceaccount

containers

- name: nginx-ingress-controller

image: quay.io/kubernetes-ingress-controller/nginx-ingress-controller:0.26.1

。。。

。。。

。。。

ports:

- name: http

containerPort: 80

- name: https

containerPort: 443

復(fù)制代碼

我們看到

- name: http

containerPort: 80

- name: https

containerPort: 443

復(fù)制代碼

默認(rèn)對外監(jiān)聽了兩個(gè)端口80和443,也就是說,有這兩個(gè)端口對外就可以web服務(wù)了。

2、ingress 資源

ingress 資源通過yaml進(jìn)行管理的,比如以下:

apiVersion: extensions/v1beta1

kind: Ingress

metadata:

name: order

spec:

rules:

- host: order.example.com

http:

paths: /

backend:

serviceName: order

servicePort: 80

復(fù)制代碼

以上我們定義了一個(gè)單一規(guī)則的ingress,該pod(nginx-ingress)接收到外部所有的請求,將被發(fā)送到內(nèi)部order服務(wù)的80端口上。接下來我們看pod(nginx-ingress)如何把ingress資源轉(zhuǎn)化為該pod中的nginx反向代理配置文件

upstream order{

server order:80;

}

server {

listen 80;

server_name order.example.com;

。。。

。。。

location / {

proxy_pass_header Server;

proxy_set_header Host $http_host;

proxy_set_header X-Real-IP $remote_addr;

proxy_set_header X-Scheme $scheme;

proxy_pass http://order; # 對應(yīng)ingress 資源 name: order

}

}

復(fù)制代碼

當(dāng)然ingress如果包含https,那么會轉(zhuǎn)化nginx對應(yīng)的443端口及證書的配置文件內(nèi)容,這里就不寫了。

那么,單一個(gè)規(guī)則的ingress資源代理多個(gè)服務(wù)(比如order服務(wù),product服務(wù))或者多個(gè)ingress資源文件如何轉(zhuǎn)化為nginx配置?猜測,其實(shí)就是轉(zhuǎn)化成了多個(gè)

upstream order{

server order:80;

}

復(fù)制代碼

當(dāng)然,被轉(zhuǎn)化的nginx配置文件要比這些復(fù)雜的多,據(jù)說還是用lua腳本寫的,靈活如openresty。

3、nginx-ingress對外提供服務(wù)

一般來講,pod直接對外提供服務(wù)就只有兩種方式:

create一個(gè)service,該service暴漏nodePort

forward 映射

我們一般采用第一種。nginx-ingress也是一個(gè)pod,所以,為了能使外部通過該pod代理訪問,還需要nginx-ingress對外提供一個(gè)nodePort的service。這個(gè)service這里也不再寫了。

4、nginx-ingress工作流程

我們可以看到,因?yàn)閚ginx-ingress這個(gè)pod做了所有service的代理,在高并發(fā)情況下將承受巨大壓力,我們可以增加多個(gè)pod實(shí)例。

來源:掘金 - dakesolo

編輯:jq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 主機(jī)
    +關(guān)注

    關(guān)注

    0

    文章

    1038

    瀏覽量

    35986
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4900

    瀏覽量

    70743
  • nginx
    +關(guān)注

    關(guān)注

    0

    文章

    171

    瀏覽量

    12602

原文標(biāo)題:Nginx-ingress 控制器到底怎樣實(shí)現(xiàn)的,這篇文章教你看明白了

文章出處:【微信號:LinuxHub,微信公眾號:Linux愛好者】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    詳解Nginx負(fù)載均衡

    Nginx作為負(fù)載均衡器,通過將請求分發(fā)到多個(gè)后端服務(wù),以提高性能、可靠性和擴(kuò)展性。支持多種負(fù)載均衡算法,如輪詢、最小連接數(shù)、IP哈希等,可以根據(jù)需求選擇適合的算法。
    的頭像 發(fā)表于 06-25 14:51 ?192次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b>詳解<b class='flag-5'>Nginx</b>負(fù)載均衡

    多軸運(yùn)動(dòng)控制器JMC-F2-A6中手冊

    電子發(fā)燒友網(wǎng)站提供《多軸運(yùn)動(dòng)控制器JMC-F2-A6中手冊.pdf》資料免費(fèi)下載
    發(fā)表于 06-23 15:14 ?0次下載

    Ingress網(wǎng)關(guān)高并發(fā)請求的解決方案

    當(dāng) Ingress 網(wǎng)關(guān)面臨高并發(fā)請求(如 QPS 超過 10萬+)時(shí),可能導(dǎo)致服務(wù)崩潰、響應(yīng)延遲激增或資源耗盡。
    的頭像 發(fā)表于 05-14 11:52 ?263次閱讀

    Nginx緩存配置詳解

    Nginx個(gè)功能強(qiáng)大的 Web 服務(wù)和反向代理服務(wù),它可以用于實(shí)現(xiàn)靜態(tài)內(nèi)容的緩存,緩存可以分為客戶端緩存和服務(wù)端緩存。
    的頭像 發(fā)表于 05-07 14:03 ?594次閱讀
    <b class='flag-5'>Nginx</b>緩存配置詳解

    工程機(jī)械控制器廠家 控制器國產(chǎn)替代 #國產(chǎn)控制器#控制器廠家#控制器品牌

    控制器
    長沙碩博電子科技股份有限公司
    發(fā)布于 :2025年04月29日 14:15:05

    讀懂IO控制器:靈活高效的工業(yè)信號采集與控制利器

    什么是IO控制器? IO控制器(輸入輸出控制器)是現(xiàn)代工業(yè)自動(dòng)化系統(tǒng)中的關(guān)鍵設(shè)備,它如同工業(yè)現(xiàn)場的"神經(jīng)末梢",負(fù)責(zé)采集各種傳感信號(輸入),并根據(jù)
    的頭像 發(fā)表于 03-31 16:39 ?552次閱讀

    工程機(jī)械控制器如何選型?控制器選型指南 #控制器 #車載控制器 #整車控制器 #控制器選型

    控制器
    長沙碩博電子科技股份有限公司
    發(fā)布于 :2025年03月14日 10:54:24

    nginx+lua+redis實(shí)現(xiàn)灰度發(fā)布

    作者:馬仁喜 前言: 授人以魚不如授人以漁 .先學(xué)會用,在學(xué)原理,在學(xué)創(chuàng)造,可能輩子用不到這種能力,但是不能不具備這種能力。這篇文章主要是沉淀使用nginx+lua+redis實(shí)現(xiàn)灰度,當(dāng)我們具備
    的頭像 發(fā)表于 12-17 10:01 ?439次閱讀

    nginx隱藏版本號與WEB服務(wù)信息

    nginx不僅可以隱藏版本信息,還支持自定義web服務(wù)信息 先看看最終的隱藏結(jié)果吧 具體怎么實(shí)現(xiàn)呢,其實(shí)也很簡單,請往下看 1 官網(wǎng)下載最新穩(wěn)定版 wget http://nginx
    的頭像 發(fā)表于 11-22 10:25 ?614次閱讀
    <b class='flag-5'>nginx</b>隱藏版本號與WEB服務(wù)<b class='flag-5'>器</b>信息

    讀懂單燈控制器工作原理

    讀懂單燈控制器工作原理
    的頭像 發(fā)表于 11-11 13:13 ?1291次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b>讀懂單燈<b class='flag-5'>控制器</b>工作原理

    nginx負(fù)載均衡配置介紹

    目錄 nginx負(fù)載均衡 nginx負(fù)載均衡介紹 反向代理與負(fù)載均衡 nginx負(fù)載均衡配置 Keepalived高可用nginx負(fù)載均衡器 修改Web服務(wù)
    的頭像 發(fā)表于 11-10 13:39 ?763次閱讀
    <b class='flag-5'>nginx</b>負(fù)載均衡配置介紹

    PID控制器的類型和選擇指南

    PID控制器種廣泛應(yīng)用于工業(yè)控制系統(tǒng)中的控制器,它根據(jù)系統(tǒng)的偏差來計(jì)算控制量,以實(shí)現(xiàn)對系統(tǒng)的
    的頭像 發(fā)表于 11-06 10:37 ?1845次閱讀

    國產(chǎn)控制器廠家 整車控制器 以太網(wǎng)控制器 CAN控制器 國產(chǎn)化替代

    控制器
    長沙碩博電子科技股份有限公司
    發(fā)布于 :2024年09月03日 09:15:51

    車載智能控制器 工程機(jī)械控制器 CAN總線控制器 碩博電子 #控制器 #can總線 #國產(chǎn)化替代

    控制器總線
    長沙碩博電子科技股份有限公司
    發(fā)布于 :2024年08月29日 10:43:57