4

我想用cargo-wasi编译以下代码。

// reqwest = { version = "0.11", features = ["json"] }
// tokio = { version = "1", features = ["full"] }

use std::collections::HashMap;

#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    let resp = reqwest::get("https://httpbin.org/ip")
        .await?
        .json::<HashMap<String, String>>()
        .await?;
    println!("{:#?}", resp);
    Ok(())
}

尝试编译后出现以下错误,因为mio目前不支持WASI

$ cargo wasi run
   Compiling mio v0.7.9
   Compiling parking_lot v0.11.1
   Compiling serde_json v1.0.64
   Compiling idna v0.2.2
error[E0432]: unresolved import `crate::sys::IoSourceState`
  --> /home/ducaale/.cargo/registry/src/github.com-1ecc6299db9ec823/mio-0.7.9/src/io_source.rs:12:5
   |
12 | use crate::sys::IoSourceState;
   |     ^^^^^^^^^^^^^^^^^^^^^^^^^ no `IoSourceState` in `sys`
... errors omitted

我做了一些研究,到目前为止我发现的例子都没有使用 async/await。有什么我可以替换tokio的东西,所以我的代码可以在 WASI 中编译吗?

4

1 回答 1

3

我尝试运行它,似乎 reqwests crate 无法使用 cargo wasi 或 wasm-pack 正确构建,因为它无法编译 mio(在本地编译时由 tokio 使用)。github上有一些提到reqwests可以与wasm一起使用,但它还没有完全支持,我找不到太多关于如何使它工作的信息。听起来目前 WASI 上的 HTTP 请求还没有太多解决方案,但是 web-sys 可以用于通过 Node.js 或浏览器发出请求。

似乎 tokio 需要特定的功能标志才能与 Web 组装一起使用。这个问题在底部提到了同步和 rt 标志:https ://github.com/tokio-rs/tokio/issues/1597但为了也使用#[tokio:main],你需要“rt-multi -thread”和“宏”功能标志也是如此。

也可以使用 wasm bindgen 将未来转换为承诺,但这可能不适用于 WASI:https ://rustwasm.github.io/wasm-bindgen/api/wasm_bindgen_futures/

于 2021-03-10T23:59:58.547 回答