TIPC消息阻塞丢包最多显示981行问题解决

本文介绍了TIPC在信息回显过程中出现的消息丢失问题及其原因。深入探讨了TIPC Socket的拥塞管理设置方法,包括不同优先级的设定及拥塞控制选项,并提供了具体的解决措施。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、现象
TIPC用于信息回显,A进程连续发送成功,B进程接收最多981条,其他全部无法select到,后续消息被丢弃;

2、原因
TIPC的Socket可以在Bind前通过setsockopt()函数进行设置拥塞管理,其参数如下:
setsockopt(int sockfd, int level, int optname, const void *optval, socklen_t optlen);
当level为SOL_TIPC,也就是使用tipc时,optname有如下值可以选择:
1)TIPC_IMPORTANCE
这个值用来标识本Socket消息的重要性,设置为重要时本Socket在发生拥塞时,消息丢失的可能性很小,默认级别是TIPC_LOW_IMPORTANCE,即发送拥塞消息丢弃。
TIPC_LOW_IMPORTANCE, 低优先级
TIPC_MEDIUM_IMPORTANCE, 中优先级
TIPC_HIGH_IMPORTANCE 高优先级
TIPC_CRITICAL_IMPORTANCE. 紧急优先级

3、解决办法
TIPC连续最多回显981行消息就阻塞丢弃问题,修改方法如下:
在这里插入图片描述

4、其他拥塞管理选项
1)TIPC_SRC_DROPPABLE
同样是作为拥塞控制,如果设置为此值,则在拥塞发生时,TIPC会丢弃消息,否则,将把消息放入队列缓存。

默认情况下: 对SOCK_SEQPACKET, SOCK_STREAM, SOCK_RDM 三种传输方式,也就是可靠链接则将消息缓存,对SOCK_DGRAM,也就是不可靠链接则将消息丢弃。

2)TIPC_DEST_DROPPABLE
仍然为拥塞控制服务。针对下面三种情况有用,消息不能发送到目的地址,或者目的地址不存在,或者目的地址发生了拥塞。如果使能这个功能,在发生以上三种情况是,消息将被丢弃,否则会将消息返回给发送者。

默认情况下:SOCK_SEQPACKET ,SOCK_STREAM两种传输方式,返回给发送者。对SOCK_RDM和SOCK_DGRAM则将消息丢弃。这样做的目的是在使用面向链接的情况下发生通信失败时进行合适的处理,同时不增加面向无链接的情况下通信失败的处理的复杂性。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值