flink 提交到k8s中

Last updated on January 17, 2025 am

🧙 Questions

☄️ Ideas

容器中的yml
apiVersion: v1
kind: Pod
metadata:
  creationTimestamp: "2023-08-04T08:24:47Z"
  generateName: my-first-application-cluster-69c95dc944-
  labels:
    app: my-first-application-cluster
    component: jobmanager
    pod-template-hash: 69c95dc944
    type: flink-native-kubernetes
  name: my-first-application-cluster-69c95dc944-zqtrd
  namespace: default
  ownerReferences:
    - apiVersion: apps/v1
      blockOwnerDeletion: true
      controller: true
      kind: ReplicaSet
      name: my-first-application-cluster-69c95dc944
      uid: 372ed005-e0ac-4150-8da6-f6fe7054c9a8
  resourceVersion: "1227957"
  uid: 51fb989f-3dc6-42df-983e-fe8ec35e7f2f
spec:
  containers:
    - args:
        - native-k8s
        - $JAVA_HOME/bin/java -classpath $FLINK_CLASSPATH -Xmx1073741824 -Xms1073741824
          -XX:MaxMetaspaceSize=268435456 -Dlog.file=/opt/flink/log/jobmanager.log -Dlogback.configurationFile=file:/opt/flink/conf/logback-console.xml
          -Dlog4j.configuration=file:/opt/flink/conf/log4j-console.properties -Dlog4j.configurationFile=file:/opt/flink/conf/log4j-console.properties
          org.apache.flink.kubernetes.entrypoint.KubernetesApplicationClusterEntrypoint
          -D jobmanager.memory.off-heap.size=134217728b -D jobmanager.memory.jvm-overhead.min=201326592b
          -D jobmanager.memory.jvm-metaspace.size=268435456b -D jobmanager.memory.heap.size=1073741824b
          -D jobmanager.memory.jvm-overhead.max=201326592b
      command:
        - /docker-entrypoint.sh
      env:
        - name: _POD_IP_ADDRESS
          valueFrom:
            fieldRef:
              apiVersion: v1
              fieldPath: status.podIP
      image: apache/flink:1.12.7-scala_2.12
      imagePullPolicy: IfNotPresent
      name: flink-job-manager
      ports:
        - containerPort: 8081
          name: rest
          protocol: TCP
        - containerPort: 6123
          name: jobmanager-rpc
          protocol: TCP
        - containerPort: 6124
          name: blobserver
          protocol: TCP
      resources:
        limits:
          cpu: "1"
          memory: 1600Mi
        requests:
          cpu: "1"
          memory: 1600Mi
      terminationMessagePath: /dev/termination-log
      terminationMessagePolicy: File
      volumeMounts:
        - mountPath: /opt/flink/conf
          name: flink-config-volume
        - mountPath: /var/run/secrets/kubernetes.io/serviceaccount
          name: kube-api-access-g9wnl
          readOnly: true
  dnsPolicy: ClusterFirst
  enableServiceLinks: true
  nodeName: docker-desktop
  preemptionPolicy: PreemptLowerPriority
  priority: 0
  restartPolicy: Always
  schedulerName: default-scheduler
  securityContext: {}
  serviceAccount: default
  serviceAccountName: default
  terminationGracePeriodSeconds: 30
  tolerations:
    - effect: NoExecute
      key: node.kubernetes.io/not-ready
      operator: Exists
      tolerationSeconds: 300
    - effect: NoExecute
      key: node.kubernetes.io/unreachable
      operator: Exists
      tolerationSeconds: 300
  volumes:
    - configMap:
        defaultMode: 420
        items:
          - key: logback-console.xml
            path: logback-console.xml
          - key: log4j-console.properties
            path: log4j-console.properties
          - key: flink-conf.yaml
            path: flink-conf.yaml
        name: flink-config-my-first-application-cluster
      name: flink-config-volume
    - name: kube-api-access-g9wnl
      projected:
        defaultMode: 420
        sources:
          - serviceAccountToken:
              expirationSeconds: 3607
              path: token
          - configMap:
              items:
                - key: ca.crt
                  path: ca.crt
              name: kube-root-ca.crt
          - downwardAPI:
              items:
                - fieldRef:
                    apiVersion: v1
                    fieldPath: metadata.namespace
                  path: namespace
