K8S Nginx Ingress 介紹

一、Ingress 介紹

Kubernetes 暴露服務(wù)的方式目前只有三種:LoadBlancer Service返劲、NodePort Service位喂、Ingress挠阁;前兩種估計都應(yīng)該很熟悉,具體的可以參考下?這篇文章硫朦;下面詳細(xì)的嘮一下這個 Ingress

1.1贷腕、Ingress 是個什么玩意

可能從大致印象上 Ingress 就是能利用 Nginx、Haproxy 啥的負(fù)載均衡器暴露集群內(nèi)服務(wù)的工具咬展;那么問題來了泽裳,集群內(nèi)服務(wù)想要暴露出去面臨著幾個問題:

1.2、Pod 漂移問題

眾所周知 Kubernetes 具有強大的副本控制能力破婆,能保證在任意副本(Pod)掛掉時自動從其他機器啟動一個新的涮总,還可以動態(tài)擴容等,總之一句話祷舀,這個 Pod 可能在任何時刻出現(xiàn)在任何節(jié)點上瀑梗,也可能在任何時刻死在任何節(jié)點上烹笔;那么自然隨著 Pod 的創(chuàng)建和銷毀,Pod IP 肯定會動態(tài)變化抛丽;那么如何把這個動態(tài)的 Pod IP 暴露出去谤职?這里借助于 Kubernetes 的 Service 機制,Service 可以以標(biāo)簽的形式選定一組帶有指定標(biāo)簽的 Pod亿鲜,并監(jiān)控和自動負(fù)載他們的 Pod IP允蜈,那么我們向外暴露只暴露 Service IP 就行了;這就是 NodePort 模式:即在每個節(jié)點上開起一個端口蒿柳,然后轉(zhuǎn)發(fā)到內(nèi)部 Pod IP 上饶套,如下圖所示


1.3、端口管理問題

采用 NodePort 方式暴露服務(wù)面臨一個坑爹的問題是垒探,服務(wù)一旦多起來凤跑,NodePort 在每個節(jié)點上開啟的端口會及其龐大,而且難以維護叛复;這時候引出的思考問題是?“能不能使用 Nginx 啥的只監(jiān)聽一個端口,比如 80扔仓,然后按照域名向后轉(zhuǎn)發(fā)褐奥?”?這思路很好,簡單的實現(xiàn)就是使用 DaemonSet 在每個 node 上監(jiān)聽 80翘簇,然后寫好規(guī)則撬码,因為 Nginx 外面綁定了宿主機 80 端口(就像 NodePort),本身又在集群內(nèi)版保,那么向后直接轉(zhuǎn)發(fā)到相應(yīng) Service IP 就行了呜笑,如下圖所示


1.4、域名分配及動態(tài)更新問題

從上面的思路彻犁,采用 Nginx 似乎已經(jīng)解決了問題叫胁,但是其實這里面有一個很大缺陷:每次有新服務(wù)加入怎么改 Nginx 配置?總不能手動改或者來個 Rolling Update 前端 Nginx Pod 吧汞幢?這時候 “偉大而又正直勇敢的” Ingress 登場驼鹅,如果不算上面的 Nginx,Ingress 只有兩大組件:Ingress Controller 和 Ingress

????????Ingress 這個玩意森篷,簡單的理解就是?你原來要改 Nginx 配置输钩,然后配置各種域名對應(yīng)哪個 Service,現(xiàn)在把這個動作抽象出來仲智,變成一個 Ingress 對象买乃,你可以用 yml 創(chuàng)建,每次不要去改 Nginx 了钓辆,直接改 yml 然后創(chuàng)建/更新就行了剪验;那么問題來了:”Nginx 咋整肴焊?”

????????Ingress Controller 這東西就是解決 “Nginx 咋整” 的;Ingress Controoler 通過與 Kubernetes API 交互碉咆,動態(tài)的去感知集群中 Ingress 規(guī)則變化抖韩,然后讀取他,按照他自己模板生成一段 Nginx 配置疫铜,再寫到 Nginx Pod 里茂浮,最后 reload 一下,工作流程如下圖


當(dāng)然在實際應(yīng)用中壳咕,最新版本 Kubernetes 已經(jīng)將 Nginx 與 Ingress Controller 合并為一個組件席揽,所以 Nginx 無需單獨部署,只需要部署 Ingress Controller 即可

二谓厘、懟一個 Nginx Ingress

