日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
五分鐘K8S入門到實(shí)戰(zhàn)-應(yīng)用配置

背景

在前面三節(jié)中已經(jīng)講到如何將我們的應(yīng)用部署到 k8s 集群并提供對(duì)外訪問的能力,x現(xiàn)在可以滿足基本的應(yīng)用開發(fā)需求了。

現(xiàn)在我們需要更進(jìn)一步,使用 k8s 提供的一些其他對(duì)象來標(biāo)準(zhǔn)化我的應(yīng)用開發(fā)。首先就是 ConfigMap,從它的名字也可以看出這是用于管理配置的對(duì)象。

ConfigMap

不管我們之前是做 Java、Go 還是 Python 開發(fā)都會(huì)使用到配置文件,而 ConfigMap 的作用可以將我們?cè)緦懺谂渲梦募锏膬?nèi)容轉(zhuǎn)存到 k8s 中,然后和我們的 Container 進(jìn)行綁定。

存儲(chǔ)到環(huán)境變量

綁定的第一種方式就是將配置直接寫入到環(huán)境變量,這里我先定義一個(gè) ConfigMap:

apiVersion: v1  
kind: ConfigMap  
metadata:  
  name: k8s-combat-configmap  
data:  
  PG_URL: "postgres://postgres:postgres@localhost:5432/postgres?sslmode=disable"

重點(diǎn)是 data 部分,存儲(chǔ)的是一個(gè) KV 結(jié)構(gòu)的數(shù)據(jù),這里存儲(chǔ)的是一個(gè)數(shù)據(jù)庫連接。

需要注意,KV 的大小不能超過 1MB

接著可以在容器定義中綁定這個(gè) ConfigMap 的所有 KV 到容器的環(huán)境變量:

# Define all the ConfigMap's data as container environment variables 
envFrom:  
  - configMapRef:  
      name: k8s-combat-configmap

我將 ConfigMap 的定義也放在了同一個(gè) deployment 中,直接 apply:

 k apply -f deployment/deployment.yaml
deployment.apps/k8s-combat created
configmap/k8s-combat-configmap created

此時(shí) ConfigMap 也會(huì)被創(chuàng)建,我們可以使用

 k get configmap
NAME                   DATA   AGE
k8s-combat-configmap   1      3m17s

 k describe configmap k8s-combat-configmap
Data
====
PG_URL:
----
postgres://postgres:postgres@localhost:5432/postgres?sslmode=disable

拿到剛才聲明的配置信息。


同時(shí)我在代碼中也讀取了這個(gè)環(huán)境變量:

http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {  
   name, _ := os.Hostname()  
   url := os.Getenv("PG_URL")   
   fmt.Fprint(w, fmt.Sprintf("%s-%s", name, url))  
})

訪問這個(gè)接口便能拿到這個(gè)環(huán)境變量:

root@k8s-combat-7b987bb496-pqt9s:/# curl http://127.0.0.1:8081
k8s-combat-7b987bb496-pqt9s-postgres://postgres:postgres@localhost:5432/postgres?sslmode=disable

root@k8s-combat-7b987bb496-pqt9s:/# echo $PG_URL
postgres://postgres:postgres@localhost:5432/postgres?sslmode=disable

存儲(chǔ)到文件

有些時(shí)候我們也需要將這些配置存儲(chǔ)到一個(gè)文件中,比如在 Java 中可以使用 spring 讀取,Go 也可以使用 configor 這些第三方庫來讀取,所有配置都在一個(gè)文件中也更方便維護(hù)。

在 ConfigMap 中新增了一個(gè) key:APP 存放了一個(gè) yaml 格式的數(shù)據(jù),然后在容器中使用 volumes 和 volumeMounts 將數(shù)據(jù)掛載到容器中的指定路徑/go/bin/app.yaml

apply 之后我們可以在容器中查看這個(gè)文件是否存在:

root@k8s-combat-7b987bb496-pqt9s:/# cat /go/bin/app.yaml
name: k8s-combat
pulsar:
  url: "pulsar://localhost:6650"
  token: "abc"

配置已經(jīng)成功掛載到了這個(gè)路徑,我們便可以在代碼中讀取這些數(shù)據(jù)。

Secret

可以看到 ConfigMap 中是明文存儲(chǔ)數(shù)據(jù)的;

k describe configmap k8s-combat-configmap

可以直接查看。

對(duì)一些敏感數(shù)據(jù)就不夠用了,這時(shí)我們可以使用 Secret:

apiVersion: v1  
kind: Secret  
metadata:  
  name: k8s-combat-secret  
type: Opaque  
data:  
  PWD: YWJjCg==

---
env:  
  - name: PG_PWD  
    valueFrom:  
      secretKeyRef:  
        name: k8s-combat-secret  
        key: PWD

這里我新增了一個(gè) Secret 用于存儲(chǔ)密碼,并在 container 中也將這個(gè) key 寫入到環(huán)境變量中。

 echo 'abc' | base64
YWJjCg==

Secret 中的數(shù)據(jù)需要使用 base64 進(jìn)行編碼,所以我這里存儲(chǔ)的是 abc.

apply 之后我們?cè)俨榭催@個(gè) Secret 是不能直接查看原始數(shù)據(jù)的。

 k describe secret k8s-combat-secret
Name:         k8s-combat-secret
Type:  Opaque

Data
====
PWD:  4 bytes

Secret 相比 ConfigMap 多了一個(gè) Type 選項(xiàng)。

我們現(xiàn)階段在應(yīng)用中用的最多的就是這里的 Opaque,其他的暫時(shí)還用不上。

總結(jié)

在實(shí)際開發(fā)過程中研發(fā)人員基本上是不會(huì)直接接觸 ConfigMap,一般會(huì)給開發(fā)者在管理臺(tái)提供維護(hù)配置的頁面進(jìn)行 CRUD。

由于 ConfigMap 依賴于 k8s 與我們應(yīng)用的語言無關(guān),所以一些高級(jí)特性,比如實(shí)時(shí)更新就無法實(shí)現(xiàn),每次修改后都得重啟應(yīng)用才能生效。

類似于 Java 中常見的配置中心:Apollo,Nacos 使用上會(huì)有不小的區(qū)別,但這些是應(yīng)用語言強(qiáng)綁定的,如果業(yè)務(wù)對(duì)這些配置中心特性有強(qiáng)烈需求的話也是可以使用的。

但如果團(tuán)隊(duì)本身就是多語言研發(fā),想要降低運(yùn)維復(fù)雜度 ConfigMap 還是不二的選擇。

下一章節(jié)會(huì)更新大家都很感興趣的服務(wù)網(wǎng)格 Istio,感興趣的朋友多多點(diǎn)贊轉(zhuǎn)發(fā)。

本文的所有源碼和資源文件在這里可以訪問:https://github.com/crossoverJie/k8s-combat


當(dāng)前標(biāo)題:五分鐘K8S入門到實(shí)戰(zhàn)-應(yīng)用配置
標(biāo)題網(wǎng)址:http://www.5511xx.com/article/dppjisp.html