status:
  conditions:
    - lastProbeTime: null
      lastTransitionTime: "2023-08-04T08:24:47Z"
      status: "True"
      type: Initialized
    - lastProbeTime: null
      lastTransitionTime: "2023-08-04T08:25:05Z"
      status: "True"
      type: Ready
    - lastProbeTime: null
      lastTransitionTime: "2023-08-04T08:25:05Z"
      status: "True"
      type: ContainersReady
    - lastProbeTime: null
      lastTransitionTime: "2023-08-04T08:24:47Z"
      status: "True"
      type: PodScheduled
  containerStatuses:
    - containerID: docker://8243c39483184d02316f557518956ad391f57153191078ac3e745a02b67a009b
      image: apache/flink:1.12.7
      imageID: docker-pullable://apache/flink@sha256:90bcdc6e6abba4fe118c100229b5ee69386d6ad13a42e871828398683055a65c
      lastState:
        terminated:
          containerID: docker://0b439a080ad6b4473d7bcdb96843a75d69654a049c0901cf4035b5903b30b489
          exitCode: 1
          finishedAt: "2023-08-04T08:25:03Z"
          reason: Error
          startedAt: "2023-08-04T08:24:52Z"
      name: flink-job-manager
      ready: true
      restartCount: 1
      started: true
      state:
        running:
          startedAt: "2023-08-04T08:25:04Z"
  hostIP: 192.168.65.4
  phase: Running
  podIP: 10.1.0.121
  podIPs:
    - ip: 10.1.0.121
  qosClass: Guaranteed
  startTime: "2023-08-04T08:24:47Z"

vim /Users/ispong/pod-init.yaml

apiVersion: v1
kind: Pod
metadata:
  name: host-pod
spec:
  containers:
    - name: flink-main-container
      # ports:
      #   - containerPort: 8081
      #     hostPort: 8081
      #     protocol: TCP
      #   - containerPort: 6123
      #     hostPort: 6123
      #     protocol: TCP
      #   - containerPort: 6124
      #     hostPort: 6124
      #     protocol: TCP
      volumeMounts:
        - name: file1
          mountPath: /opt/flink/examples/streaming/flink-execute-sql-plugin.jar
        - name: mysql-jdbc
          mountPath: /opt/flink/lib/mysql-connector-j-8.1.0.jar
        - name: mysql-cdc
          mountPath: /opt/flink/lib/flink-connector-mysql-cdc-2.4.2.jar
        - name: log-cdc
          mountPath: /opt/flink/lib/flink-out-connector.jar
        - name: flink-jdbc
          mountPath: /opt/flink/lib/flink-connector-jdbc-3.1.1-1.17.jar
        # - name: flink-yml
        #   mountPath: /opt/flink/log/flink-conf.yaml
        # - name: log4j
        #   mountPath: /opt/flink/log/log4j.properties
        # - name: logback
        #   mountPath: /opt/flink/log/logback.xml
  hostAliases:
    - ip: "192.168.34.113"
      hostnames:
        - "isxcode"
  volumes:
    - name: file1
      hostPath:
        path: /Users/ispong/code/flink-yun/flink-yun-vip/flink-yun-plugins/flink-sql-plugin/build/libs/flink-execute-sql-plugin.jar
    - name: mysql-cdc
      hostPath:
        path: /Users/ispong/code/flink-yun/flink-yun-dist/flink-min/lib/flink-connector-mysql-cdc-2.4.2.jar
    - name: log-cdc
      hostPath:
        path: /Users/ispong/code/flink-yun/flink-yun-dist/flink-min/lib/flink-out-connector.jar
    - name: mysql-jdbc
      hostPath:
        path: /Users/ispong/code/flink-yun/flink-yun-dist/flink-min/lib/mysql-connector-j-8.1.0.jar
    - name: flink-jdbc
      hostPath:
        path: /Users/ispong/code/flink-yun/flink-yun-dist/flink-min/lib/flink-connector-jdbc-3.1.1-1.17.jar
    # - name: flink-yml
    #   hostPath:
    #     path: /Users/ispong/code/flink-yun/flink-yun-dist/flink-min/conf/flink-conf.yaml
    # - name: log4j
    #   hostPath:
    #     path: /Users/ispong/code/flink-yun/flink-yun-dist/flink-min/conf/log4j.properties
    # - name: logback
    #   hostPath:
    #     path: /Users/ispong/code/flink-yun/flink-yun-dist/flink-min/conf/logback.xml