上面啰嗦了那么多幌羞,只是為了講明白 Ingress 的各種理論概念,下面實際部署很簡單

2.1竟稳、部署默認(rèn)后端

我們知道?前端的 Nginx 最終要負(fù)載到后端 service 上属桦,那么如果訪問不存在的域名咋整?官方給出的建議是部署一個?默認(rèn)后端他爸,對于未知請求全部負(fù)載到這個默認(rèn)后端上聂宾;這個后端啥也不干,就是返回 404诊笤,部署如下

~ kubectl create-f default-backend.yamldeployment

default-http-backend"createdservice

default-http-backend"created

這個?default-backend.yaml?文件可以在?官方 Ingress 倉庫?找到系谐,由于篇幅限制這里不貼了,倉庫位置如下


2.2讨跟、部署 Ingress Controller

部署完了后端就得把最重要的組件 Nginx+Ingres Controller(官方統(tǒng)一稱為 Ingress Controller) 部署上

~ kubectl create -f nginx-ingress-controller.yaml

daemonset "nginx-ingress-lb" created

注意:官方的 Ingress Controller 有個坑纪他,至少我看了 DaemonSet 方式部署的有這個問題:沒有綁定到宿主機 80 端口,也就是說前端 Nginx 沒有監(jiān)聽宿主機 80 端口(這還玩?zhèn)€卵啊)晾匠;所以需要把配置搞下來自己加一下?hostNetwork茶袒,截圖如下


同樣配置文件自己找一下,地址?點這里凉馆,倉庫截圖如下


當(dāng)然它支持以 deamonset 的方式部署弹谁,這里用的就是(個人喜歡而已),所以你發(fā)現(xiàn)我上面截圖是 deployment句喜,但是鏈接給的卻是 daemonset预愤,因為我截圖截錯了…..

2.3、部署 Ingress

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末咳胃,一起剝皮案震驚了整個濱河市植康,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌展懈,老刑警劉巖销睁,帶你破解...
    沈念sama閱讀 216,496評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件供璧,死亡現(xiàn)場離奇詭異,居然都是意外死亡冻记,警方通過查閱死者的電腦和手機睡毒,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,407評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來冗栗,“玉大人演顾,你說我怎么就攤上這事∮缇樱” “怎么了钠至?”我有些...
    開封第一講書人閱讀 162,632評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長胎源。 經(jīng)常有香客問我棉钧,道長,這世上最難降的妖魔是什么涕蚤? 我笑而不...
    開封第一講書人閱讀 58,180評論 1 292
  • 正文 為了忘掉前任宪卿,我火速辦了婚禮,結(jié)果婚禮上万栅,老公的妹妹穿的比我還像新娘愧捕。我一直安慰自己,他們只是感情好申钩,可當(dāng)我...
    茶點故事閱讀 67,198評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著瘪阁,像睡著了一般撒遣。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上管跺,一...
    開封第一講書人閱讀 51,165評論 1 299
  • 那天义黎,我揣著相機與錄音,去河邊找鬼豁跑。 笑死廉涕,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的艇拍。 我是一名探鬼主播狐蜕,決...
    沈念sama閱讀 40,052評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼卸夕!你這毒婦竟也來了层释?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,910評論 0 274
  • 序言:老撾萬榮一對情侶失蹤快集,失蹤者是張志新(化名)和其女友劉穎贡羔,沒想到半個月后廉白,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,324評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡乖寒,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,542評論 2 332
  • 正文 我和宋清朗相戀三年猴蹂,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片楣嘁。...
    茶點故事閱讀 39,711評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡磅轻,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出马澈,到底是詐尸還是另有隱情瓢省,我是刑警寧澤,帶...
    沈念sama閱讀 35,424評論 5 343
  • 正文 年R本政府宣布痊班,位于F島的核電站勤婚,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏涤伐。R本人自食惡果不足惜馒胆,卻給世界環(huán)境...
    茶點故事閱讀 41,017評論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望凝果。 院中可真熱鬧祝迂,春花似錦、人聲如沸器净。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,668評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽山害。三九已至纠俭,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間浪慌,已是汗流浹背冤荆。 一陣腳步聲響...
    開封第一講書人閱讀 32,823評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留权纤,地道東北人钓简。 一個月前我還...
    沈念sama閱讀 47,722評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像汹想,于是被迫代替她去往敵國和親外邓。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,611評論 2 353