成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

使用 Sidecar CRD 優(yōu)化 Istio 性能

開發(fā) 前端
Sidecar 對象描述了 Sidecar 代理的配置,Sidecar 代理管理與其連接的工作負(fù)載的Inbound 和 Outbound 流量。默認(rèn)情況下,Istio 將為網(wǎng)格中的所有 Sidecar 代理服務(wù),使其具有到達(dá)網(wǎng)格中每個工作負(fù)載所需的必要配置,并在與工作負(fù)載關(guān)聯(lián)的所有端口上接收流量。

我們知道在服務(wù)網(wǎng)格集群中的每個工作負(fù)載實(shí)例上都會透明地注入一個 Istio sidecar 代理,這個代理攔截負(fù)載的出入流量,并根據(jù)配置完成相應(yīng)的流量管理,包括流量、安全、可觀測性等等。為了更加細(xì)粒度的控制代理的行為,從 1.1 版本開始 Istio 便引入了和服務(wù)網(wǎng)格數(shù)據(jù)面 Sidecar 同名的 Sidecar CRD 資源對象,控制負(fù)載上的出入流量以及課訪問的目標(biāo)服務(wù)等。

Sidecar 對象描述了 sidecar 代理的配置,sidecar 代理管理與其連接的工作負(fù)載的 inbound 和 outbound 流量。默認(rèn)情況下,Istio 將為網(wǎng)格中的所有 sidecar 代理服務(wù),使其具有到達(dá)網(wǎng)格中每個工作負(fù)載所需的必要配置,并在與工作負(fù)載關(guān)聯(lián)的所有端口上接收流量。Sidecar 資源提供了一種的方法,在向工作負(fù)載轉(zhuǎn)發(fā)流量或從工作負(fù)載轉(zhuǎn)發(fā)流量時,微調(diào)端口集合和代理將接收的協(xié)議,此外,可以限制代理在從工作負(fù)載轉(zhuǎn)發(fā) outbound 流量時可以達(dá)到的服務(wù)集合。

比如我們可以創(chuàng)建一個如下所示的 Sidecar 對象:

apiVersion: networking.istio.io/v1beta1
kind: Sidecar
metadata:
  name: test-sc
spec:
  egress:
    - hosts:
        - "istio-system/*"
        - "default/*"

