当前位置: 首页 > 知识库问答 >
问题:

如何修复Rust中资源暂时不可用错误?

长孙阳成
2023-03-14

以下是错误日志

note: Run with `RUST_BACKTRACE=1` environment variable to display a backtrace.
        thread 'arbiter:724dcce3-b3b3-4523-8b02-3b2e9fa035dd:actix-net-worker-62' panicked at 'called `Result::unwrap()` on an `Err` value: Os { code: 11, kind: WouldBlock, message: "Resource temporarily unavailable" }', src/libcore/result.rs:997:5
let _ = server::new(move || {
        App::with_state()
            // Enable logger
            .middleware(middleware::Logger::default())
            .resource("/default", |r| HttpResponse::Ok)
    })
    .bind(&localhost_port)
    .unwrap_or_else(|_| panic!("Can not bind to {}", &localhost_port))
    .start();
.shutdown_timeout(0)    // <- Set shutdown timeout to 0 seconds (default 60s)

这里有一个相关的问题:https://stackoverflow.com/a/14370767,它建议使用SO_SNDTIMEO套接字选项设置发送超时。

共有1个答案

葛宪
2023-03-14

您的问题与Rust(或Actix)无关。您的问题是,其他一些程序已经在您试图绑定到的同一个端口上侦听。您需要识别它是哪个程序,例如:

sudo netstat -an --program | grep $PORT

(用端口号替换$port),然后关闭该程序或使用其他端口。

 类似资料:
  • 我正在用c语言(使用openwrt作为操作系统)构建一个项目,将文件上载到FTP服务器。我对传入的数据使用MQTT。因此,对于我订阅的每个主题,我都会保存这些数据,然后将其上载到FTP服务器,为了使事情顺利进行,每次需要上载文件时,我都会使用一个线程来完成这项工作。为了确保程序不会运行太多线程,允许每个主题创建一个线程。我使用了一个变量(比如mutex,但它不是pthread\u mutex\t,

  • 我在C中使用tcp套接字服务器和客户端。使用AF_INET、SOCK_STREAM和IPPROTO_TCP 在sock send()命令上有一个可能导致“资源暂时不可用”的帖子,其中Davide Berra说 这是因为您使用的是非阻塞套接字,并且输出缓冲区已满。 从send()手册页

  • 创建套接字 使其非阻塞 呼叫连接 按预期返回-1和errno EINPROGRESS 调用select 返回>0,因此已建立连接 再次阻塞套接字 此部件的代码如下: 那还行。但是我有一个循环,在这个循环中我调用了一个函数,该函数检查是否收到了要读取的新数据包:

  • 我有一个伪终端从机,它给我一个资源暂时不可用的读/写错误(11)。我一直无法解决这个问题,但直到一周前我还不知道任何事情。所以,我可能漏掉了一些明显的东西。 根据我所了解的情况,这可能是由对非阻塞PTY调用引起的。但是,当我检查从pty的I之后的时,该值显示它是一个阻塞文件描述符。 我甚至尝试将视为非阻塞文件,使用来确定它何时就绪。但是,它只是每次都超时。 那么,如果设置为blocking,为什么

  • 我在使用和PhantomJS驱动程序运行单元测试时遇到了一个问题。它似乎与PhantomJS进程中的stderr/stdout的资源争用有关。错误是: 更多详细信息请参见:https://gist.github.com/lucaswiman/9788422 null

  • 我试图让父进程在父进程继续之前等待多个子进程发出信号,使用未命名信号量数组(每个子进程一个信号量)。但是,当使用sem_wait()时,父进程将无限期地等待,而sem_trywait()返回“资源暂时不可用”错误,并在子进程没有发出信号的情况下继续。sem_init()和sem_post()都不返回错误。 编辑以添加:sem_wait()遇到错误,无论子进程在等待之前还是之后调用sem_post(