values.yaml 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336
  1. # Default values for flink.
  2. # This is a YAML-formatted file.
  3. # Declare variables to be passed into your templates.
  4. nameOverride: ""
  5. fullnameOverride: ""
  6. image:
  7. repository: flink
  8. tag: 1.12.1-scala_2.12-java11
  9. pullPolicy: IfNotPresent
  10. imagePullSecrets: []
  11. # For general configuration
  12. flink:
  13. # logging, log4j configuration copied from Flink distribution
  14. logging:
  15. log4j_properties: |+
  16. # This affects logging for both user code and Flink
  17. rootLogger.level = INFO
  18. rootLogger.appenderRef.console.ref = ConsoleAppender
  19. rootLogger.appenderRef.rolling.ref = RollingFileAppender
  20. # Uncomment this if you want to _only_ change Flink's logging
  21. #logger.flink.name = org.apache.flink
  22. #logger.flink.level = INFO
  23. # The following lines keep the log level of common libraries/connectors on
  24. # log level INFO. The root logger does not override this. You have to manually
  25. # change the log levels here.
  26. logger.akka.name = akka
  27. logger.akka.level = INFO
  28. logger.kafka.name= org.apache.kafka
  29. logger.kafka.level = INFO
  30. logger.hadoop.name = org.apache.hadoop
  31. logger.hadoop.level = INFO
  32. logger.zookeeper.name = org.apache.zookeeper
  33. logger.zookeeper.level = INFO
  34. # Log all infos to the console
  35. appender.console.name = ConsoleAppender
  36. appender.console.type = CONSOLE
  37. appender.console.layout.type = PatternLayout
  38. appender.console.layout.pattern = %d{yyyy-MM-dd HH:mm:ss,SSS} %-5p %-60c %x - %m%n
  39. # Log all infos in the given rolling file
  40. appender.rolling.name = RollingFileAppender
  41. appender.rolling.type = RollingFile
  42. appender.rolling.append = false
  43. appender.rolling.fileName = ${sys:log.file}
  44. appender.rolling.filePattern = ${sys:log.file}.%i
  45. appender.rolling.layout.type = PatternLayout
  46. appender.rolling.layout.pattern = %d{yyyy-MM-dd HH:mm:ss,SSS} %-5p %-60c %x - %m%n
  47. appender.rolling.policies.type = Policies
  48. appender.rolling.policies.size.type = SizeBasedTriggeringPolicy
  49. appender.rolling.policies.size.size=100MB
  50. appender.rolling.strategy.type = DefaultRolloverStrategy
  51. appender.rolling.strategy.max = 10
  52. # Suppress the irrelevant (wrong) warnings from the Netty channel handler
  53. logger.netty.name = org.apache.flink.shaded.akka.org.jboss.netty.channel.DefaultChannelPipeline
  54. logger.netty.level = OFF
  55. # monitoring is exporting metrics in Prometheus format
  56. monitoring:
  57. enabled: true
  58. # port for metrics
  59. port: 9999
  60. # latency monitoring
  61. latency:
  62. enabled: false
  63. probingInterval: 1000
  64. # system is additional system metrics
  65. system:
  66. enabled: true
  67. probingInterval: 5000
  68. rocksdb:
  69. enabled: false
  70. workDir: /opt/flink
  71. # In case of issue - Metaspace OOM increase this param according to your memory limits
  72. # params: |+
  73. # taskmanager.memory.jvm-metaspace.size: 256mb
  74. params: ""
  75. state:
  76. # backend for state. Available options: filesystem, rocksdb, memory; empty - for default(memory)
  77. backend: filesystem
  78. # These values are default excludes file pathes
  79. # https://ci.apache.org/projects/flink/flink-docs-stable/dev/stream/state/checkpointing.html#related-config-options
  80. params: |+
  81. state.checkpoints.dir: s3p://<s3_bucket>/flink_state/checkpoints
  82. state.savepoints.dir: s3p://<s3_bucket>/flink_state/savepoints
  83. state.backend.async: true
  84. state.backend.fs.memory-threshold: 1024
  85. state.backend.fs.write-buffer-size: 4096
  86. state.backend.incremental: false
  87. state.backend.local-recovery: false
  88. state.checkpoints.num-retained: 30
  89. taskmanager.state.local.root-dirs: s3p://<s3_bucket>/flink_state/local-recovery
  90. # https://ci.apache.org/projects/flink/flink-docs-stable/ops/state/state_backends.html#rocksdb-state-backend-config-options
  91. # * state.backend.rocksdb.localdir doesn't have a prefix - file://
  92. rocksdb: |+
  93. state.backend.rocksdb.checkpoint.transfer.thread.num: 1
  94. state.backend.rocksdb.localdir: /flink_state/rocksdb
  95. state.backend.rocksdb.options-factory: org.apache.flink.contrib.streaming.state.DefaultConfigurableOptionsFactory
  96. state.backend.rocksdb.predefined-options: DEFAULT
  97. state.backend.rocksdb.timer-service.factory: HEAP
  98. state.backend.rocksdb.ttl.compaction.filter.enabled: false
  99. # extraEnvs passes envs to both Jobmanagers and Taskmanager
  100. # for example
  101. # extraEnvs:
  102. # - name: KAFKA_BOOTSTRAP_SERVERS
  103. # value: dest-kafka-bootstrap:9092
  104. #
  105. extraEnvs: []
  106. jobmanager:
  107. # Statefulset option will create Jobmanager as a StatefulSet
  108. statefulset: false
  109. # Init containers
  110. initContainers: {}
  111. # Example
  112. # test:
  113. # image: busybox:1.28
  114. # command:
  115. # - /bin/sh
  116. # - -c
  117. # - "echo test"
  118. # highAvailability configuration based on zookeeper
  119. highAvailability:
  120. # enabled also will enable zookeeper Dependency
  121. enabled: true
  122. zookeeperConnect: "{{ .Release.Name }}-zookeeper:{{ .Values.zookeeper.env.ZOO_PORT }}"
  123. zookeeperRootPath: /flink
  124. clusterId: <cluster-id>
  125. # storageDir for Jobmanagers. DFS expected.
  126. # Docs - Storage directory (required): JobManager metadata is persisted in the file system storageDir and only a pointer to this state is stored in ZooKeeper
  127. storageDir: s3p://<s3_bucket>/flink_state/recovery
  128. # syncPort is a rpc port in HA configuration
  129. syncPort: 6150
  130. # command for HA configuration
  131. # this trick with sed required because taskmanagers read jobmanager.rpc.address from Zookeeper.
  132. # For configuration with one jobmanager (it's enough stable because Kubernetes will restart Jobmanager on falures)
  133. # 'sed' can be changed to use flink service name, e.g. {{ include "flink.name" . }}-jobmanager
  134. command: >-
  135. sed 's/REPLACE_HOSTNAME/'${FLINK_POD_IP}'/'
  136. $FLINK_HOME/conf/flink-conf.yaml.tpl > $FLINK_HOME/conf/flink-conf.yaml &&
  137. $FLINK_HOME/bin/jobmanager.sh start-foreground;
  138. # Additional param for JVM to support security.properties override
  139. # check configMap for more information
  140. jvmArgs: "-Djava.security.properties={{ .Values.flink.workDir }}/conf/security.properties"
  141. # extraEnvs passes envs to Jobmanagers
  142. extraEnvs: []
  143. ports:
  144. rpc: 6123
  145. # blob port uses for Liveness probe
  146. blob: 6124
  147. ui: 8081
  148. replicaCount: 2
  149. # heapSize params for Jobmanager
  150. # keep in mind that Flink can use offheap memory
  151. # e.g. in case of checkpoint usage
  152. heapSize: 1g
  153. resources: {}
  154. # Example
  155. # limits:
  156. # cpu: 3800m
  157. # memory: 8000Mi
  158. additionalCommand: >-
  159. apt-get update &&
  160. apt-get -y install awscli &&
  161. mkdir -p /opt/flink/plugins/s3-fs-presto/ &&
  162. cp /opt/flink/opt/flink-s3-fs-presto-1.12.1.jar /opt/flink/lib/flink-s3-fs-presto-1.12.1.jar &&
  163. cp /opt/flink/opt/flink-s3-fs-presto-1.12.1.jar /opt/flink/plugins/s3-fs-presto/flink-s3-fs-presto-1.12.1.jar &&
  164. wget https://repo1.maven.org/maven2/com/github/oshi/oshi-core/3.4.0/oshi-core-3.4.0.jar
  165. -O /opt/flink/lib/oshi-core-3.4.0.jar &&
  166. wget https://repo1.maven.org/maven2/net/java/dev/jna/jna/5.4.0/jna-5.4.0.jar
  167. -O /opt/flink/lib/jna-5.4.0.jar &&
  168. wget https://repo1.maven.org/maven2/net/java/dev/jna/jna-platform/5.4.0/jna-platform-5.4.0.jar
  169. -O /opt/flink/lib/jna-platform-5.4.0.jar
  170. command: >-
  171. cp $FLINK_HOME/conf/flink-conf.yaml.tpl $FLINK_HOME/conf/flink-conf.yaml &&
  172. $FLINK_HOME/bin/jobmanager.sh start-foreground;
  173. service:
  174. type: LoadBalancer
  175. annotations:
  176. service.beta.kubernetes.io/aws-load-balancer-internal: "true"
  177. # rest is additional service which exposes only HTTP port
  178. # can be using for cases of using exposeController
  179. rest:
  180. enabled: true
  181. annotations: {}
  182. headless:
  183. annotations: {}
  184. nodeSelector: {}
  185. affinity: {}
  186. tolerations: []
  187. persistent:
  188. enabled: false
  189. # https://kubernetes.io/docs/concepts/storage/persistent-volumes/#class-1
  190. storageClass:
  191. size: 8Gi
  192. mountPath: "/flink_state"
  193. podManagementPolicy: Parallel
  194. annotations: {}
  195. # Example
  196. # "cluster-autoscaler.kubernetes.io/safe-to-evict": "false"
  197. serviceAccount:
  198. # Specifies whether a ServiceAccount should be created
  199. create: true
  200. # The name of the ServiceAccount to use.
  201. # If not set and create is true, a name is generated using the fullname template
  202. name:
  203. annotations: {}
  204. #livenessProbe will conduct checks for rpc port as tcpSocket probe
  205. livenessProbe:
  206. initialDelaySeconds: 10
  207. periodSeconds: 15
  208. readinessProbe:
  209. periodSeconds: 10
  210. initialDelaySeconds: 20
  211. podAnnotations: {}
  212. taskmanager:
  213. # Statefulset option will create Taskmanager as a StatefulSet
  214. # A necessary option for Persistent
  215. statefulset: true
  216. # Additional param for JVM to support security.properties override
  217. # check configMap for more information
  218. jvmArgs: "-Djava.security.properties={{ .Values.flink.workDir }}/conf/security.properties"
  219. # extraEnvs passes envs to Taskmanagers
  220. extraEnvs: []
  221. ports:
  222. rpc: 6122
  223. replicaCount: 4
  224. numberOfTaskSlots: 1
  225. memoryProcessSize: 1g
  226. memoryFlinkSize:
  227. resources: {}
  228. # Example
  229. # limits:
  230. # cpu: 3800m
  231. # memory: 8000Mi
  232. additionalCommand: >-
  233. apt-get update &&
  234. apt-get -y install awscli &&
  235. mkdir -p /opt/flink/plugins/s3-fs-presto/ &&
  236. cp /opt/flink/opt/flink-s3-fs-presto-1.12.1.jar /opt/flink/lib/flink-s3-fs-presto-1.12.1.jar &&
  237. cp /opt/flink/opt/flink-s3-fs-presto-1.12.1.jar /opt/flink/plugins/s3-fs-presto/flink-s3-fs-presto-1.12.1.jar &&
  238. wget https://repo1.maven.org/maven2/com/github/oshi/oshi-core/3.4.0/oshi-core-3.4.0.jar
  239. -O /opt/flink/lib/oshi-core-3.4.0.jar &&
  240. wget https://repo1.maven.org/maven2/net/java/dev/jna/jna/5.4.0/jna-5.4.0.jar
  241. -O /opt/flink/lib/jna-5.4.0.jar &&
  242. wget https://repo1.maven.org/maven2/net/java/dev/jna/jna-platform/5.4.0/jna-platform-5.4.0.jar
  243. -O /opt/flink/lib/jna-platform-5.4.0.jar
  244. command: >-
  245. $FLINK_HOME/bin/taskmanager.sh start-foreground;
  246. service:
  247. type: ClusterIP
  248. nodeSelector: {}
  249. affinity: {}
  250. tolerations: []
  251. persistent:
  252. enabled: false
  253. # https://kubernetes.io/docs/concepts/storage/persistent-volumes/#class-1
  254. storageClass:
  255. size: 8Gi
  256. mountPath: "/flink_state"
  257. podManagementPolicy: Parallel
  258. annotations:
  259. "cluster-autoscaler.kubernetes.io/safe-to-evict": "false"
  260. serviceAccount:
  261. # Specifies whether a ServiceAccount should be created
  262. create: true
  263. # The name of the ServiceAccount to use.
  264. # If not set and create is true, a name is generated using the fullname template
  265. name:
  266. annotations: {}
  267. #livenessProbe will conduct checks for rpc port as tcpSocket probe
  268. livenessProbe:
  269. initialDelaySeconds: 30
  270. periodSeconds: 60
  271. podAnnotations: {}
  272. ingress:
  273. enabled: false
  274. annotations: {}
  275. path: /
  276. hosts: []
  277. tls: []
  278. prometheus:
  279. # serviceMonitor provides service discovery for prometheus operatored installations
  280. serviceMonitor:
  281. enabled: false
  282. namespace:
  283. interval: 5s
  284. selector:
  285. # According to default selector for prometheus operator
  286. prometheus: kube-prometheus
  287. zookeeper:
  288. enabled: true
  289. replicaCount: 2
  290. env:
  291. ZK_HEAP_SIZE: "1G"
  292. ZOO_PORT: 2181
  293. resources:
  294. limits:
  295. cpu: 400m
  296. memory: 1256Mi
  297. persistence:
  298. enabled: true
  299. secrets:
  300. # Plain predefined secrets example
  301. # kubernetesSecrets:
  302. # - name: kerberos
  303. # mountPath: /kerberos
  304. bitnamiSealedSecrets:
  305. enabled: false
  306. # The encrypted raw file sealed secrets generated for example with
  307. # kubeseal --raw --from-file=... --controller-name sealed-secrets --scope namespace-wide
  308. sealedSecretFiles: {}
  309. # file1: encypted_file1
  310. # file2: encypted_file2
  311. sealedSecretFilesPath: /etc/sealed
  312. sealedSecretFilesAnnotations:
  313. sealedsecrets.bitnami.com/namespace-wide: true
  314. # The encrypted raw env sealed secrets generated for example with
  315. # echo -n password | kubeseal --raw --from-file=/dev/stdin --controller-name sealed-secrets --scope namespace-wide
  316. sealedSecretEnvs: {}
  317. # env1: encypted_env1
  318. # env2: encypted_env2
  319. sealedSecretEnvsAnnotations:
  320. sealedsecrets.bitnami.com/namespace-wide: true