kafka-ssl-components.yaml 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. ---
  2. version: '3.4'
  3. services:
  4. kafka-ui:
  5. container_name: kafka-ui
  6. image: provectuslabs/kafka-ui:latest
  7. ports:
  8. - 8080:8080
  9. depends_on:
  10. - kafka0
  11. - schemaregistry0
  12. - kafka-connect0
  13. - ksqldb0
  14. environment:
  15. KAFKA_CLUSTERS_0_NAME: local
  16. KAFKA_CLUSTERS_0_PROPERTIES_SECURITY_PROTOCOL: SSL
  17. KAFKA_CLUSTERS_0_BOOTSTRAPSERVERS: kafka0:29092 # SSL LISTENER!
  18. KAFKA_CLUSTERS_0_PROPERTIES_SSL_ENDPOINT_IDENTIFICATION_ALGORITHM: '' # DISABLE COMMON NAME VERIFICATION
  19. KAFKA_CLUSTERS_0_SCHEMAREGISTRY: https://schemaregistry0:8085
  20. KAFKA_CLUSTERS_0_SCHEMAREGISTRYSSL_KEYSTORELOCATION: /kafka.keystore.jks
  21. KAFKA_CLUSTERS_0_SCHEMAREGISTRYSSL_KEYSTOREPASSWORD: "secret"
  22. KAFKA_CLUSTERS_0_KSQLDBSERVER: https://ksqldb0:8088
  23. KAFKA_CLUSTERS_0_KSQLDBSERVERSSL_KEYSTORELOCATION: /kafka.keystore.jks
  24. KAFKA_CLUSTERS_0_KSQLDBSERVERSSL_KEYSTOREPASSWORD: "secret"
  25. KAFKA_CLUSTERS_0_KAFKACONNECT_0_NAME: local
  26. KAFKA_CLUSTERS_0_KAFKACONNECT_0_ADDRESS: https://kafka-connect0:8083
  27. KAFKA_CLUSTERS_0_KAFKACONNECT_0_KEYSTORELOCATION: /kafka.keystore.jks
  28. KAFKA_CLUSTERS_0_KAFKACONNECT_0_KEYSTOREPASSWORD: "secret"
  29. KAFKA_CLUSTERS_0_SSL_TRUSTSTORELOCATION: /kafka.truststore.jks
  30. KAFKA_CLUSTERS_0_SSL_TRUSTSTOREPASSWORD: "secret"
  31. DYNAMIC_CONFIG_ENABLED: 'true' # not necessary for ssl, added for tests
  32. volumes:
  33. - ./ssl/kafka.truststore.jks:/kafka.truststore.jks
  34. - ./ssl/kafka.keystore.jks:/kafka.keystore.jks
  35. kafka0:
  36. image: confluentinc/cp-kafka:7.2.1
  37. hostname: kafka0
  38. container_name: kafka0
  39. ports:
  40. - "9092:9092"
  41. - "9997:9997"
  42. environment:
  43. KAFKA_BROKER_ID: 1
  44. KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: 'CONTROLLER:PLAINTEXT,SSL:SSL,PLAINTEXT_HOST:PLAINTEXT'
  45. KAFKA_ADVERTISED_LISTENERS: 'SSL://kafka0:29092,PLAINTEXT_HOST://localhost:9092'
  46. KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 1
  47. KAFKA_GROUP_INITIAL_REBALANCE_DELAY_MS: 0
  48. KAFKA_TRANSACTION_STATE_LOG_MIN_ISR: 1
  49. KAFKA_TRANSACTION_STATE_LOG_REPLICATION_FACTOR: 1
  50. KAFKA_JMX_PORT: 9997
  51. KAFKA_JMX_HOSTNAME: localhost
  52. KAFKA_PROCESS_ROLES: 'broker,controller'
  53. KAFKA_NODE_ID: 1
  54. KAFKA_CONTROLLER_QUORUM_VOTERS: '1@kafka0:29093'
  55. KAFKA_LISTENERS: 'SSL://kafka0:29092,CONTROLLER://kafka0:29093,PLAINTEXT_HOST://0.0.0.0:9092'
  56. KAFKA_INTER_BROKER_LISTENER_NAME: 'SSL'
  57. KAFKA_CONTROLLER_LISTENER_NAMES: 'CONTROLLER'
  58. KAFKA_LOG_DIRS: '/tmp/kraft-combined-logs'
  59. KAFKA_SECURITY_PROTOCOL: SSL
  60. KAFKA_SSL_ENABLED_MECHANISMS: PLAIN,SSL
  61. KAFKA_SSL_KEYSTORE_FILENAME: kafka.keystore.jks
  62. KAFKA_SSL_KEYSTORE_CREDENTIALS: creds
  63. KAFKA_SSL_KEY_CREDENTIALS: creds
  64. KAFKA_SSL_TRUSTSTORE_FILENAME: kafka.truststore.jks
  65. KAFKA_SSL_TRUSTSTORE_CREDENTIALS: creds
  66. #KAFKA_SSL_CLIENT_AUTH: 'required'
  67. KAFKA_SSL_CLIENT_AUTH: 'requested'
  68. KAFKA_SSL_ENDPOINT_IDENTIFICATION_ALGORITHM: '' # COMMON NAME VERIFICATION IS DISABLED SERVER-SIDE
  69. volumes:
  70. - ./scripts/update_run.sh:/tmp/update_run.sh
  71. - ./ssl/creds:/etc/kafka/secrets/creds
  72. - ./ssl/kafka.truststore.jks:/etc/kafka/secrets/kafka.truststore.jks
  73. - ./ssl/kafka.keystore.jks:/etc/kafka/secrets/kafka.keystore.jks
  74. command: "bash -c 'if [ ! -f /tmp/update_run.sh ]; then echo \"ERROR: Did you forget the update_run.sh file that came with this docker-compose.yml file?\" && exit 1 ; else /tmp/update_run.sh && /etc/confluent/docker/run ; fi'"
  75. schemaregistry0:
  76. image: confluentinc/cp-schema-registry:7.2.1
  77. depends_on:
  78. - kafka0
  79. environment:
  80. SCHEMA_REGISTRY_KAFKASTORE_BOOTSTRAP_SERVERS: SSL://kafka0:29092
  81. SCHEMA_REGISTRY_KAFKASTORE_SECURITY_PROTOCOL: SSL
  82. SCHEMA_REGISTRY_KAFKASTORE_SSL_TRUSTSTORE_LOCATION: /kafka.truststore.jks
  83. SCHEMA_REGISTRY_KAFKASTORE_SSL_TRUSTSTORE_PASSWORD: secret
  84. SCHEMA_REGISTRY_KAFKASTORE_SSL_KEYSTORE_LOCATION: /kafka.keystore.jks
  85. SCHEMA_REGISTRY_KAFKASTORE_SSL_KEYSTORE_PASSWORD: secret
  86. SCHEMA_REGISTRY_KAFKASTORE_SSL_KEY_PASSWORD: secret
  87. SCHEMA_REGISTRY_HOST_NAME: schemaregistry0
  88. SCHEMA_REGISTRY_LISTENERS: https://schemaregistry0:8085
  89. SCHEMA_REGISTRY_INTER_INSTANCE_PROTOCOL: https
  90. SCHEMA_REGISTRY_SCHEMA_REGISTRY_INTER_INSTANCE_PROTOCOL: "https"
  91. SCHEMA_REGISTRY_LOG4J_ROOT_LOGLEVEL: INFO
  92. SCHEMA_REGISTRY_KAFKASTORE_TOPIC: _schemas
  93. SCHEMA_REGISTRY_SSL_CLIENT_AUTHENTICATION: "REQUIRED"
  94. SCHEMA_REGISTRY_SSL_TRUSTSTORE_LOCATION: /kafka.truststore.jks
  95. SCHEMA_REGISTRY_SSL_TRUSTSTORE_PASSWORD: secret
  96. SCHEMA_REGISTRY_SSL_KEYSTORE_LOCATION: /kafka.keystore.jks
  97. SCHEMA_REGISTRY_SSL_KEYSTORE_PASSWORD: secret
  98. SCHEMA_REGISTRY_SSL_KEY_PASSWORD: secret
  99. ports:
  100. - 8085:8085
  101. volumes:
  102. - ./ssl/kafka.truststore.jks:/kafka.truststore.jks
  103. - ./ssl/kafka.keystore.jks:/kafka.keystore.jks
  104. kafka-connect0:
  105. image: confluentinc/cp-kafka-connect:7.2.1
  106. ports:
  107. - 8083:8083
  108. depends_on:
  109. - kafka0
  110. - schemaregistry0
  111. environment:
  112. CONNECT_BOOTSTRAP_SERVERS: kafka0:29092
  113. CONNECT_GROUP_ID: compose-connect-group
  114. CONNECT_CONFIG_STORAGE_TOPIC: _connect_configs
  115. CONNECT_CONFIG_STORAGE_REPLICATION_FACTOR: 1
  116. CONNECT_OFFSET_STORAGE_TOPIC: _connect_offset
  117. CONNECT_OFFSET_STORAGE_REPLICATION_FACTOR: 1
  118. CONNECT_STATUS_STORAGE_TOPIC: _connect_status
  119. CONNECT_STATUS_STORAGE_REPLICATION_FACTOR: 1
  120. CONNECT_KEY_CONVERTER: org.apache.kafka.connect.storage.StringConverter
  121. CONNECT_KEY_CONVERTER_SCHEMA_REGISTRY_URL: https://schemaregistry0:8085
  122. CONNECT_VALUE_CONVERTER: org.apache.kafka.connect.storage.StringConverter
  123. CONNECT_VALUE_CONVERTER_SCHEMA_REGISTRY_URL: https://schemaregistry0:8085
  124. CONNECT_INTERNAL_KEY_CONVERTER: org.apache.kafka.connect.json.JsonConverter
  125. CONNECT_INTERNAL_VALUE_CONVERTER: org.apache.kafka.connect.json.JsonConverter
  126. CONNECT_REST_ADVERTISED_HOST_NAME: kafka-connect0
  127. CONNECT_PLUGIN_PATH: "/usr/share/java,/usr/share/confluent-hub-components"
  128. CONNECT_SECURITY_PROTOCOL: "SSL"
  129. CONNECT_SSL_KEYSTORE_LOCATION: "/kafka.keystore.jks"
  130. CONNECT_SSL_KEY_PASSWORD: "secret"
  131. CONNECT_SSL_KEYSTORE_PASSWORD: "secret"
  132. CONNECT_SSL_TRUSTSTORE_LOCATION: "/kafka.truststore.jks"
  133. CONNECT_SSL_TRUSTSTORE_PASSWORD: "secret"
  134. CONNECT_SSL_CLIENT_AUTH: "requested"
  135. CONNECT_REST_ADVERTISED_LISTENER: "https"
  136. CONNECT_LISTENERS: "https://kafka-connect0:8083"
  137. volumes:
  138. - ./ssl/kafka.truststore.jks:/kafka.truststore.jks
  139. - ./ssl/kafka.keystore.jks:/kafka.keystore.jks
  140. ksqldb0:
  141. image: confluentinc/ksqldb-server:0.18.0
  142. depends_on:
  143. - kafka0
  144. - kafka-connect0
  145. - schemaregistry0
  146. ports:
  147. - 8088:8088
  148. environment:
  149. KSQL_CUB_KAFKA_TIMEOUT: 120
  150. KSQL_LISTENERS: https://0.0.0.0:8088
  151. KSQL_BOOTSTRAP_SERVERS: SSL://kafka0:29092
  152. KSQL_SECURITY_PROTOCOL: SSL
  153. KSQL_SSL_TRUSTSTORE_LOCATION: /kafka.truststore.jks
  154. KSQL_SSL_TRUSTSTORE_PASSWORD: secret
  155. KSQL_SSL_KEYSTORE_LOCATION: /kafka.keystore.jks
  156. KSQL_SSL_KEYSTORE_PASSWORD: secret
  157. KSQL_SSL_KEY_PASSWORD: secret
  158. KSQL_SSL_CLIENT_AUTHENTICATION: REQUIRED
  159. KSQL_KSQL_LOGGING_PROCESSING_STREAM_AUTO_CREATE: "true"
  160. KSQL_KSQL_LOGGING_PROCESSING_TOPIC_AUTO_CREATE: "true"
  161. KSQL_KSQL_CONNECT_URL: https://kafka-connect0:8083
  162. KSQL_KSQL_SCHEMA_REGISTRY_URL: https://schemaregistry0:8085
  163. KSQL_KSQL_SERVICE_ID: my_ksql_1
  164. KSQL_KSQL_HIDDEN_TOPICS: '^_.*'
  165. KSQL_CACHE_MAX_BYTES_BUFFERING: 0
  166. volumes:
  167. - ./ssl/kafka.truststore.jks:/kafka.truststore.jks
  168. - ./ssl/kafka.keystore.jks:/kafka.keystore.jks