提交命令
# 创建空间名称
kubectl create namespace zhiliuyun-space
# 创建账号
kubectl create serviceaccount zhiliuyun -n zhiliuyun-space
# 绑定权限
kubectl create clusterrolebinding flink-role --clusterrole=edit --serviceaccount=zhiliuyun-space:zhiliuyun --namespace=zhiliuyun-space
# 检查是否成功
kubectl auth can-i create pods --as=system:serviceaccount:zhiliuyun-space:zhiliuyun

# 查看pods
kubectl get pods -n zhiliuyun-space -o wide

# 查看pods日志
kubectl logs -f zhiliuyun-cluster-1712720389574-7887d46ff9-w4brf -n zhiliuyun-space

# 查看deployment
kubectl get deployment -n zhiliuyun-space -o wide

# 查看deployment日志
kubectl describe deployment zhiliuyun-cluster-1712720389574  -n zhiliuyun-space

# 关闭deployment
kubectl scale deployment zhiliuyun-cluster --replicas=0 -n zhiliuyun-space

# 删除deployment
kubectl delete deployment zhiliuyun-cluster-1712763933629 -n zhiliuyun-space
kubectl delete deployment flink-cluster-9617446f3c3d102f5ced4ef5bbfbf23
vim /Users/ispong/Downloads/pod-template.yaml

containers.name 一定要匹配上

apiVersion: v1
kind: Pod
metadata:
  name: host-pod
spec:
  initContainers:
    - name: artifacts-fetcher
      image: busybox:latest
      command: [ 'cp','-r','/conf','/opt/flink/conf' ]
      volumeMounts:
        - name: flink-config
          mountPath: /conf
  containers:
    - name: flink-main-container
      volumeMounts:
        - name: app
          mountPath: /opt/flink/examples/app.jar
        - name: flink-connector-jdbc
          mountPath: /opt/flink/lib/flink-connector-jdbc-3.1.2-1.18.jar
        - name: mysql-driver
          mountPath: /opt/flink/lib/mysql-connector-j-8.1.0.jar
        - name: flink-log
          mountPath: /opt/flink/log
        - name: flink-config
          mountPath: /opt/flink/examples/conf2
  volumes:
    - name: app
      hostPath:
        path: /Users/ispong/Downloads/flink-sql-execute-plugin.jar
    - name: flink-connector-jdbc
      hostPath:
        path: /Users/ispong/Downloads/flink-connector-jdbc-3.1.2-1.18.jar
    - name: mysql-driver
      hostPath:
        path: /Users/ispong/Downloads/mysql-connector-j-8.1.0.jar
    - name: flink-log
      hostPath:
        path: /Users/ispong/Downloads/log
        type: Directory
    - name: flink-config
      hostPath:
        path: /Users/ispong/isxcode/flink-yun/flink-yun-dist/flink-min/conf
vim /Users/ispong/Downloads/pod-template.yaml
apiVersion: v1
kind: Pod
metadata:
  name: host-pod
