server - Rust echo 服务器和客户端使用 futures 永远阻塞自己

标签 server client rust echo

我用了this code对于服务器,修改了this tutorial对于客户端代码。当客户端连接到服务器时,它会永远阻止自己。

服务器:

extern crate futures;
extern crate futures_io;
extern crate futures_mio;

use std::net::SocketAddr;

use futures::Future;
use futures_io::{copy, TaskIo};
use futures::stream::Stream;

fn main() {
    let addr = "127.0.0.1:8080".parse::<SocketAddr>().unwrap();

    let mut l = futures_mio::Loop::new().unwrap();

    let server = l.handle().tcp_listen(&addr);

    let done = server.and_then(move |socket| {
        println!("Listening on: {}", addr);

        socket.incoming().for_each(|(socket, addr)| {
            let io = TaskIo::new(socket);
            let pair = io.map(|io| io.split());
            let amt = pair.and_then(|(reader, writer)| {
                copy(reader, writer)
            });
            amt.map(move |amt| {
                println!("wrote {} bytes to {}", amt, addr)
            }).forget();

            Ok(())
        })
    });
    l.run(done).unwrap();
}

客户:

extern crate futures;
extern crate futures_io;
extern crate futures_mio;

use std::net::SocketAddr;

use futures::Future;
use futures_mio::Loop;

fn main() {
    let mut lp = Loop::new().unwrap();
    let addr = "127.0.0.1:8080".parse::<SocketAddr>().unwrap();

    let socket = lp.handle().tcp_connect(&addr);

    let request = socket.and_then(|socket| {
        futures_io::write_all(socket, b"Hello!")
    });

    let response = request.and_then(|(socket, _)| {
        futures_io::read_to_end(socket, Vec::new())
    });

    let data = lp.run(response).unwrap();
    println!("{}", String::from_utf8_lossy(&data));
}

最佳答案

问题与 future 无关。你有一个打开的套接字,你要求“读到最后”。 什么决定结束?在这种情况下,是关闭套接字的时间;那是什么时候?

技巧问题!

  • 当服务器的写套接字关闭时,客户端的读套接字也关闭。
  • 服务器的写套接字在服务器的读套接字关闭时关闭。
  • 当客户端的写套接字关闭时,服务器的读套接字也关闭。

那什么时候发生呢?因为没有专门执行此操作的代码,所以当套接字被删除时它将关闭,所以:

  • 客户端的写套接字在客户端结束时关闭。

因此陷入僵局。可以通过显式关闭套接字的写入部分来解决此问题:

let response = request.and_then(|(socket, _)| {
    socket.shutdown(std::net::Shutdown::Write).expect("Couldn't shut down");
    read_to_end(socket, Vec::new())
});

关于server - Rust echo 服务器和客户端使用 futures 永远阻塞自己,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39049365/

相关文章:

rust - Rust 中的共享循环引用

http - 为什么这个 go http 服务器在多次请求后停止响应?

html - Express.js 不发送 css 文件

java - 使用php将base64图像从android上传到服务器时出错

windows - 带有 "autopush"的 Git 客户端?

rust - 在 Rust 的宏中创建闭包环境

javascript - Python 服务器 Websocket 握手响应

java - DataInputStream read() 总是返回 -1

javascript - 在客户端运行 runat=server

rust - 从枚举中访问元组