首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >注入Istio Sidecar后内部gRPC路由超时

注入Istio Sidecar后内部gRPC路由超时
EN

Stack Overflow用户
提问于 2018-08-10 01:15:44
回答 1查看 340关注 0票数 0

我目前正在尝试在GKE上的Kubernetes集群中部署Istio Service Mesh。当我使用kubectl apply -f <(istioctl kube-inject -f <service-name>.yaml注入Istio sidecar时,下游服务不能使用gRPC连接。当Istio sidecar在HTTP服务中运行时,不会出现此问题。

gRPC服务的配置文件如下:

代码语言:javascript
复制
apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  name: <service name>
  namespace: default
  labels:
    app: <service-name>
    version: v1
spec:
  minReadySeconds: 30
  replicas: 1
  template:
    metadata:
      labels:
        app: <service-name>
    spec:
      containers:
      - name: <service-name>
        image: gcr.io/project/service-name
        ports:
        - containerPort: 5011
          name: grpc
        resources:
          requests:
            memory: "10Mi"
            cpu: "100m"
          limits:
            memory: "100Mi"
            cpu: "250m"
        readinessProbe:
          tcpSocket:
            port: 5011
          initialDelaySeconds: 5
          periodSeconds: 10
        livenessProbe:
          tcpSocket:
            port: 5011
          initialDelaySeconds: 15
          periodSeconds: 20
---
apiVersion: v1
kind: Service
metadata:
  name: <service-name>
  namespace: default
spec:
  selector:
    app: <service-name>
  ports:
  - port: 5011
    targetPort: 5011
    name: grpc

Istio正在下游服务中运行,不会向上游服务显示任何传出请求。如果我在不使用Istio的情况下重新部署上游服务,则gRPC调用成功,并且日志显示传出请求。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-08-14 22:25:49

我设法解决了这个问题。问题是上游gRPC服务正在向Datastore发出请求,而Istio没有配置为让到Google Cloud服务的流量脱离网格,因此请求超时。我通过运行以下命令解决了这个问题

代码语言:javascript
复制
helm template install/kubernetes/helm/istio <the flags you used to install Istio> 
--set global.proxy.includeIPRanges="<cluster IP ranges>" 
-x templates/sidecar-injector-configmap.yaml | kubectl apply -f -
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51772665

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档