Как развернуть кластер Akka в Кубернетес? - PullRequest
0 голосов
/ 30 сентября 2019

Я написал небольшое приложение, поддерживающее кластеризацию с помощью Akka Cluster. Я хочу развернуть его в Kubernetes с поддержкой масштабирования. Это мой docker-compose.yml файл:

version: '3.5'

networks:
  cluster-network:

services:
  seed:
    networks:
      - cluster-network
    image: akka-cluster-server
    ports:
      - '2552:2552'
      - '8000:8000'
    environment:
      SERVER_IP: 0.0.0.0
      CLUSTER_IP: seed
      CLUSTER_SEED_IP: seed

  node1:
    networks:
      - cluster-network
    image: akka-cluster-server
    ports:
      - '8001:8000'
    environment:
      SERVER_IP: 0.0.0.0
      CLUSTER_IP: node1
      CLUSTER_PORT: 1600
      CLUSTER_SEED_IP: seed
      CLUSTER_SEED_PORT: 2552

  node2:
    networks:
      - cluster-network
    image: akka-cluster-server
    ports:
      - '8002:8000'
    environment:
      SERVER_IP: 0.0.0.0
      CLUSTER_IP: node2
      CLUSTER_PORT: 1600
      CLUSTER_SEED_IP: seed
      CLUSTER_SEED_PORT: 2552

Существует три экземпляра, которые совместно используют сеть между собой. Обратите внимание, что node1 и node2 используют DNS-имя seed для подключения. Я написал простое развертывание и обслуживание.

Развертывание:

apiVersion: apps/v1
kind: Deployment
metadata:
  name: akka-cluster
spec:
  selector:
    matchLabels:
      app: akka-cluster
  replicas: 2
  template:
    metadata:
      labels:
        app: akka-cluster
    spec:
      containers:
      - name: server-seed
        image: akka-cluster-server
        imagePullPolicy: Never
        ports:
        - containerPort: 8000
        - containerPort: 2552
        env:
        - name: SERVER_IP
          value: 0.0.0.0
        - name: CLUSTER_IP
          valueFrom:
            fieldRef:
              fieldPath: status.podIP
        - name: CLUSTER_SEED_IP
          valueFrom:
            fieldRef:
              fieldPath: status.podIP
        - name: CLUSTER_PORT
          value: "1600"
        - name: CLUSTER_SEED_PORT
          value: "2552"

Служба:

apiVersion: v1
kind: Service
metadata:
  name: akka-cluster-service
spec:
  type: LoadBalancer
  selector:
    app: akka-cluster
  ports:
    - protocol: TCP
      port: 8080
      targetPort: 8000

Обратите внимание, что в этом случае контейнеры будут подключаться к себе (CLUSTER_SEED_IP)вместо начального узла, когда вы будете масштабировать реплики.

Как правильно перевести мой docker-compose.yml для развертывания / обслуживания Kubernetes?

1 Ответ

1 голос
/ 30 сентября 2019

Чтобы правильно «перевести» docker-compose, вы должны создать два набора развертывания + сервис: один для семени и другой для узлов.

Если вам нужно перечислить все экземпляры в качестве начальных значений, то, вероятно, лучшим способом было бы реализовать это через набор состояний. Вы можете проверить это например https://github.com/IBM/Akka-cluster-deploy-kubernetes/blob/master/deploy/kubernetes/resources/myapp/myapp-statefulset.json

...