From d8fd5d3ec6200c4362c6932b70e4be0eccc2dea2 Mon Sep 17 00:00:00 2001 From: Noel Kwan Date: Fri, 1 Nov 2024 10:28:56 +0800 Subject: [PATCH 1/4] update Cargo.toml to use madsim-tokio --- Cargo.toml | 5 +++-- examples/mysql/todos/Cargo.toml | 2 +- examples/postgres/axum-social-with-tests/Cargo.toml | 2 +- examples/postgres/chat/Cargo.toml | 2 +- examples/postgres/files/Cargo.toml | 2 +- examples/postgres/json/Cargo.toml | 2 +- examples/postgres/listen/Cargo.toml | 2 +- examples/postgres/mockable-todos/Cargo.toml | 2 +- examples/postgres/todos/Cargo.toml | 2 +- examples/postgres/transaction/Cargo.toml | 2 +- examples/sqlite/todos/Cargo.toml | 2 +- sqlx-cli/Cargo.toml | 2 +- sqlx-core/Cargo.toml | 3 +-- sqlx-sqlite/Cargo.toml | 2 +- sqlx-test/Cargo.toml | 2 +- 15 files changed, 17 insertions(+), 17 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index 79e8ff3882..ad368fffcc 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -151,8 +151,9 @@ dotenvy = { version = "0.15.0", default-features = false } version = "1.12" [workspace.dependencies.tokio] -version = "1" -features = ["time", "net", "sync", "fs", "io-util", "rt"] +version = "0.2.30" +package = "madsim-tokio" +features = ["time", "net", "sync", "fs", "io-util", "rt", "macros", "rt-multi-thread"] default-features = false [dependencies] diff --git a/examples/mysql/todos/Cargo.toml b/examples/mysql/todos/Cargo.toml index cb0b59a63b..f9ae20e79f 100644 --- a/examples/mysql/todos/Cargo.toml +++ b/examples/mysql/todos/Cargo.toml @@ -9,4 +9,4 @@ anyhow = "1.0" futures = "0.3" sqlx = { path = "../../../", features = [ "mysql", "runtime-tokio", "tls-native-tls" ] } clap = { version = "4", features = ["derive"] } -tokio = { version = "1.20.0", features = ["rt", "macros"]} +tokio = { workspace = true, optional = true } \ No newline at end of file diff --git a/examples/postgres/axum-social-with-tests/Cargo.toml b/examples/postgres/axum-social-with-tests/Cargo.toml index 111b6ecac8..728fd4d0f4 100644 --- a/examples/postgres/axum-social-with-tests/Cargo.toml +++ b/examples/postgres/axum-social-with-tests/Cargo.toml @@ -9,7 +9,7 @@ edition = "2021" # Primary crates axum = { version = "0.5.13", features = ["macros"] } sqlx = { path = "../../../", features = [ "runtime-tokio", "tls-rustls-ring", "postgres", "time", "uuid" ] } -tokio = { version = "1.20.1", features = ["rt-multi-thread", "macros"] } +tokio = { workspace = true, optional = true } # Important secondary crates argon2 = "0.4.1" diff --git a/examples/postgres/chat/Cargo.toml b/examples/postgres/chat/Cargo.toml index cdeebcb611..438c3d4b82 100644 --- a/examples/postgres/chat/Cargo.toml +++ b/examples/postgres/chat/Cargo.toml @@ -7,7 +7,7 @@ workspace = "../../../" [dependencies] sqlx = { path = "../../../", features = [ "postgres", "runtime-tokio", "tls-native-tls" ] } futures = "0.3.1" -tokio = { version = "1.20.0", features = [ "rt-multi-thread", "macros" ] } +tokio = { workspace = true, optional = true } ratatui = "0.27.0" crossterm = "0.27.0" unicode-width = "0.1" diff --git a/examples/postgres/files/Cargo.toml b/examples/postgres/files/Cargo.toml index 5b9ac6bd49..9c68bd0452 100644 --- a/examples/postgres/files/Cargo.toml +++ b/examples/postgres/files/Cargo.toml @@ -8,5 +8,5 @@ edition = "2021" [dependencies] anyhow = "1.0" sqlx = { path = "../../../", features = [ "postgres", "runtime-tokio", "tls-native-tls" ] } -tokio = { version = "1.20.0", features = ["rt", "macros"]} +tokio = { workspace = true, optional = true } dotenvy = "0.15.0" diff --git a/examples/postgres/json/Cargo.toml b/examples/postgres/json/Cargo.toml index 5ddccede12..35b1cec7c5 100644 --- a/examples/postgres/json/Cargo.toml +++ b/examples/postgres/json/Cargo.toml @@ -12,4 +12,4 @@ serde = { version = "1", features = ["derive"] } serde_json = "1" sqlx = { path = "../../../", features = [ "runtime-tokio", "postgres", "json" ] } clap = { version = "4", features = ["derive"] } -tokio = { version = "1.20.0", features = ["rt", "macros"]} +tokio = { workspace = true, optional = true } diff --git a/examples/postgres/listen/Cargo.toml b/examples/postgres/listen/Cargo.toml index ce1d9153aa..cb36be5da5 100644 --- a/examples/postgres/listen/Cargo.toml +++ b/examples/postgres/listen/Cargo.toml @@ -7,4 +7,4 @@ workspace = "../../../" [dependencies] sqlx = { path = "../../../", features = [ "runtime-tokio", "postgres" ] } futures = "0.3.1" -tokio = { version = "1.20.0", features = ["rt-multi-thread", "macros", "time"]} +tokio = { workspace = true, optional = true } diff --git a/examples/postgres/mockable-todos/Cargo.toml b/examples/postgres/mockable-todos/Cargo.toml index 5d99ab90dc..aeeec88a2d 100644 --- a/examples/postgres/mockable-todos/Cargo.toml +++ b/examples/postgres/mockable-todos/Cargo.toml @@ -9,7 +9,7 @@ anyhow = "1.0" futures = "0.3" sqlx = { path = "../../../", features = [ "postgres", "runtime-tokio", "tls-native-tls" ] } clap = { version = "4", features = ["derive"] } -tokio = { version = "1.20.0", features = ["rt", "macros"]} +tokio = { workspace = true, optional = true } dotenvy = "0.15.0" async-trait = "0.1.41" mockall = "0.11" diff --git a/examples/postgres/todos/Cargo.toml b/examples/postgres/todos/Cargo.toml index 76a57b328c..0147536115 100644 --- a/examples/postgres/todos/Cargo.toml +++ b/examples/postgres/todos/Cargo.toml @@ -9,5 +9,5 @@ anyhow = "1.0" futures = "0.3" sqlx = { path = "../../../", features = [ "postgres", "runtime-tokio", "tls-native-tls" ] } clap = { version = "4", features = ["derive"] } -tokio = { version = "1.20.0", features = ["rt", "macros"]} +tokio = { workspace = true, optional = true } dotenvy = "0.15.0" diff --git a/examples/postgres/transaction/Cargo.toml b/examples/postgres/transaction/Cargo.toml index be91cb7ebf..9ad3ee530d 100644 --- a/examples/postgres/transaction/Cargo.toml +++ b/examples/postgres/transaction/Cargo.toml @@ -7,4 +7,4 @@ workspace = "../../../" [dependencies] sqlx = { path = "../../../", features = [ "postgres", "runtime-tokio", "tls-native-tls" ] } futures = "0.3.1" -tokio = { version = "1.20.0", features = ["rt-multi-thread", "macros"]} +tokio = { workspace = true, optional = true } diff --git a/examples/sqlite/todos/Cargo.toml b/examples/sqlite/todos/Cargo.toml index edc6831ae0..56b36b91f7 100644 --- a/examples/sqlite/todos/Cargo.toml +++ b/examples/sqlite/todos/Cargo.toml @@ -9,4 +9,4 @@ anyhow = "1.0" futures = "0.3" sqlx = { path = "../../../", features = [ "sqlite", "runtime-tokio", "tls-native-tls" ] } clap = { version = "4", features = ["derive"] } -tokio = { version = "1.20.0", features = ["rt", "macros"]} +tokio = { workspace = true, optional = true } \ No newline at end of file diff --git a/sqlx-cli/Cargo.toml b/sqlx-cli/Cargo.toml index 6ddc71de7c..2520670839 100644 --- a/sqlx-cli/Cargo.toml +++ b/sqlx-cli/Cargo.toml @@ -26,7 +26,7 @@ path = "src/bin/cargo-sqlx.rs" [dependencies] dotenvy = "0.15.0" -tokio = { version = "1.15.0", features = ["macros", "rt", "rt-multi-thread"] } +tokio = { workspace = true, optional = true } sqlx = { workspace = true, default-features = false, features = [ "runtime-tokio", "migrate", diff --git a/sqlx-core/Cargo.toml b/sqlx-core/Cargo.toml index 60f9573aae..86c91c7dfd 100644 --- a/sqlx-core/Cargo.toml +++ b/sqlx-core/Cargo.toml @@ -93,7 +93,6 @@ hashbrown = "0.14.5" [dev-dependencies] sqlx = { workspace = true, features = ["postgres", "sqlite", "mysql", "migrate", "macros", "time", "uuid"] } -tokio = { version = "1", features = ["rt"] } [lints] -workspace = true +workspace = true \ No newline at end of file diff --git a/sqlx-sqlite/Cargo.toml b/sqlx-sqlite/Cargo.toml index 1ad87de102..b2b289c695 100644 --- a/sqlx-sqlite/Cargo.toml +++ b/sqlx-sqlite/Cargo.toml @@ -27,7 +27,6 @@ regexp = ["dep:regex"] futures-core = { version = "0.3.19", default-features = false } futures-channel = { version = "0.3.19", default-features = false, features = ["sink", "alloc", "std"] } # used by the SQLite worker thread to block on the async mutex that locks the database handle -futures-executor = { version = "0.3.19" } futures-intrusive = "0.5.0" futures-util = { version = "0.3.19", default-features = false, features = ["alloc", "sink"] } @@ -48,6 +47,7 @@ tracing = { version = "0.1.37", features = ["log"] } serde = { version = "1.0.145", features = ["derive"], optional = true } regex = { version = "1.5.5", optional = true } +tokio = { workspace = true } [dependencies.libsqlite3-sys] version = "0.30.1" diff --git a/sqlx-test/Cargo.toml b/sqlx-test/Cargo.toml index af76d5562f..fe3f989071 100644 --- a/sqlx-test/Cargo.toml +++ b/sqlx-test/Cargo.toml @@ -11,4 +11,4 @@ dotenvy = "0.15.0" anyhow = "1.0.26" [lints] -workspace = true +workspace = true \ No newline at end of file From a890c40b5230dfb6ba9d897829ef8d9a42bccb6a Mon Sep 17 00:00:00 2001 From: Noel Kwan Date: Fri, 1 Nov 2024 10:29:28 +0800 Subject: [PATCH 2/4] cargo update tokio --- Cargo.lock | 348 ++++++++++++++++++++++++++++++++++++++++++++++------- 1 file changed, 307 insertions(+), 41 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index dcbc6d1519..cfd5060e25 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -35,6 +35,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e89da841a80418a9b391ebaea17f5c112ffaaa96f621d2c285b5174da76b9011" dependencies = [ "cfg-if", + "getrandom", "once_cell", "version_check", "zerocopy", @@ -311,6 +312,28 @@ dependencies = [ "wasm-bindgen-futures", ] +[[package]] +name = "async-stream" +version = "0.3.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0b5a71a6f37880a80d1d7f19efd781e4b5de42c88f0722cc13bcb6cc2cfe8476" +dependencies = [ + "async-stream-impl", + "futures-core", + "pin-project-lite", +] + +[[package]] +name = "async-stream-impl" +version = "0.3.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c7c24de15d275a1ecfd47a380fb4d5ec9bfe0933f309ed5e705b775596a3574d" +dependencies = [ + "proc-macro2", + "quote", + "syn 2.0.52", +] + [[package]] name = "async-task" version = "4.7.0" @@ -505,6 +528,15 @@ dependencies = [ "num-traits", ] +[[package]] +name = "bincode" +version = "1.3.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b1f45e9417d87227c7a56d22e471c6206462cba514c7590c09aff4cf6d1ddcad" +dependencies = [ + "serde", +] + [[package]] name = "bindgen" version = "0.69.4" @@ -514,7 +546,7 @@ dependencies = [ "bitflags 2.4.2", "cexpr", "clang-sys", - "itertools 0.10.5", + "itertools 0.12.1", "lazy_static", "lazycell", "log", @@ -1042,7 +1074,7 @@ dependencies = [ "bitflags 2.4.2", "crossterm_winapi", "libc", - "mio", + "mio 0.8.11", "parking_lot", "signal-hook", "signal-hook-mio", @@ -1074,14 +1106,38 @@ dependencies = [ "typenum", ] +[[package]] +name = "darling" +version = "0.14.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7b750cb3417fd1b327431a470f388520309479ab0bf5e323505daf0290cd3850" +dependencies = [ + "darling_core 0.14.4", + "darling_macro 0.14.4", +] + [[package]] name = "darling" version = "0.20.8" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "54e36fcd13ed84ffdfda6f5be89b31287cbb80c439841fe69e04841435464391" dependencies = [ - "darling_core", - "darling_macro", + "darling_core 0.20.8", + "darling_macro 0.20.8", +] + +[[package]] +name = "darling_core" +version = "0.14.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "109c1ca6e6b7f82cc233a97004ea8ed7ca123a9af07a8230878fcfda9b158bf0" +dependencies = [ + "fnv", + "ident_case", + "proc-macro2", + "quote", + "strsim 0.10.0", + "syn 1.0.109", ] [[package]] @@ -1098,13 +1154,24 @@ dependencies = [ "syn 2.0.52", ] +[[package]] +name = "darling_macro" +version = "0.14.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a4aab4dbc9f7611d8b55048a3a16d2d010c2c8334e46304b40ac1cc14bf3b48e" +dependencies = [ + "darling_core 0.14.4", + "quote", + "syn 1.0.109", +] + [[package]] name = "darling_macro" version = "0.20.8" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a668eda54683121533a393014d8692171709ff57a7d61f187b6e782719f8933f" dependencies = [ - "darling_core", + "darling_core 0.20.8", "quote", "syn 2.0.52", ] @@ -1187,6 +1254,12 @@ version = "0.11.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "1435fa1053d8b2fbbe9be7e97eca7f33d37b28409959813daefc1446a14247f1" +[[package]] +name = "downcast-rs" +version = "1.2.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "75b325c5dbd37f80359721ad39aca5a29fb04c89279657cffdda8736d0c0b9d2" + [[package]] name = "dunce" version = "1.0.4" @@ -1978,7 +2051,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "e310b3a6b5907f99202fcdb4960ff45b93735d7c7d96b760fcff8db2dc0e103d" dependencies = [ "cfg-if", - "windows-targets 0.48.5", + "windows-targets 0.52.4", ] [[package]] @@ -2059,6 +2132,60 @@ dependencies = [ "winapi", ] +[[package]] +name = "madsim" +version = "0.2.31" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b3c97f34bb19cf6a435a4da2187e90acc6bc59faa730e493b28b6d33e1bb9ccb" +dependencies = [ + "ahash 0.8.11", + "async-channel 2.2.0", + "async-stream", + "async-task", + "bincode", + "bytes", + "downcast-rs", + "futures-util", + "lazy_static", + "libc", + "madsim-macros", + "naive-timer", + "panic-message", + "rand", + "rand_xoshiro", + "rustversion", + "serde", + "spin 0.9.8", + "tokio", + "tokio-util", + "toml", + "tracing", + "tracing-subscriber", +] + +[[package]] +name = "madsim-macros" +version = "0.2.12" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f3d248e97b1a48826a12c3828d921e8548e714394bf17274dd0a93910dc946e1" +dependencies = [ + "darling 0.14.4", + "proc-macro2", + "quote", + "syn 1.0.109", +] + +[[package]] +name = "madsim-tokio" +version = "0.2.30" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7d3eb2acc57c82d21d699119b859e2df70a91dbdb84734885a1e72be83bdecb5" +dependencies = [ + "madsim", + "spin 0.9.8", + "tokio", +] + [[package]] name = "matchit" version = "0.5.0" @@ -2123,6 +2250,18 @@ dependencies = [ "windows-sys 0.48.0", ] +[[package]] +name = "mio" +version = "1.0.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "80e04d1dcff3aae0704555fe5fee3bcfaf3d1fdf8a7e521d5b9d2b42acb52cec" +dependencies = [ + "hermit-abi", + "libc", + "wasi", + "windows-sys 0.52.0", +] + [[package]] name = "mirai-annotations" version = "1.12.0" @@ -2156,6 +2295,12 @@ dependencies = [ "syn 1.0.109", ] +[[package]] +name = "naive-timer" +version = "0.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "034a0ad7deebf0c2abcf2435950a6666c3c15ea9d8fad0c0f48efa8a7f843fed" + [[package]] name = "native-tls" version = "0.2.11" @@ -2212,6 +2357,16 @@ version = "0.3.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "61807f77802ff30975e01f4f071c8ba10c022052f98b3294119f3e615d13e5be" +[[package]] +name = "nu-ansi-term" +version = "0.46.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "77a8165726e8236064dbb45459242600304b42a5ea24ee2948e18e023bf7ba84" +dependencies = [ + "overload", + "winapi", +] + [[package]] name = "num-bigint" version = "0.4.4" @@ -2276,16 +2431,6 @@ dependencies = [ "libm", ] -[[package]] -name = "num_cpus" -version = "1.16.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4161fcb6d602d4d2081af7c3a45852d875a03dd337a6bfdd6e06407b61342a43" -dependencies = [ - "hermit-abi", - "libc", -] - [[package]] name = "object" version = "0.32.2" @@ -2361,6 +2506,18 @@ dependencies = [ "vcpkg", ] +[[package]] +name = "overload" +version = "0.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b15813163c1d831bf4a13c3610c05c0d03b39feb07f7e09fa234dac9b15aaf39" + +[[package]] +name = "panic-message" +version = "0.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "384e52fd8fbd4cbe3c317e8216260c21a0f9134de108cea8a4dd4e7e152c472d" + [[package]] name = "parking" version = "2.2.0" @@ -2619,7 +2776,7 @@ version = "3.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "6d37c51ca738a55da99dc0c4a34860fd675453b8b36209178c2249bb13651284" dependencies = [ - "toml_edit", + "toml_edit 0.21.1", ] [[package]] @@ -3138,6 +3295,15 @@ dependencies = [ "serde", ] +[[package]] +name = "serde_spanned" +version = "0.6.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "87607cb1398ed59d48732e575a4c28a7a8ebf2454b964fe3f224f2afc07909e1" +dependencies = [ + "serde", +] + [[package]] name = "serde_urlencoded" version = "0.7.1" @@ -3172,7 +3338,7 @@ version = "2.3.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "881b6f881b17d13214e5d494c939ebab463d01264ce1811e9d4ac3a882e7695f" dependencies = [ - "darling", + "darling 0.20.8", "proc-macro2", "quote", "syn 2.0.52", @@ -3200,6 +3366,15 @@ dependencies = [ "digest", ] +[[package]] +name = "sharded-slab" +version = "0.1.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f40ca3c46823713e0d4209592e8d6e826aa57e928f09752619fc696c499637f6" +dependencies = [ + "lazy_static", +] + [[package]] name = "shlex" version = "1.3.0" @@ -3223,7 +3398,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "29ad2e15f37ec9a6cc544097b78a1ec90001e9f71b81338ca39f430adaca99af" dependencies = [ "libc", - "mio", + "mio 0.8.11", "signal-hook", ] @@ -3373,13 +3548,13 @@ dependencies = [ "filetime", "futures", "glob", + "madsim-tokio", "openssl", "promptly", "serde", "serde_json", "sqlx", "tempfile", - "tokio", "url", ] @@ -3414,6 +3589,7 @@ dependencies = [ "ipnetwork", "log", "mac_address", + "madsim-tokio", "memchr", "native-tls", "num-bigint", @@ -3433,7 +3609,6 @@ dependencies = [ "sqlx", "thiserror", "time", - "tokio", "tokio-stream", "tracing", "url", @@ -3448,8 +3623,8 @@ dependencies = [ "anyhow", "clap", "futures", + "madsim-tokio", "sqlx", - "tokio", ] [[package]] @@ -3460,6 +3635,7 @@ dependencies = [ "argon2", "axum", "dotenvy", + "madsim-tokio", "once_cell", "rand", "regex", @@ -3469,7 +3645,6 @@ dependencies = [ "sqlx", "thiserror", "time", - "tokio", "tower", "tracing", "uuid", @@ -3482,9 +3657,9 @@ version = "0.1.0" dependencies = [ "crossterm", "futures", + "madsim-tokio", "ratatui", "sqlx", - "tokio", "unicode-width", ] @@ -3494,8 +3669,8 @@ version = "0.1.0" dependencies = [ "anyhow", "dotenvy", + "madsim-tokio", "sqlx", - "tokio", ] [[package]] @@ -3506,10 +3681,10 @@ dependencies = [ "clap", "dotenvy", "futures", + "madsim-tokio", "serde", "serde_json", "sqlx", - "tokio", ] [[package]] @@ -3517,8 +3692,8 @@ name = "sqlx-example-postgres-listen" version = "0.1.0" dependencies = [ "futures", + "madsim-tokio", "sqlx", - "tokio", ] [[package]] @@ -3530,9 +3705,9 @@ dependencies = [ "clap", "dotenvy", "futures", + "madsim-tokio", "mockall", "sqlx", - "tokio", ] [[package]] @@ -3543,8 +3718,8 @@ dependencies = [ "clap", "dotenvy", "futures", + "madsim-tokio", "sqlx", - "tokio", ] [[package]] @@ -3552,8 +3727,8 @@ name = "sqlx-example-postgres-transaction" version = "0.1.0" dependencies = [ "futures", + "madsim-tokio", "sqlx", - "tokio", ] [[package]] @@ -3563,8 +3738,8 @@ dependencies = [ "anyhow", "clap", "futures", + "madsim-tokio", "sqlx", - "tokio", ] [[package]] @@ -3587,6 +3762,7 @@ dependencies = [ "either", "heck 0.5.0", "hex", + "madsim-tokio", "once_cell", "proc-macro2", "quote", @@ -3599,7 +3775,6 @@ dependencies = [ "sqlx-sqlite", "syn 2.0.52", "tempfile", - "tokio", "url", ] @@ -3704,11 +3879,11 @@ dependencies = [ "flume", "futures-channel", "futures-core", - "futures-executor", "futures-intrusive", "futures-util", "libsqlite3-sys", "log", + "madsim-tokio", "percent-encoding", "regex", "serde", @@ -3897,6 +4072,16 @@ dependencies = [ "syn 2.0.52", ] +[[package]] +name = "thread_local" +version = "1.1.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8b9ef9bad013ada3808854ceac7b46812a6465ba368859a37e2100283d2d719c" +dependencies = [ + "cfg-if", + "once_cell", +] + [[package]] name = "time" version = "0.3.36" @@ -3955,28 +4140,27 @@ checksum = "1f3ccbac311fea05f86f61904b462b55fb3df8837a366dfc601a0161d0532f20" [[package]] name = "tokio" -version = "1.36.0" +version = "1.41.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "61285f6515fa018fb2d1e46eb21223fff441ee8db5d0f1435e8ab4f5cdb80931" +checksum = "145f3413504347a2be84393cc8a7d2fb4d863b375909ea59f2158261aa258bbb" dependencies = [ "backtrace", "bytes", "libc", - "mio", - "num_cpus", + "mio 1.0.2", "parking_lot", "pin-project-lite", "signal-hook-registry", "socket2 0.5.6", "tokio-macros", - "windows-sys 0.48.0", + "windows-sys 0.52.0", ] [[package]] name = "tokio-macros" -version = "2.2.0" +version = "2.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5b8a1e28f2deaa14e508979454cb3a223b10b938b45af148bc0986de36f1923b" +checksum = "693d596312e88961bc67d7f1f97af8a70227d9f90c31bba5806eec004978d752" dependencies = [ "proc-macro2", "quote", @@ -3994,11 +4178,39 @@ dependencies = [ "tokio", ] +[[package]] +name = "tokio-util" +version = "0.7.12" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "61e7c3654c13bcd040d4a03abee2c75b1d14a37b423cf5a813ceae1cc903ec6a" +dependencies = [ + "bytes", + "futures-core", + "futures-sink", + "pin-project-lite", + "tokio", +] + +[[package]] +name = "toml" +version = "0.8.15" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ac2caab0bf757388c6c0ae23b3293fdb463fee59434529014f85e3263b995c28" +dependencies = [ + "serde", + "serde_spanned", + "toml_datetime", + "toml_edit 0.22.16", +] + [[package]] name = "toml_datetime" version = "0.6.6" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "4badfd56924ae69bcc9039335b2e017639ce3f9b001c393c1b2d1ef846ce2cbf" +dependencies = [ + "serde", +] [[package]] name = "toml_edit" @@ -4008,7 +4220,20 @@ checksum = "6a8534fd7f78b5405e860340ad6575217ce99f38d4d5c8f2442cb5ecb50090e1" dependencies = [ "indexmap 2.2.5", "toml_datetime", - "winnow", + "winnow 0.5.40", +] + +[[package]] +name = "toml_edit" +version = "0.22.16" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "278f3d518e152219c994ce877758516bca5e118eaed6996192a774fb9fbf0788" +dependencies = [ + "indexmap 2.2.5", + "serde", + "serde_spanned", + "toml_datetime", + "winnow 0.6.20", ] [[package]] @@ -4088,6 +4313,32 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "c06d3da6113f116aaee68e4d601191614c9053067f9ab7f6edbcb161237daa54" dependencies = [ "once_cell", + "valuable", +] + +[[package]] +name = "tracing-log" +version = "0.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ee855f1f400bd0e5c02d150ae5de3840039a3f54b025156404e34c23c03f47c3" +dependencies = [ + "log", + "once_cell", + "tracing-core", +] + +[[package]] +name = "tracing-subscriber" +version = "0.3.18" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ad0f048c97dbd9faa9b7df56362b8ebcaa52adb06b498c050d2f4e32f90a7a8b" +dependencies = [ + "nu-ansi-term", + "sharded-slab", + "smallvec", + "thread_local", + "tracing-core", + "tracing-log", ] [[package]] @@ -4241,6 +4492,12 @@ dependencies = [ "syn 1.0.109", ] +[[package]] +name = "valuable" +version = "0.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "830b7e5d4d90034032940e4ace0d9a9a057e7a45cd94e6c007832e39edb82f6d" + [[package]] name = "value-bag" version = "1.8.0" @@ -4593,6 +4850,15 @@ dependencies = [ "memchr", ] +[[package]] +name = "winnow" +version = "0.6.20" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "36c1fec1a2bb5866f07c25f68c26e565c4c200aebb96d7e55710c19d3e8ac49b" +dependencies = [ + "memchr", +] + [[package]] name = "wyz" version = "0.5.1" From 0960678d4758cf0264cea0d9fe11de3cefde8e76 Mon Sep 17 00:00:00 2001 From: Noel Kwan Date: Fri, 1 Nov 2024 10:30:21 +0800 Subject: [PATCH 3/4] make Socket trait compatible with madsim --- sqlx-core/src/net/socket/mod.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/sqlx-core/src/net/socket/mod.rs b/sqlx-core/src/net/socket/mod.rs index 0470abb5ec..71e0b047bc 100644 --- a/sqlx-core/src/net/socket/mod.rs +++ b/sqlx-core/src/net/socket/mod.rs @@ -13,7 +13,7 @@ use crate::io::ReadBuf; mod buffered; -pub trait Socket: Send + Sync + Unpin + 'static { +pub trait Socket: Send + Unpin + 'static { fn try_read(&mut self, buf: &mut dyn ReadBuf) -> io::Result; fn try_write(&mut self, buf: &[u8]) -> io::Result; From 3efe6d0065963db2a2b7f30dee69f647e28dec81 Mon Sep 17 00:00:00 2001 From: Noel Kwan Date: Fri, 1 Nov 2024 10:31:16 +0800 Subject: [PATCH 4/4] make worker message send non-blocking + use tokio spawn instead of system thread --- sqlx-sqlite/src/connection/worker.rs | 40 +++++++++++++--------------- 1 file changed, 18 insertions(+), 22 deletions(-) diff --git a/sqlx-sqlite/src/connection/worker.rs b/sqlx-sqlite/src/connection/worker.rs index a01de2419c..69d7b52342 100644 --- a/sqlx-sqlite/src/connection/worker.rs +++ b/sqlx-sqlite/src/connection/worker.rs @@ -2,7 +2,6 @@ use std::borrow::Cow; use std::future::Future; use std::sync::atomic::{AtomicUsize, Ordering}; use std::sync::Arc; -use std::thread; use futures_channel::oneshot; use futures_intrusive::sync::{Mutex, MutexGuard}; @@ -79,9 +78,7 @@ impl ConnectionWorker { pub(crate) async fn establish(params: EstablishParams) -> Result { let (establish_tx, establish_rx) = oneshot::channel(); - thread::Builder::new() - .name(params.thread_name.clone()) - .spawn(move || { + tokio::spawn(async move { let (command_tx, command_rx) = flume::bounded(params.command_channel_size); let conn = match params.establish() { @@ -116,10 +113,11 @@ impl ConnectionWorker { // would rollback an already completed transaction. let mut ignore_next_start_rollback = false; - for (cmd, span) in command_rx { + while let Ok((cmd, span)) = command_rx.recv_async().await { let _guard = span.enter(); match cmd { Command::Prepare { query, tx } => { + // TODO(kwannoel): Make this async? tx.send(prepare(&mut conn, &query).map(|prepared| { update_cached_statements_size( &conn, @@ -130,6 +128,7 @@ impl ConnectionWorker { .ok(); } Command::Describe { query, tx } => { + // TODO(kwannoel): Make this async? tx.send(describe(&mut conn, &query)).ok(); } Command::Execute { @@ -143,7 +142,7 @@ impl ConnectionWorker { { Ok(iter) => iter, Err(e) => { - tx.send(Err(e)).ok(); + tx.send_async(Err(e)).await.ok(); continue; } }; @@ -151,7 +150,7 @@ impl ConnectionWorker { match limit { None => { for res in iter { - if tx.send(res).is_err() { + if tx.send_async(res).await.is_err() { break; } } @@ -166,12 +165,12 @@ impl ConnectionWorker { rows_returned += 1; if rows_returned >= limit { drop(iter); - let _ = tx.send(res); + let _ = tx.send_async(res).await; break; } } } - if tx.send(res).is_err() { + if tx.send_async(res).await.is_err() { break; } } @@ -190,7 +189,7 @@ impl ConnectionWorker { }); let res_ok = res.is_ok(); - if tx.blocking_send(res).is_err() && res_ok { + if tx.send(res).await.is_err() && res_ok { // The BEGIN was processed but not acknowledged. This means no // `Transaction` was created and so there is no way to commit / // rollback this transaction. We need to roll it back @@ -224,7 +223,7 @@ impl ConnectionWorker { }; let res_ok = res.is_ok(); - if tx.blocking_send(res).is_err() && res_ok { + if tx.send(res).await.is_err() && res_ok { // The COMMIT was processed but not acknowledged. This means that // the `Transaction` doesn't know it was committed and will try to // rollback on drop. We need to ignore that rollback. @@ -252,7 +251,7 @@ impl ConnectionWorker { let res_ok = res.is_ok(); if let Some(tx) = tx { - if tx.blocking_send(res).is_err() && res_ok { + if tx.send(res).await.is_err() && res_ok { // The ROLLBACK was processed but not acknowledged. This means // that the `Transaction` doesn't know it was rolled back and // will try to rollback again on drop. We need to ignore that @@ -268,7 +267,7 @@ impl ConnectionWorker { } Command::UnlockDb => { drop(conn); - conn = futures_executor::block_on(shared.conn.lock()); + conn = shared.conn.lock().await; } Command::Ping { tx } => { tx.send(()).ok(); @@ -283,7 +282,7 @@ impl ConnectionWorker { } } } - })?; + }); establish_rx.await.map_err(|_| Error::WorkerCrashed)? } @@ -408,12 +407,13 @@ impl ConnectionWorker { pub(crate) fn shutdown(&mut self) -> impl Future> { let (tx, rx) = oneshot::channel(); - let send_res = self - .command_tx - .send((Command::Shutdown { tx }, Span::current())) - .map_err(|_| Error::WorkerCrashed); + let command_tx = self.command_tx.clone(); async move { + let send_res = command_tx + .send_async((Command::Shutdown { tx }, Span::current())) + .await + .map_err(|_| Error::WorkerCrashed); send_res?; // wait for the response @@ -471,10 +471,6 @@ mod rendezvous_oneshot { self.inner.send((value, ack_tx)).map_err(|_| Canceled)?; ack_rx.await } - - pub fn blocking_send(self, value: T) -> Result<(), Canceled> { - futures_executor::block_on(self.send(value)) - } } pub struct Receiver {