gpt4 book ai didi

rust - 在闭包内共享连接池

转载 作者:行者123 更新时间:2023-12-03 11:44:16 24 4
gpt4 key购买 nike

我有以下代码:

#[async_std::main]
async fn main() -> tide::Result<()> {
let mut app = tide::new();

let pool = MySqlPoolOptions::new()
.max_connections(500)
.connect(&"mysql://root:root@127.0.0.1/test").await?;


app.at("/").get(|_req: Request<()>| async move {
let row: (i64,) = sqlx::query_as("select sleep(FLOOR(RAND()*10)) as s")
.fetch_one(&pool).await?;

Ok(Body::from_json(&row)?)
});
但是rust编译器提示 closure is FnOnce because it moves the variable pool out of its environment。据我了解,这是一个由于借阅检查器而引起的问题:

通过将 pool传递给闭包并在闭包上使用 move语义来实现
  • ,我是说我希望将引用的变量移至闭包

  • 我的问题是:将 sqlx连接池设施与此类代码一起使用的正确方法是什么?这是我的第一个防 rust 程序,所以我还不太了解借位检查器

    最佳答案

    您应该使用应用程序状态并在其中存储池,这是example如何在请求处理程序中设置和使用状态

    关于rust - 在闭包内共享连接池,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65117107/

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