【发布时间】:2019-01-17 06:03:19
【问题描述】:
我目前正在尝试在 GKE 上的 Kubernetes 集群中部署 Istio 服务网格。当我使用 kubectl apply -f <(istioctl kube-inject -f <service-name>.yaml 注入 Istio sidecar 时,下游服务无法使用 gRPC 进行连接。当 Istio sidecar 在 HTTP 服务中运行时,该问题不会出现。
gRPC服务的配置文件如下:
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 调用会成功并且日志会显示一个传出请求。
【问题讨论】:
-
您使用的是哪个版本的 Istio?
-
当前运行版本 1.0.0
标签: kubernetes grpc google-kubernetes-engine istio