【发布时间】:2019-03-27 17:37:17
【问题描述】:
我正在 kubernetes (Azure AKS) 中设置多节点 cassandra 集群,因为这是一个无头服务,具有全状态集 pod,没有外部 IP。 如何将我的 spark 应用程序与 kubernetes 集群中的 cassandra 连接
我们已经尝试使用集群 ip,入口 ip 也但是只有单个 pod 起床休息失败。
我有 3 个清单:
- 服务
- PersistentVolumeClaim
- 有状态集
apiVersion: v1
kind: Service
metadata:
labels:
app: cassandra
name: cassandra
spec:
clusterIP: None
ports:
- port: 9042
selector:
app: cassandra
kind: PersistentVolumeClaim
apiVersion: v1
metadata:
name: myvolume-disk-claim
spec:
storageClassName: default
accessModes:
- ReadWriteOnce
resources:
requests:
storage: 10Gi
apiVersion: "apps/v1"
kind: StatefulSet
metadata:
name: cassandra
labels:
app: cassandra
spec:
serviceName: cassandra
replicas: 3
selector:
matchLabels:
app: cassandra
template:
metadata:
labels:
app: cassandra
spec:
containers:
- name: cassandra
image: gcr.io/google-samples/cassandra:v13
imagePullPolicy: Always
ports:
- containerPort: 7000
name: intra-node
- containerPort: 7001
name: tls-intra-node
- containerPort: 7199
name: jmx
- containerPort: 9042
name: cql
env:
- name: CASSANDRA_SEEDS
value: cassandra-0.cassandra.default.svc.cluster.local
- name: MAX_HEAP_SIZE
value: 256M
- name: HEAP_NEWSIZE
value: 100M
- name: CASSANDRA_CLUSTER_NAME
value: "Cassandra"
- name: CASSANDRA_DC
value: "DC1"
- name: CASSANDRA_RACK
value: "Rack1"
- name: CASSANDRA_ENDPOINT_SNITCH
value: GossipingPropertyFileSnitch
- name: POD_IP
valueFrom:
fieldRef:
fieldPath: status.podIP
readinessProbe:
exec:
command:
- /bin/bash
- -c
- /ready-probe.sh
initialDelaySeconds: 15
timeoutSeconds: 5
volumeMounts:
- mountPath: /var/lib/cassandra/data
name: myvolume-disk-claim
volumeClaimTemplates:
- metadata:
name: myvolume-disk-claim
spec:
storageClassName: default
accessModes:
- ReadWriteOnce
resources:
requests:
storage: 10Gi
预期结果:(公共IP作为外部IP)
dspg@Digiteds28:$ kubectl get svc
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
kubernetes ClusterIP 10.0.0.1 <none> 443/TCP 1h
cassandra ClusterIP None 154.167.90.98 9042/TCP 1h
dspg@Digiteds28:$ kubectl get pod
NAME READY STATUS RESTARTS AGE
cassandra-0 1/1 Running 0 59m
cassandra-1 1/1 Running 0 58m
cassandra-2 1/1 Running 0 56m
实际输出:
dspg@Digiteds28:$ kubectl get svc
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
kubernetes ClusterIP 10.0.0.1 <none> 443/TCP 1h
cassandra ClusterIP None <none> 9042/TCP 1h
dspg@Digiteds28:$ kubectl get pod
NAME READY STATUS RESTARTS AGE
cassandra-0 1/1 Running 0 59m
cassandra-1 1/1 Running 0 58m
cassandra-2 1/1 Running 0 56m
现在这不包括连接到应用程序的外部 IP。
【问题讨论】:
-
您好,如果您已经有一个公共 IP,那么您可以使用外部 IP 服务字段kubernetes.io/docs/concepts/services-networking/service/…
标签: apache-spark cassandra kubernetes