我目前正在尝试创建X个Pod的群集,每个Pod都有自己的持久卷。为此,我创建了一个带有X个副本的StateFulSet
和一个PersistentVolumeClaimTemplate
的这一部分。
问题在于,似乎不可能以与deployment
相同的方式使用LoadBalancer来暴露那些豆荚(因为有状态集中豆荚的唯一性)。
此刻,我试图将其公开,因为一个简单的部署巫婆无法正常工作,而我发现的唯一方法是逐个公开每个吊舱(我没有测试过,但是我在{ {3}}),但可扩展性不强...
我没有在任何云提供商平台上运行kubernetes,请避免使用专有命令行。
答案 0 :(得分:4)
问题在于,似乎不可能以与部署相同的方式使用LoadBalancer来公开那些pods(因为有状态集中pods的唯一性)。
为什么不呢?这是默认状态为Nginx的StatefulSet
$ k -n test get statefulset
NAME DESIRED CURRENT AGE
web 2 2 5d
$ k -n test get pods
web-0 1/1 Running 0 5d
web-1 1/1 Running 0 5d
这是我的服务类型LoadBalancer,在Minikube的情况下,它实际上是NodePort
$ k -n test get svc
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
nginx LoadBalancer 10.110.22.74 <pending> 80:32710/TCP 5d
让我们运行一些带有curl的pod并向ClusterIP发出一些请求:
$ kubectl -n test run -i --tty tools --image=ellerbrock/alpine-bash-curl-ssl -- bash
bash-4.4$ curl 10.110.22.74 &> /dev/null
bash-4.4$ curl 10.110.22.74 &> /dev/null
bash-4.4$ curl 10.110.22.74 &> /dev/null
bash-4.4$ curl 10.110.22.74 &> /dev/null
我们来看看Nginx日志:
$ k -n test logs web-0
172.17.0.7 - - [18/Apr/2019:23:35:04 +0000] "GET / HTTP/1.1" 200 612 "-" "curl/7.61.0"
172.17.0.7 - - [18/Apr/2019:23:35:05 +0000] "GET / HTTP/1.1" 200 612 "-" "curl/7.61.0"
172.17.0.7 - - [18/Apr/2019:23:35:17 +0000] "GET / HTTP/1.1" 200 612 "-" "curl/7.61.0"
$ k -n test logs web-1
172.17.0.7 - - [18/Apr/2019:23:35:15 +0000] "GET / HTTP/1.1" 200 612 "-" "curl/7.61.0"
172.17.0.7-是我的卷曲的豆荚:
NAME READY STATUS RESTARTS AGE IP NODE
tools-654cfc5cdc-8zttt 1/1 Running 1 5d 172.17.0.7 minikube
实际上,在StatefulSet的Pod之间进行负载平衡的情况下,ClusterIP足够了,因为您有一个端点列表
$ k -n test get endpoints
NAME ENDPOINTS AGE
nginx 172.17.0.5:80,172.17.0.6:80 5d
YAML:
apiVersion: apps/v1beta1
kind: StatefulSet
metadata:
name: web
spec:
serviceName: "nginx"
replicas: 2
selector:
matchLabels:
app: nginx
template:
metadata:
labels:
app: nginx
spec:
containers:
- name: nginx
image: k8s.gcr.io/nginx-slim:0.8
ports:
- containerPort: 80
name: web
apiVersion: v1
kind: Service
metadata:
name: nginx
labels:
app: nginx
spec:
type: LoadBalancer
ports:
- port: 80
name: web
selector:
app: nginx