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。