记录docker下kafka公网端口映射访问

需求

公司内网kafka需要外部访问,通过外网端口映射到kakfa内网某个端口

软件

docker下部署的kafka,使用镜像为:confluentinc/cp-kafka

网络:

CLIENT
公司外网 IP1:10001
防火墙-交换机
公司内网KAFKA IP2:10002

公司外网和内网映射:IP1:10001—>IP2:10002

kakfa内网ip为IP2

实现

kafka核心配置如下:(IP1,IP2对应各自内外网ip)

kafka:
    image: confluentinc/cp-kafka
    ports:
      - 10002:10002    #外网访问端口
      - 9093:9093     #内网访问端口
    environment:
           # LISTENERS
			KAFKA_LISTENERS: INTERNAL://:9093,EXTERNAL://:10002
			# ADVERTISED_LISTENERS
			KAFKA_ADVERTISED_LISTENERS: INTERNAL://{IP2}:9093,EXTERNAL://{IP1}:10001
			KAFKA_INTER_BROKER_LISTENER_NAME: INTERNAL
			KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: INTERNAL:SASL_PLAINTEXT,EXTERNAL:SASL_PLAINTEXT

listeners就是主要用来定义Kafka Broker的Listener的配置项。

advertised.listeners参数的作用就是将Broker的Listener信息发布到Zookeeper中,供Clients(Producer/Consumer)使用。如果配置了advertised.listeners,那么就不会将listeners配置的信息发布到Zookeeper中去了

可以参考此文章Kafka从上手到实践-Kafka集群:Kafka Listeners,其实具体还是不理解。

疑问

  • advertised.listeners 和listeners具体关系
  • kafka 启动流程,以及producer连接流程
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值