rust学习(tokio中tcp_stream调用的问题)

问题:

我们涉及了一个socket连接的类,每次收到数据以后,我们都会把tokio::net::TcpStream对应的tcp_stream传递给其他线程。

起初设计如下:

rust 复制代码
pub struct TarNetStream {
    stream:TcpStream, //1
    ...
}

pub trait TarListener {
    fn on_event(&self,event:Event,data:Option<Vec<u8>>,stream:Arc<Box<TarNetStream>>); //2
}

1.stream直接move给TarNetStream

2.回调函数中采用了Arc智能指针

问题1:由于stream被move了,所以多线程编译会直接报错。

改进1:将成员变量变成Arc>(由于stream的read/write都需要mut权限,所以这里需要用refcell)

rust 复制代码
pub struct TarNetStream {
   stream:Arc<RefCell<TcpStream>>,
}

问题2:正常都能使用,但是多线程调用的时候会提示Refcell不能再多线程中使用

改进2:添加mutex锁

rust 复制代码
pub struct TarNetStream {
   stream:Arc<tokio::sync::Mutex<RefCell<TcpStream>>>,
}

问题3:运行直接卡死。原因如下:

rust 复制代码
线程1运行读:
let obj = stream.lock().await;
let result = obj.try_borrow_mut().unwrap().read(&mut buf).await;//1

线程2运行写:
let obj = stream.lock().await;//2
let result = obj.try_borrow_mut().unwrap().write(buf).await;

1.没有数据,这里卡死

2.由于线程1一直在等数据,所以线程2只能在这里2处卡住。

改进4:读写分离

rust 复制代码
pub struct TarNetStream<'a>'> {
    //stream:Arc<RefCell<TcpStream>>,
    read_stream:tokio::sync::Mutex<tokio::net::tcp::ReadHalf<'a'>>>,
    write_stream:tokio::sync::Mutex<WriteHalf<'a'>>>,
    ...
}

问题4:异步线程调用时候编译提示生命周期有问题,应该是ReadHalf/WriteHalf里面存放的是stream的引用,多线程情况下会出现问题,所以直接编译报错?

改进4:移除生命周期,采用OwnerReadHalf/WriteHalf

rust 复制代码
pub struct TarNetStream {
    //stream:Arc<RefCell<TcpStream>>,
    read_stream:tokio::sync::Mutex<tokio::net::tcp::OwnedReadHalf>,
    write_stream:tokio::sync::Mutex<OwnedWriteHalf>,
    ...
}

备考:

如果需要使用OwnedWriteHalf/OwnedReadHalf,需要类似如下的调用:

相关推荐
胖咕噜的稞达鸭7 分钟前
网络基础:初识TCP/IP协议
网络·网络协议·tcp/ip
全栈工程师修炼指南19 分钟前
Nginx | stream content 阶段:UDP 协议四层反向代理浅析与实践
运维·网络·网络协议·nginx·udp
cur1es40 分钟前
【UDP的报文结构】
网络·网络协议·udp·md5
闲人编程1 小时前
使用FastAPI和WebSocket构建高性能实时聊天系统
websocket·网络协议·网络编程·fastapi·持久化·实时聊天·codecapsule
惊讶的猫1 小时前
OpenFeign(声明式HTTP客户端)
网络·网络协议·http·微服务·openfeign
野犬寒鸦2 小时前
从零起步学习并发编程 || 第七章:ThreadLocal深层解析及常见问题解决方案
java·服务器·开发语言·jvm·后端·学习
陈桴浮海2 小时前
【Linux&Ansible】学习笔记合集二
linux·学习·ansible
心.c2 小时前
TCP协议深入解析
网络·网络协议·tcp/ip
摇滚侠2 小时前
HTTP 404 - No response body available
网络·网络协议·http
全栈工程师修炼指南2 小时前
Nginx | stream content 阶段:TCP 协议四层反向代理浅析与实践
运维·网络·网络协议·tcp/ip·nginx