【mio】TCP 服务器(一)

环境

  • Time 2022-01-07
  • Rust 1.57.0
  • mio 0.8

概念

参考:https://github.com/tokio-rs/mio/blob/master/examples/tcp_server.rs

mio 是跨平台的非阻塞 IO 库,在其它平台实现类似 linux 下 epoll 的的特性。
实现一个 TCP 服务器,先编写绑定端口和获取连接的客户端信息的逻辑。

示例

Cargo.toml

[package]
edition = "2021"
name = "game"
version = "0.1.0"

[dependencies]
mio = {version = "*", features = ["os-poll", "net"]}

绑定 IP 和端口

let addr = "127.0.0.1:4444".parse().unwrap();
let mut server = TcpListener::bind(addr)?;

监听 epoll 事件

let mut poll = Poll::new()?;
let mut events = Events::with_capacity(128);
poll.registry()
    .register(&mut server, SERVER, Interest::READABLE)?;

事件循环

loop {
    poll.poll(&mut events, None)?;
    for _event in events.iter() {
        match server.accept() {
            Ok((_, address)) => {
                println!("客户端: {}", address);
            }
            Err(e) => return Err(e),
        };
    }
}

使用 nc 命令访问

nc 127.0.0.1 4444
客户端: 127.0.0.1:55348

总结

使用 mio 编写 TCP 服务器,可以正确监听端口,并且获取到客户端的信息。

附录

完整代码

use mio::{net::TcpListener, Events, Interest, Poll, Token};
use std::io;

const SERVER: Token = Token(0);
fn main() -> io::Result<()> {
    let addr = "127.0.0.1:4444".parse().unwrap();
    let mut server = TcpListener::bind(addr)?;

    let mut poll = Poll::new()?;
    let mut events = Events::with_capacity(128);
    poll.registry()
        .register(&mut server, SERVER, Interest::READABLE)?;

    loop {
        poll.poll(&mut events, None)?;
        for _event in events.iter() {
            match server.accept() {
                Ok((_, address)) => {
                    println!("客户端: {}", address);
                }
                Err(e) => return Err(e),
            };
        }
    }
}
posted @   jiangbo4444  阅读(194)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
点击右上角即可分享
微信分享提示