k8s 部署Flink

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了k8s 部署Flink相关的知识,希望对你有一定的参考价值。

https://flink.apache.org/ # Flink官网

  1. 此步骤(k8s)部署才需要 配置文件

先把Flink的所有配置文件拷贝到本地, 再把本地的配置文件挂在到POD里面
技术图片

1.1 jobmanager的配置文件

vim flink-conf.yaml 修改配置文件

jobmanager.rpc.address: flink-jobmanager-svc
jobmanager.rpc.port: 6123
jobmanager.heap.size: 1024m
taskmanager.heap.size: 1024m
taskmanager.numberOfTaskSlots: 1
parallelism.default: 1
high-availability: zookeeper
high-availability.zookeeper.path.root: /flink
high-availability.cluster-id: 1
high-availability.storageDir: file:///data/ha
high-availability.zookeeper.quorum: localhost:2181
zookeeper.sasl.disable: true
high-availability.jobmanager.port: 6123
state.backend: filesystem
state.backend.fs.checkpointdir: file:///data/state
web.upload.dir: /data/upload
blob.server.port: 6124
metrics.internal.query-service.port: 6125
classloader.resolve-order: parent-first

vim zoo.cfg //可高用的配置

# The number of milliseconds of each tick
tickTime=2000

# The number of ticks that the initial  synchronization phase can take
initLimit=10

# The number of ticks that can pass between  sending a request and getting an acknowledgement
syncLimit=5

# The directory where the snapshot is stored.
# dataDir=/tmp/zookeeper

# The port at which the clients will connect
clientPort=2181

# ZooKeeper quorum peers
server.1=localhost:2888:3888
dataDir=/usr/local/flink-1.8.1/zookeeper/data
dataLogDir=/usr/local/flink-1.8.1/zookeeper/log

1.2 taskmanager的配置文件

vim flink-conf.yaml

jobmanager.rpc.address: flink-jobmanager-svc
jobmanager.rpc.port: 6123
jobmanager.heap.size: 1024m
taskmanager.heap.size: 1024m
taskmanager.numberOfTaskSlots: 4
parallelism.default: 1
high-availability: zookeeper
high-availability.cluster-id: 1
high-availability.storageDir: file:///tmp
high-availability.zookeeper.quorum: flink-jobmanager-svc:2181
zookeeper.sasl.disable: true
classloader.resolve-order: parent-first
  1. k8s部署

vim flink-jobmanager.yml

jobmanager 部署
apiVersion: v1
kind: PersistentVolume
metadata:
  name: flink-jobmanager-conf-pv
spec:
  accessModes:
    - ReadWriteMany
  capacity:
    storage: 10Gi
  persistentVolumeReclaimPolicy: Retain
  storageClassName: nas
  nfs:
    path: /flink/jobmanager/conf
    server: 自建

---
kind: PersistentVolumeClaim
apiVersion: v1
metadata:
  name: flink-jobmanager-conf-pvc
spec:
  accessModes:
    - ReadWriteMany
  storageClassName: nas
  resources:
    requests:
      storage: 10Gi

---
apiVersion: v1
kind: PersistentVolume
metadata:
  name: flink-jobmanager-lib-pv
spec:
  accessModes:
    - ReadWriteMany
  capacity:
    storage: 20Gi
  persistentVolumeReclaimPolicy: Retain
  storageClassName: nas
  nfs:
    path: /flink/jobmanager/lib
    server: 自建

---
kind: PersistentVolumeClaim
apiVersion: v1
metadata:
  name: flink-jobmanager-lib-pvc
spec:
  accessModes:
    - ReadWriteMany
  storageClassName: nas
  resources:
    requests:
      storage: 20Gi

apiVersion: v1
kind: PersistentVolume
metadata:
  name: flink-jobmanager-zookeeper-pv
spec:
  accessModes:
    - ReadWriteMany
  capacity:
    storage: 20Gi
  persistentVolumeReclaimPolicy: Retain
  storageClassName: nas
  nfs:
    path: /flink/jobmanager/zookeeper
    server: 自建

---
kind: PersistentVolumeClaim
apiVersion: v1
metadata:
  name: flink-jobmanager-zookeeper-pvc
spec:
  accessModes:
    - ReadWriteMany
  storageClassName: nas
  resources:
    requests:
      storage: 20Gi

apiVersion: v1
kind: PersistentVolume
metadata:
  name: flink-jobmanager-data-pv
spec:
  accessModes:
    - ReadWriteMany
  capacity:
    storage: 20Gi
  persistentVolumeReclaimPolicy: Retain
  storageClassName: nas
  nfs:
    path: /flink/jobmanager/data
    server: 自建

