操作场景
随着电商网站业务规模的增大,对网站的访问请求并发量开始增加,网站业务人员计划限制服务最大并发数,保证服务运行的健壮性。
操作步骤
为模拟“高并发”请求场景,首先通过提交以下 YAML 部署 client 服务(10 pods),模拟对 user 服务的高并发请求。
apiVersion: v1kind: Namespacemetadata:name: testlabels:istio-injection: enabledspec:finalizers:- kubernetes---apiVersion: apps/v1kind: Deploymentmetadata:name: clientnamespace: testlabels:app: clientspec:replicas: 10selector:matchLabels:app: clienttemplate:metadata:labels:app: clientspec:containers:- name: clientimage: ccr.ccs.tencentyun.com/zhulei/testclient:v1imagePullPolicy: Alwaysenv:- name: POD_NAMEvalueFrom:fieldRef:fieldPath: metadata.name- name: REGIONvalue: "guangzhou-zoneA"ports:- containerPort: 7000protocol: TCP---?apiVersion: v1kind: Servicemetadata:name: clientnamespace: testlabels:app: clientspec:ports:- name: httpport: 7000protocol: TCPselector:app: clienttype: ClusterIP
此时对于访问 user 服务没有最大并发数限制,所有请求均可访问成功。通过 TKE 控制台 client deployment 查看 client pod 日志,所有的请求均返回了用户名 Kevin,证明访问请求成功。
高并发请求如下图所示:
?
?所有请求均可访问成功如下图所示:
?
?通过配置 user 服务的 Destination Rule 限制最大并发数为1:
apiVersion: networking.istio.io/v1alpha3kind: DestinationRulemetadata:name: usernamespace: basespec:host: usertrafficPolicy:connectionPool:http:http1MaxPendingRequests: 1http2MaxRequests: 1maxRequestsPerConnection: 1exportTo:- '*'
此时查看 client pod 日志,部分请求开始出现异常,未返回用户名,请求失败,连接池起到了限制访问服务最大并发数的作用。
部分请求访问失败如下图所示:
?
?删除流量策略相关配置如下图所示:
连接池测试完成后,在 user 服务的详情页面删除连接池相关流量策略配置。
?
?