在上面的 Sidecar 對象中我們指定了 egress 字段,這個字段用于指定 sidecar 代理的出口流量,其中 hosts 字段用于指定 sidecar 代理可以訪問的目標(biāo)服務(wù),這里我們指定了 istio-system/* 和 default/*,意思是我們可以控制 default 命名空間下的 sidecar 代理只可以訪問 istio-system 和 default 命名空間下的服務(wù),其他命名空間下的服務(wù)則無法訪問。

整體上 Sidecar 對象的核心包括四個字段:workloadSelector、ingress 與 egress、outboundTrafficPolicy。

  • workloadSelector:這個字段用來指定 sidecar 代理所屬的工作負(fù)載,可以通過標(biāo)簽來指定,如果沒有指定則會應(yīng)用到當(dāng)前命名空間下所有的工作負(fù)載上(每個命名空間下只能定義一個全局的 Sidecar 對象),如果定義在根命名空間 istio-system 下則會應(yīng)用到所有命名空間下的工作負(fù)載上。需要注意的是如果一個命名空間下存在多個 workloadSelector 的 Sidecar 選中同樣的負(fù)載,則也會出現(xiàn)問題,所有要注意避免這種情況。
  • egress:這個字段用來配置 sidecar 代理對服務(wù)網(wǎng)格內(nèi)部其他服務(wù)的訪問,如果沒有配置則默認(rèn)命名空間下的所有服務(wù)都可以訪問,如果配置了則只能訪問配置的服務(wù)。該字段下面可以配置如下幾個參數(shù):
  • hosts:這是一個必選的字段,表示監(jiān)聽器對應(yīng)的服務(wù)地址,格式為 <namespace>/<FQDN>,可以對 namespace、FQDN 進(jìn)行通配符匹配,比如 default/* 表示 default 命名空間下的所有服務(wù),*/foo 表示所有命名空間下的 foo 服務(wù),*/* 表示允許目標(biāo)是任意命名空間下的任意服務(wù),~/* 表示禁止目標(biāo)是任意命名空間下的任意服務(wù)。
  • port:監(jiān)聽器關(guān)聯(lián)的端口。
  • bind:監(jiān)聽器綁定的地址。
  • captureMode:配置流量捕獲模式,可以是 DEFAULT、IPTABLES、NONE 三種模式,默認(rèn)是 DEFAULT,DEFAULT 模式表示使用環(huán)境默認(rèn)的流量捕獲規(guī)則;IPTABLES 模式表示基于 iptables 規(guī)則轉(zhuǎn)發(fā)的流量,NONE 模式表示沒有流量攔截。
  • ingress:這個字段用來配置 sidecar 代理對應(yīng)工作負(fù)載的入流量控制。該字段下面可以配置如下幾個參數(shù):
  • port:這是一個必選的字段,表示監(jiān)聽器對應(yīng)的端口。

  • bind:監(jiān)聽器綁定的地址。

  • captureMode:配置流量捕獲模式,與 egress 中的 captureMode 字段一樣。

  • defaultEndpoint:也是必選字段,表示流量的轉(zhuǎn)發(fā)目標(biāo)地址,比如 127.0.0.1:port 或者 0.0.0.0:port。

  • outboundTrafficPolicy:這個字段用來配置 sidecar 代理對應(yīng)工作負(fù)載的出流量控制,該字段有兩種訪問配置:

  • ALLOW_ANY:表示允許訪問任意服務(wù),sidecar 代理在攔截到這個出流量后,會直接透傳。

  • REGISTRY_ONLY:sidecar 代理會攔截所有的出口流量,只允許服務(wù)網(wǎng)格內(nèi)部服務(wù)可以被訪問,對于外部服務(wù)需要使用 ServiceEntry 注冊才可以被訪問。

Sidecar 對象可以定義在根命名空間 istio-system 下,這樣就會應(yīng)用到所有命名空間下的工作負(fù)載上,比如我們可以創(chuàng)建一個如下所示的 Sidecar 對象:

# global-sidecar.yaml
apiVersion: networking.istio.io/v1beta1
kind: Sidecar
metadata:
  name: default
  namespace: istio-system
spec:
  egress:
    - hosts:
        - "./*"

上面的這個 Sidecar 對象定義在 istio-system 命名空間下,這樣就會應(yīng)用到所有命名空間下的工作負(fù)載上,其中 egress 字段中的 hosts 字段指定了可以訪問的服務(wù),這里我們指定了 "./*",表示限制整個服務(wù)網(wǎng)格中的服務(wù)只能訪問本命名空間的服務(wù)。在實(shí)踐中我們推薦使用這種方式在全局范圍定義一個統(tǒng)一的 Sidecar 規(guī)則,然后在特定的命名空間下再定義一個 Sidecar 對象來覆蓋全局的 Sidecar 規(guī)則。

比如我們可以在 default 命名空間下創(chuàng)建一個如下所示的 Sidecar 對象來覆蓋上面全局的這個對象:

# default-sidecar.yaml
apiVersion: networking.istio.io/v1beta1
kind: Sidecar
metadata:
  name: default
  namespace: default
spec:
  egress:
    - hosts:
        - "foo/*"

這個對象就允許 default 命名空間的服務(wù)可以訪問 foo 命名空間的服務(wù)。

同樣我們還可以使用 workloadSelector 字段來指定 sidecar 代理所屬的工作負(fù)載,比如我們可以創(chuàng)建一個如下所示的 Sidecar 對象:

# default-sidecar.yaml
apiVersion: networking.istio.io/v1beta1
kind: Sidecar
metadata:
  name: default
  namespace: default
spec:
  workloadSelector:
    labels:
      app: bar
  egress:
    - hosts:
        - "bar/foo-api"

上面的這個對象只會應(yīng)用到 app: bar 標(biāo)簽的工作負(fù)載上,并覆蓋以上命名空間級別的規(guī)則,使得 default 命名空間下面的 app: bar 標(biāo)簽的工作負(fù)載只能訪問 bar 命名空間下面的 foo-api 服務(wù)。

接下來我們使用 sleep 和 httpbin 應(yīng)用來進(jìn)行測試說明,將這兩個應(yīng)用部署到 default 和 other 兩個命名空間下面:

kubectl create ns other
kubectl label ns other istio-injectinotallow=enabled
kubectl apply -f samples/sleep/sleep.yaml -n default
kubectl apply -f samples/sleep/sleep.yaml -n other
kubectl apply -f samples/httpbin/httpbin.yaml -n default
kubectl apply -f samples/httpbin/httpbin.yaml -n other

默認(rèn)情況下,注入了 Istio 的工作負(fù)載會進(jìn)行全網(wǎng)格的傳播,假設(shè) default 和 other 兩個不相干的命名空間,other 中有大量的服務(wù),而 default 中只有幾個,因?yàn)槁酚蓚鞑サ年P(guān)系,default 命名空間中的工作負(fù)載,其 sidecar 代理中也會帶上 other 命名空間中的路由信息。例如:

$ istioctl proxy-config clusters sleep-9454cc476-jfw97 |grep other
httpbin.other.svc.cluster.local                                        8000      -               outbound      EDS
sleep.other.svc.cluster.local                                          80        -               outbound      EDS

可以看到,在 default 命名空間中的 Pod,保存了其它命名空間中的路由信息。這不管是對內(nèi)存消耗還是路由控制來說,都會造成一定浪費(fèi),這個時候我們就可以定義一個 Sidecar 資源,限制 sleep 服務(wù)只訪問同一命名空間的其他服務(wù),如下所示:

# sleep-sidecar.yaml
apiVersion: networking.istio.io/v1alpha3
kind: Sidecar
metadata:
  name: sleep
spec:
  workloadSelector:
    labels:
      app: sleep
  egress:
    - hosts:
        - "default/*"

直接應(yīng)用上面的資源對象即可:

$ kubectl apply -f sleep-sidecar.yaml
$ kubectl get sidecar
NAME    AGE
sleep   16s

這個時候可以看到在 sleep 應(yīng)用中只剩下了本命名空間之內(nèi)的服務(wù)了:

$ istioctl proxy-config clusters sleep-9454cc476-jfw97
SERVICE FQDN                              PORT     SUBSET          DIRECTION     TYPE             DESTINATION RULE
                                          80       -               inbound       ORIGINAL_DST
BlackHoleCluster                          -        -               -             STATIC
InboundPassthroughClusterIpv4             -        -               -             ORIGINAL_DST
PassthroughCluster                        -        -               -             ORIGINAL_DST
agent                                     -        -               -             STATIC
httpbin.default.svc.cluster.local         8000     -               outbound      EDS
kubernetes.default.svc.cluster.local      443      -               outbound      EDS
prometheus_stats                          -        -               -             STATIC
sds-grpc                                  -        -               -             STATIC
sleep.default.svc.cluster.local           80       -               outbound      EDS
xds-grpc                                  -        -               -             STATIC
zipkin                                    -        -               -             STRICT_DNS

現(xiàn)在我們可以在 sleep 應(yīng)用中去訪問下 httpbin 的應(yīng)用:

$ kubectl exec -it sleep-9454cc476-jfw97 -- curl http://httpbin.default:8000/ip
{
  "origin": "127.0.0.6"
}

可以看到 default 命名空間下面的應(yīng)用可以正常訪問,那么對于 other 命名空間下面的服務(wù)正常就不能訪問了。

$ kubectl exec -it sleep-9454cc476-jfw97 -- curl http://httpbin.other.svc.cluster.local:8000/ip

可以看到 default 命名空間下面的應(yīng)用無法訪問 other 命名空間下面的服務(wù)了。

Istio 默認(rèn)情況下,服務(wù)網(wǎng)格內(nèi)部的所有數(shù)據(jù)面代理都通過 xDS 從控制面獲取全量的配置,這種方式在數(shù)據(jù)面代理數(shù)量較少的情況下是沒有問題的,但是當(dāng)數(shù)據(jù)面代理數(shù)量較多的大規(guī)模服務(wù)網(wǎng)格的場景下,這種方式顯然會造成性能問題,全量的配置會引起數(shù)據(jù)面代理的內(nèi)存暴漲,所以 Sidecar 對象是非常有必要的,通過 Sidecar 對象只維護(hù)少量依賴服務(wù)的配置,可以大大減少無用的內(nèi)存消耗,所以在生產(chǎn)環(huán)境中我們推薦大家使用 Sidecar 對象來控制數(shù)據(jù)面代理的配置。

責(zé)任編輯:姜華 來源: k8s技術(shù)圈
相關(guān)推薦

2025-03-27 05:25:00

2017-12-14 14:32:30

.Net內(nèi)存代碼

2011-05-11 17:26:17

Minify

2022-09-15 10:44:42

SidecarIstioeBPFizer

2022-06-06 22:36:55

渲染性能CSS

2017-01-19 15:27:24

Android性能優(yōu)化Lint

2016-08-12 10:23:28

javascriptChrome前端

2023-10-07 08:59:02

2023-11-20 07:19:33

2025-06-03 00:00:06

性能優(yōu)化性能指標(biāo)響應(yīng)時間

2014-12-10 10:12:02

Web

2022-07-13 13:34:30

微服務(wù)邊車SideCar

2017-08-14 09:05:50

SIOC存儲負(fù)載

2009-04-16 17:44:46

性能優(yōu)化擴(kuò)展高性能

2019-03-22 09:50:52

WebJavaScript前端

2024-11-21 08:00:00

向量搜索人工智能

2024-01-01 21:57:41

kubernetesCRDOperator

2013-06-09 15:31:35

jQueryjQuery優(yōu)化性能優(yōu)化

2017-08-08 09:45:43

Python性能優(yōu)化

2009-06-16 16:10:59

Hibernate性能
點(diǎn)贊
收藏

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

主站蜘蛛池模板: 国产一区二区三区视频 | 亚洲国产精品成人久久久 | 国产日韩欧美在线观看 | 红色av社区| 性欧美xxxx | 国产精品污www一区二区三区 | 国产视频久久 | 久久久综合精品 | 欧美精品一区二区三区在线播放 | 涩爱av一区二区三区 | 国产视频久久 | 欧美国产精品 | 久久久久国产一区二区三区四区 | 久久99精品久久久久久青青日本 | 国产真实乱全部视频 | 成人性生交大片免费看中文带字幕 | av网站免费 | 久久久高清 | 精品国产乱码久久久久久丨区2区 | 久久久久久国产精品mv | 91精品在线看 | 久草在线在线精品观看 | 午夜影院在线观看版 | www.婷婷| 青春草91| 久久中文高清 | 国产成人免费视频 | 欧美一级电影免费观看 | 国产精品中文 | 国产在线视频99 | 欧美视频一区二区三区 | 视频在线观看一区二区 | 欧美日韩久久精品 | 成人三级视频 | 精品亚洲一区二区三区 | 免费观看a级毛片在线播放 黄网站免费入口 | 日本一区视频在线观看 | 色毛片| 视频在线一区 | 欧美a级成人淫片免费看 | 国产日产精品一区二区三区四区 |