spec:
  containers:
    - name: flink-main-container
      volumeMounts:
        - name: app
          mountPath: /opt/flink/examples/streaming/app.jar
        - name: flink-connector-jdbc
          mountPath: /opt/flink/lib/flink-connector-jdbc-3.1.2-1.18.jar
        - name: mysql-driver
          mountPath: /opt/flink/lib/mysql-connector-j-8.1.0.jar
        - name: flink-log
          mountPath: /zhiliuyun/log
  hostAliases:
    - ip: "210.87.110.108"
      hostnames:
        - "isxcode"
  volumes:
    - name: app
      hostPath:
        path: /Users/ispong/Downloads/flink-sql-execute-plugin.jar
    - name: flink-connector-jdbc
      hostPath:
        path: /Users/ispong/Downloads/flink-connector-jdbc-3.1.2-1.18.jar
    - name: mysql-driver
      hostPath:
        path: /Users/ispong/Downloads/mysql-connector-j-8.1.0.jar
    - name: flink-log
      hostPath:
        path: /Users/ispong/Downloads/log
        type: Directory
apiVersion: v1
kind: Pod
metadata:
  name: pod-template
spec:
  containers:
    - name: flink-main-container
      volumeMounts:
        - name: app
          mountPath: /opt/flink/examples/streaming/app.jar
        - name: flink-connector-jdbc
          mountPath: /opt/flink/lib/flink-connector-jdbc-3.1.2-1.18.jar
        - name: mysql-driver
          mountPath: /opt/flink/lib/mysql-connector-j-8.1.0.jar
        - name: flink-log
          mountPath: /log
        - name: checkpoint-pvc
          mountPath: /opt/flink/checkpoints
        - name: savepoint-pvc
          mountPath: /opt/flink/savepoints
  hostAliases:
    - ip: "210.87.110.108"
      hostnames:
        - "isxcode"
  volumes:
    - name: app
      hostPath:
        path: /Users/ispong/Downloads/flink-sql-execute-plugin.jar
    - name: flink-connector-jdbc
      hostPath:
        path: /Users/ispong/Downloads/flink-connector-jdbc-3.1.2-1.18.jar
    - name: mysql-driver
      hostPath:
        path: /Users/ispong/Downloads/mysql-connector-j-8.1.0.jar
    - name: flink-log
      hostPath:
        path: /Users/ispong/Downloads/log
    - name: checkpoint-pvc
      persistentVolumeClaim:
        claimName: flink-checkpoint
    - name: savepoint-pvc
      persistentVolumeClaim:
        claimName: flink-savepoint
apiVersion: v1
kind: Pod
metadata:
  name: pod-template
spec:
  containers:
    - name: flink-main-container
      volumeMounts:
        - name: app
          mountPath: /opt/flink/examples/app.jar
        - name: flink-connector-jdbc
          mountPath: /opt/flink/lib/flink-connector-jdbc-3.1.2-1.18.jar
        - name: mysql-driver
          mountPath: /opt/flink/lib/mysql-connector-j-8.1.0.jar
        - name: flink-log
          mountPath: /log
  hostAliases:
    - ip: "47.92.152.18"
      hostnames:
        - "isxcode"
  volumes:
    - name: app
      hostPath:
        path: /Users/ispong/isxcode/flink-yun/flink-yun-plugins/flink-sql-execute-plugin/build/libs/flink-sql-execute-plugin.jar
    - name: flink-connector-jdbc
      hostPath:
        path: /Users/ispong/isxcode/flink-yun/resources/cdc/flink-connector-jdbc-3.1.2-1.18.jar
    - name: mysql-driver
      hostPath:
        path: /Users/ispong/isxcode/flink-yun/resources/jdbc/system/mysql-connector-j-8.1.0.jar
    - name: flink-log
      hostPath:
        path: /Users/ispong/isxcode/flink-yun/flink-yun-dist/flink-min/log

flink 提交到k8s中
https://ispong.isxcode.com/hadoop/flink/flink 提交到k8s中/
Author
ispong
Posted on
August 7, 2023
Licensed under