---
kind: PersistentVolumeClaim
apiVersion: v1
metadata:
  name: flink-jobmanager-data-pvc
spec:
  accessModes:
    - ReadWriteMany
  storageClassName: nas
  resources:
    requests:
      storage: 20Gi

---
apiVersion: v1
kind: Service
metadata:
  name: flink-jobmanager-svc
spec:
  ports:
  - name: flink-jobmanager-web
    nodePort: 30044
    port: 8081
    targetPort: 8081
  - name: flink-jobmanager-rpc
    nodePort: 32000
    port: 6123
    targetPort: 6123
  - name: blob
    nodePort: 32001
    targetPort: 6124
    port: 6124
  - name: query
    nodePort: 32002
    targetPort: 6125
    port: 6125
  type: NodePort
  selector:
    app: flink-jobmanager

---
apiVersion: apps/v1beta1
kind: Deployment
metadata:
  name: flink-jobmanager
spec:
  selector:
    matchLabels:
      app: flink-jobmanager
  template:
    metadata:
      labels:
        app: flink-jobmanager
    spec:
      containers:
      - image: flink:1.8.1
        name: flink-jobmanager
        ports:
        - containerPort: 8081
          name: flink-job
        command: ["/bin/sh","-c"]
        args: ["./zookeeper.sh start 1 && ./jobmanager.sh start-foreground"]
        volumeMounts:
        - name: flink-jobmanager-conf-pv
          mountPath: /usr/local/flink-1.8.1/conf
        - name: flink-jobmanager-lib-pv
          mountPath: /usr/local/flink-1.8.1/lib
        - name: flink-jobmanager-zookeeper-pv
          mountPath: /usr/local/flink-1.8.1/zookeeper
        - name: flink-jobmanager-data-pv
          mountPath: /data/
      volumes:
      - name: flink-jobmanager-conf-pv
        persistentVolumeClaim:
          claimName: flink-jobmanager-conf-pvc
      - name: flink-jobmanager-lib-pv
        persistentVolumeClaim:
          claimName: flink-jobmanager-lib-pvc
      - name: flink-jobmanager-zookeeper-pv
        persistentVolumeClaim:
          claimName: flink-jobmanager-zookeeper-pvc
      - name: flink-jobmanager-data-pv
        persistentVolumeClaim:
          claimName: flink-jobmanager-data-pvc

vim flink-taskmanager.yml

taskmanager 部署

apiVersion: v1
kind: PersistentVolume
metadata:
  name: flink-taskmanager-pv
spec:
  accessModes:
    - ReadWriteMany
  capacity:
    storage: 10Gi
  persistentVolumeReclaimPolicy: Retain
  storageClassName: nas
  nfs:
    path: /flink/taskmanager/conf
    server: 自建
---
kind: PersistentVolumeClaim
apiVersion: v1
metadata:
  name: flink-taskmanager-pvc
spec:
  accessModes:
    - ReadWriteMany
  storageClassName: nas
  resources:
    requests:
      storage: 10Gi

---
apiVersion: apps/v1beta1
kind: Deployment
metadata:
  name: flink-taskmanager
spec:
  replicas: 2
  selector:
    matchLabels:
      app: flink-taskmanager
  template:
    metadata:
      labels:
        app: flink-taskmanager
    spec:
      containers:
      - image: flink:1.8.1
        name: flink-taskmanager
        ports:
        - containerPort: 8081
          name: flink-task
        args:
        - ./taskmanager.sh
        - start-foreground
        volumeMounts:
        - name: flink-taskmanager-pv
          mountPath: /usr/local/flink-1.8.1/conf
        - name: flink-jobmanager-lib-pv
          mountPath: /usr/local/flink-1.8.1/lib
      volumes:
      - name: flink-taskmanager-pv
        persistentVolumeClaim:
          claimName: flink-taskmanager-pvc
      - name: flink-jobmanager-lib-pv
        persistentVolumeClaim:
          claimName: flink-jobmanager-lib-pvc

kubectl apply -f flink-jobmanager.yml flink-taskmanager.yml //创建配置文件 运行项目 打开 IP:30044 查看是不是正常

注意事项: jobmanager和taskmanager lib的jar 要保持一致

点外卖的小伙伴可以进群
技术图片

以上是关于k8s 部署Flink的主要内容,如果未能解决你的问题,请参考以下文章

flink on k8s部署方案调研

flink on k8s部署方案调研

flink on k8s部署方案调研

Flink系列部署篇:Native k8s部署高可用Flink集群实战

flink on k8s部署方案实践--详细步骤

flink on k8s部署方案实践--详细步骤