python 发送图像数据时需要注意的地方

tcp 发送时判断连接是否断开的写法

 s = socket(AF_INET, SOCK_STREAM)
 if not s.recv(0): # 用s.recv(0)这句判断是否连接
       s.connect(ipport)

udp发送数据

>udp包最大只能是65535字节,所以要拆包发送
tcp 发送数据,要自己处理粘包问题

如果用kafka发送图像 数据

图像数据太大是无法发送成功的 必须修改几处地方

  • kafka 服务端的配置文件需要配置的参数
    message.max.bytes =
    kafka 会接收单个消息size的最大限制, 默认为1M左右。如果producer发送比这个大的消息,kafka默认会丢掉。producer可以从callback函数中获得错误码:10。
  • log.segment.bytes =
    kafka数据文件的大小。默认为1G, 需要确保此值大于一个消息的最大大小。
  • replica.fetch.max.bytes =
    broker可复制的消息的最大字节数, 默认为1M。这个值应该比message.max.bytes大,否则broker会接收此消息,但无法将此消息复制出去,从而造成数据丢失。
  • producer端
    message.max.bytes,
    要设置大于发送最大数据的大小,否则会produce失败。
  • consumer端
    receive.message.max.bytes :
    kafka 协议response 的最大长度,应该保证次参数大于等于message.max.bytes。否则消费会失败。
    另外,还需要注意一个问题,版本过低的librdkafka的receive.message.max.bytes只支持1000到1000000000。目前最新版本的可以支持到2147483647。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值