gpt4 book ai didi

sockets - Unix Domain Socket Server 仅在客户端关闭时打印消息

转载 作者:行者123 更新时间:2023-12-03 11:36:37 25 4
gpt4 key购买 nike

这个问题在这里已经有了答案:





Reading from a TcpStream with Read::read_to_string hangs until the connection is closed by the remote end

(1 个回答)


1年前关闭。




我正在尝试在 Rust 中实现一个 Unix 域套接字服务器,它允许客户端连接,然后客户端通过套接字发送消息,服务器打印它。但是,在我关闭(CTLR + C)客户端进程之前,服务器不会打印消息。问题可能是什么?这是两个代码:
服务器:

use std::thread;
use std::os::unix::net::{UnixStream, UnixListener};
use std::io::prelude::*;
use std::io::{BufRead, BufReader};

fn main() {
let listener = UnixListener::bind("/tmp/socket.sock").unwrap();

for stream in listener.incoming() {
match stream {
Ok(mut stream) => {
println!("Client connected!");
thread::spawn(move || {
let mut out = String::new();
let mut bf = BufReader::new(stream);
bf.read_line(&mut out);
println!("{}", out);
});
} Err(err) => {
println!("Connection failed!");
break;
}
}
}
println!("Hello, world!");
}
客户:
use std::os::unix::net::{UnixStream, UnixListener};
use std::io::prelude::*;
use std::io::{BufWriter};

fn main() {
let mut stream = UnixStream::connect("/tmp/socket.sock").unwrap();
let mut bf = BufWriter::new(&stream);

bf.write_all("Hello server".as_bytes());
bf.flush();
drop(bf);
}
我也尝试使用 read_to_string 方法,但它只是在客户端关闭之前不会打印。有谁知道问题是什么?

最佳答案

bf.read_line(&mut out);
您的读取代码读取行。但是您的发送代码不会发送一行。因此,读取的代码继续尝试按照您的要求读取一行。当连接关闭时,读取的代码不能再尝试读取一行,所以它返回。
您必须在双方都实现相同的协议(protocol)。如果读者将行结尾理解为消息边界,那么编写者必须在您希望接收代码理解消息结束的每个点处放置一个行结尾。
顺便说一句,记录您要在网络协议(protocol)之上分层的任何协议(protocol)确实是一个好主意,至少在您获得更多经验之前是这样。这样就可以避免这种错误。协议(protocol)要么会说消息由行组成,要么会说它们由其他内容组成,这将明确哪一方是错误的,哪一方是正确的。
像现在这样,任何一方都没有对错。他们只是不同意。适当的协议(protocol)文档可以完全避免这些错误。这两个程序用于相互通信的协议(protocol)是基于线路的吗?或不?你需要文件才能知道。值得努力记录。

关于sockets - Unix Domain Socket Server 仅在客户端关闭时打印消息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65148329/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com