kafka-ssl.yml 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  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. - kafka
  11. environment:
  12. KAFKA_CLUSTERS_0_NAME: local
  13. KAFKA_CLUSTERS_0_PROPERTIES_SECURITY_PROTOCOL: SSL
  14. KAFKA_CLUSTERS_0_BOOTSTRAPSERVERS: kafka:29092 # SSL LISTENER!
  15. KAFKA_CLUSTERS_0_PROPERTIES_SSL_TRUSTSTORE_LOCATION: /kafka.truststore.jks
  16. KAFKA_CLUSTERS_0_PROPERTIES_SSL_TRUSTSTORE_PASSWORD: secret
  17. KAFKA_CLUSTERS_0_PROPERTIES_SSL_KEYSTORE_LOCATION: /kafka.keystore.jks
  18. KAFKA_CLUSTERS_0_PROPERTIES_SSL_KEYSTORE_PASSWORD: secret
  19. KAFKA_CLUSTERS_0_PROPERTIES_SSL_ENDPOINT_IDENTIFICATION_ALGORITHM: '' # DISABLE COMMON NAME VERIFICATION
  20. volumes:
  21. - ./ssl/kafka.truststore.jks:/kafka.truststore.jks
  22. - ./ssl/kafka.keystore.jks:/kafka.keystore.jks
  23. kafka:
  24. image: confluentinc/cp-kafka:7.2.1
  25. hostname: kafka
  26. container_name: kafka
  27. ports:
  28. - "9092:9092"
  29. - "9997:9997"
  30. environment:
  31. KAFKA_BROKER_ID: 1
  32. KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: 'CONTROLLER:PLAINTEXT,SSL:SSL,PLAINTEXT_HOST:PLAINTEXT'
  33. KAFKA_ADVERTISED_LISTENERS: 'SSL://kafka:29092,PLAINTEXT_HOST://localhost:9092'
  34. KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 1
  35. KAFKA_GROUP_INITIAL_REBALANCE_DELAY_MS: 0
  36. KAFKA_TRANSACTION_STATE_LOG_MIN_ISR: 1
  37. KAFKA_TRANSACTION_STATE_LOG_REPLICATION_FACTOR: 1
  38. KAFKA_JMX_PORT: 9997
  39. KAFKA_JMX_HOSTNAME: localhost
  40. KAFKA_PROCESS_ROLES: 'broker,controller'
  41. KAFKA_NODE_ID: 1
  42. KAFKA_CONTROLLER_QUORUM_VOTERS: '1@kafka:29093'
  43. KAFKA_LISTENERS: 'SSL://kafka:29092,CONTROLLER://kafka:29093,PLAINTEXT_HOST://0.0.0.0:9092'
  44. KAFKA_INTER_BROKER_LISTENER_NAME: 'SSL'
  45. KAFKA_CONTROLLER_LISTENER_NAMES: 'CONTROLLER'
  46. KAFKA_LOG_DIRS: '/tmp/kraft-combined-logs'
  47. KAFKA_SECURITY_PROTOCOL: SSL
  48. KAFKA_SSL_ENABLED_MECHANISMS: PLAIN,SSL
  49. KAFKA_SSL_KEYSTORE_FILENAME: kafka.keystore.jks
  50. KAFKA_SSL_KEYSTORE_CREDENTIALS: creds
  51. KAFKA_SSL_KEY_CREDENTIALS: creds
  52. KAFKA_SSL_TRUSTSTORE_FILENAME: kafka.truststore.jks
  53. KAFKA_SSL_TRUSTSTORE_CREDENTIALS: creds
  54. #KAFKA_SSL_CLIENT_AUTH: 'required'
  55. KAFKA_SSL_CLIENT_AUTH: 'requested'
  56. KAFKA_SSL_ENDPOINT_IDENTIFICATION_ALGORITHM: '' # COMMON NAME VERIFICATION IS DISABLED SERVER-SIDE
  57. volumes:
  58. - ./scripts/update_run.sh:/tmp/update_run.sh
  59. - ./ssl/creds:/etc/kafka/secrets/creds
  60. - ./ssl/kafka.truststore.jks:/etc/kafka/secrets/kafka.truststore.jks
  61. - ./ssl/kafka.keystore.jks:/etc/kafka/secrets/kafka.keystore.jks
  62. 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'"