kafka-ssl-components.yaml 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  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. environment:
  14. KAFKA_CLUSTERS_0_NAME: local
  15. KAFKA_CLUSTERS_0_PROPERTIES_SECURITY_PROTOCOL: SSL
  16. KAFKA_CLUSTERS_0_BOOTSTRAPSERVERS: kafka0:29092 # SSL LISTENER!
  17. KAFKA_CLUSTERS_0_PROPERTIES_SSL_TRUSTSTORE_LOCATION: /kafka.truststore.jks
  18. KAFKA_CLUSTERS_0_PROPERTIES_SSL_TRUSTSTORE_PASSWORD: secret
  19. KAFKA_CLUSTERS_0_PROPERTIES_SSL_KEYSTORE_LOCATION: /kafka.keystore.jks
  20. KAFKA_CLUSTERS_0_PROPERTIES_SSL_KEYSTORE_PASSWORD: secret
  21. KAFKA_CLUSTERS_0_PROPERTIES_SSL_ENDPOINT_IDENTIFICATION_ALGORITHM: '' # DISABLE COMMON NAME VERIFICATION
  22. KAFKA_CLUSTERS_0_SCHEMAREGISTRY: https://schemaregistry0:8085
  23. KAFKA_CLUSTERS_0_SCHEMAREGISTRYSSL_KEYSTORELOCATION: /kafka.keystore.jks
  24. KAFKA_CLUSTERS_0_SCHEMAREGISTRYSSL_KEYSTOREPASSWORD: "secret"
  25. KAFKA_CLUSTERS_0_SCHEMAREGISTRYSSL_TRUSTSTORELOCATION: /kafka.truststore.jks
  26. KAFKA_CLUSTERS_0_SCHEMAREGISTRYSSL_TRUSTSTOREPASSWORD: "secret"
  27. KAFKA_CLUSTERS_0_KAFKACONNECT_0_NAME: local
  28. KAFKA_CLUSTERS_0_KAFKACONNECT_0_ADDRESS: https://kafka-connect0:8083
  29. KAFKA_CLUSTERS_0_KAFKACONNECT_0_KEYSTORELOCATION: /kafka.keystore.jks
  30. KAFKA_CLUSTERS_0_KAFKACONNECT_0_KEYSTOREPASSWORD: "secret"
  31. KAFKA_CLUSTERS_0_KAFKACONNECT_0_TRUSTSTORELOCATION: /kafka.truststore.jks
  32. KAFKA_CLUSTERS_0_KAFKACONNECT_0_TRUSTSTOREPASSWORD: "secret"
  33. volumes:
  34. - ./ssl/kafka.truststore.jks:/kafka.truststore.jks
  35. - ./ssl/kafka.keystore.jks:/kafka.keystore.jks
  36. kafka0:
  37. image: confluentinc/cp-kafka:7.2.1
  38. hostname: kafka0
  39. container_name: kafka0
  40. ports:
  41. - "9092:9092"
  42. - "9997:9997"
  43. environment:
  44. KAFKA_BROKER_ID: 1
  45. KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: 'CONTROLLER:PLAINTEXT,SSL:SSL,PLAINTEXT_HOST:PLAINTEXT'
  46. KAFKA_ADVERTISED_LISTENERS: 'SSL://kafka0:29092,PLAINTEXT_HOST://localhost:9092'
  47. KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 1
  48. KAFKA_GROUP_INITIAL_REBALANCE_DELAY_MS: 0
  49. KAFKA_TRANSACTION_STATE_LOG_MIN_ISR: 1
  50. KAFKA_TRANSACTION_STATE_LOG_REPLICATION_FACTOR: 1
  51. KAFKA_JMX_PORT: 9997
  52. KAFKA_JMX_HOSTNAME: localhost
  53. KAFKA_PROCESS_ROLES: 'broker,controller'
  54. KAFKA_NODE_ID: 1
  55. KAFKA_CONTROLLER_QUORUM_VOTERS: '1@kafka0:29093'
  56. KAFKA_LISTENERS: 'SSL://kafka0:29092,CONTROLLER://kafka0:29093,PLAINTEXT_HOST://0.0.0.0:9092'
  57. KAFKA_INTER_BROKER_LISTENER_NAME: 'SSL'
  58. KAFKA_CONTROLLER_LISTENER_NAMES: 'CONTROLLER'
  59. KAFKA_LOG_DIRS: '/tmp/kraft-combined-logs'
  60. KAFKA_SECURITY_PROTOCOL: SSL
  61. KAFKA_SSL_ENABLED_MECHANISMS: PLAIN,SSL
  62. KAFKA_SSL_KEYSTORE_FILENAME: kafka.keystore.jks
  63. KAFKA_SSL_KEYSTORE_CREDENTIALS: creds
  64. KAFKA_SSL_KEY_CREDENTIALS: creds
  65. KAFKA_SSL_TRUSTSTORE_FILENAME: kafka.truststore.jks
  66. KAFKA_SSL_TRUSTSTORE_CREDENTIALS: creds
  67. #KAFKA_SSL_CLIENT_AUTH: 'required'
  68. KAFKA_SSL_CLIENT_AUTH: 'requested'
  69. KAFKA_SSL_ENDPOINT_IDENTIFICATION_ALGORITHM: '' # COMMON NAME VERIFICATION IS DISABLED SERVER-SIDE
  70. volumes:
  71. - ./scripts/update_run.sh:/tmp/update_run.sh
  72. - ./ssl/creds:/etc/kafka/secrets/creds
  73. - ./ssl/kafka.truststore.jks:/etc/kafka/secrets/kafka.truststore.jks
  74. - ./ssl/kafka.keystore.jks:/etc/kafka/secrets/kafka.keystore.jks
  75. 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'"
  76. schemaregistry0:
  77. image: confluentinc/cp-schema-registry:7.2.1
  78. depends_on:
  79. - kafka0
  80. environment:
  81. SCHEMA_REGISTRY_KAFKASTORE_BOOTSTRAP_SERVERS: SSL://kafka0:29092
  82. SCHEMA_REGISTRY_KAFKASTORE_SECURITY_PROTOCOL: SSL
  83. SCHEMA_REGISTRY_KAFKASTORE_SSL_TRUSTSTORE_LOCATION: /kafka.truststore.jks
  84. SCHEMA_REGISTRY_KAFKASTORE_SSL_TRUSTSTORE_PASSWORD: secret
  85. SCHEMA_REGISTRY_KAFKASTORE_SSL_KEYSTORE_LOCATION: /kafka.keystore.jks
  86. SCHEMA_REGISTRY_KAFKASTORE_SSL_KEYSTORE_PASSWORD: secret
  87. SCHEMA_REGISTRY_KAFKASTORE_SSL_KEY_PASSWORD: secret
  88. SCHEMA_REGISTRY_HOST_NAME: schemaregistry0
  89. SCHEMA_REGISTRY_LISTENERS: https://schemaregistry0:8085
  90. SCHEMA_REGISTRY_INTER_INSTANCE_PROTOCOL: https
  91. SCHEMA_REGISTRY_SCHEMA_REGISTRY_INTER_INSTANCE_PROTOCOL: "https"
  92. SCHEMA_REGISTRY_LOG4J_ROOT_LOGLEVEL: INFO
  93. SCHEMA_REGISTRY_KAFKASTORE_TOPIC: _schemas
  94. SCHEMA_REGISTRY_SSL_CLIENT_AUTHENTICATION: "REQUIRED"
  95. SCHEMA_REGISTRY_SSL_TRUSTSTORE_LOCATION: /kafka.truststore.jks
  96. SCHEMA_REGISTRY_SSL_TRUSTSTORE_PASSWORD: secret
  97. SCHEMA_REGISTRY_SSL_KEYSTORE_LOCATION: /kafka.keystore.jks
  98. SCHEMA_REGISTRY_SSL_KEYSTORE_PASSWORD: secret
  99. SCHEMA_REGISTRY_SSL_KEY_PASSWORD: secret
  100. ports:
  101. - 8085:8085
  102. volumes:
  103. - ./ssl/kafka.truststore.jks:/kafka.truststore.jks
  104. - ./ssl/kafka.keystore.jks:/kafka.keystore.jks
  105. kafka-connect0:
  106. image: confluentinc/cp-kafka-connect:7.2.1
  107. ports:
  108. - 8083:8083
  109. depends_on:
  110. - kafka0
  111. - schemaregistry0
  112. environment:
  113. CONNECT_BOOTSTRAP_SERVERS: kafka0:29092
  114. CONNECT_GROUP_ID: compose-connect-group
  115. CONNECT_CONFIG_STORAGE_TOPIC: _connect_configs
  116. CONNECT_CONFIG_STORAGE_REPLICATION_FACTOR: 1
  117. CONNECT_OFFSET_STORAGE_TOPIC: _connect_offset
  118. CONNECT_OFFSET_STORAGE_REPLICATION_FACTOR: 1
  119. CONNECT_STATUS_STORAGE_TOPIC: _connect_status
  120. CONNECT_STATUS_STORAGE_REPLICATION_FACTOR: 1
  121. CONNECT_KEY_CONVERTER: org.apache.kafka.connect.storage.StringConverter
  122. CONNECT_KEY_CONVERTER_SCHEMA_REGISTRY_URL: https://schemaregistry0:8085
  123. CONNECT_VALUE_CONVERTER: org.apache.kafka.connect.storage.StringConverter
  124. CONNECT_VALUE_CONVERTER_SCHEMA_REGISTRY_URL: https://schemaregistry0:8085
  125. CONNECT_INTERNAL_KEY_CONVERTER: org.apache.kafka.connect.json.JsonConverter
  126. CONNECT_INTERNAL_VALUE_CONVERTER: org.apache.kafka.connect.json.JsonConverter
  127. CONNECT_REST_ADVERTISED_HOST_NAME: kafka-connect0
  128. CONNECT_PLUGIN_PATH: "/usr/share/java,/usr/share/confluent-hub-components"
  129. CONNECT_SECURITY_PROTOCOL: "SSL"
  130. CONNECT_SSL_KEYSTORE_LOCATION: "/kafka.keystore.jks"
  131. CONNECT_SSL_KEY_PASSWORD: "secret"
  132. CONNECT_SSL_KEYSTORE_PASSWORD: "secret"
  133. CONNECT_SSL_TRUSTSTORE_LOCATION: "/kafka.truststore.jks"
  134. CONNECT_SSL_TRUSTSTORE_PASSWORD: "secret"
  135. CONNECT_SSL_CLIENT_AUTH: "requested"
  136. CONNECT_REST_ADVERTISED_LISTENER: "https"
  137. CONNECT_LISTENERS: "https://kafka-connect0:8083"
  138. volumes:
  139. - ./ssl/kafka.truststore.jks:/kafka.truststore.jks
  140. - ./ssl/kafka.keystore.jks:/kafka.keystore.jks