mirror of
https://github.com/actix/examples
synced 2025-06-26 17:17:42 +02:00
Restructure folders (#411)
This commit is contained in:
committed by
GitHub
parent
9db98162b2
commit
c3407627d0
9
basics/state/Cargo.toml
Normal file
9
basics/state/Cargo.toml
Normal file
@ -0,0 +1,9 @@
|
||||
[package]
|
||||
name = "state"
|
||||
version = "2.0.0"
|
||||
authors = ["Nikolay Kim <fafhrd91@gmail.com>"]
|
||||
edition = "2018"
|
||||
|
||||
[dependencies]
|
||||
actix-web = "3"
|
||||
env_logger = "0.8"
|
15
basics/state/README.md
Normal file
15
basics/state/README.md
Normal file
@ -0,0 +1,15 @@
|
||||
# state
|
||||
|
||||
## Usage
|
||||
|
||||
### server
|
||||
|
||||
```bash
|
||||
cd examples/state
|
||||
cargo run
|
||||
# Started http server: 127.0.0.1:8080
|
||||
```
|
||||
|
||||
### web client
|
||||
|
||||
- [http://localhost:8080/](http://localhost:8080/)
|
78
basics/state/src/main.rs
Normal file
78
basics/state/src/main.rs
Normal file
@ -0,0 +1,78 @@
|
||||
//! Application may have multiple data objects that are shared across
|
||||
//! all handlers within same Application.
|
||||
//!
|
||||
//! For global shared state, we wrap our state in a `actix_web::web::Data` and move it into
|
||||
//! the factory closure. The closure is called once-per-thread, and we clone our state
|
||||
//! and attach to each instance of the `App` with `.app_data(state.clone())`.
|
||||
//!
|
||||
//! For thread-local state, we construct our state within the factory closure and attach to
|
||||
//! the app with `.data(state)`.
|
||||
//!
|
||||
//! We retrieve our app state within our handlers with a `state: Data<...>` argument.
|
||||
//!
|
||||
//! By default, `actix-web` runs one `App` per logical cpu core.
|
||||
//! When running on <N> cores, we see that the example will increment `counter1` (global state via
|
||||
//! Mutex) and `counter3` (global state via Atomic variable) each time the endpoint is called,
|
||||
//! but only appear to increment `counter2` every Nth time on average (thread-local state). This
|
||||
//! is because the workload is being shared equally among cores.
|
||||
//!
|
||||
//! Check [user guide](https://actix.rs/docs/application/#state) for more info.
|
||||
|
||||
use std::cell::Cell;
|
||||
use std::io;
|
||||
use std::sync::atomic::{AtomicUsize, Ordering};
|
||||
use std::sync::Mutex;
|
||||
|
||||
use actix_web::{middleware, web, App, HttpRequest, HttpResponse, HttpServer};
|
||||
|
||||
/// simple handle
|
||||
async fn index(
|
||||
counter1: web::Data<Mutex<usize>>,
|
||||
counter2: web::Data<Cell<u32>>,
|
||||
counter3: web::Data<AtomicUsize>,
|
||||
req: HttpRequest,
|
||||
) -> HttpResponse {
|
||||
println!("{:?}", req);
|
||||
|
||||
// Increment the counters
|
||||
*counter1.lock().unwrap() += 1;
|
||||
counter2.set(counter2.get() + 1);
|
||||
counter3.fetch_add(1, Ordering::SeqCst);
|
||||
|
||||
let body = format!(
|
||||
"global mutex counter: {}, local counter: {}, global atomic counter: {}",
|
||||
*counter1.lock().unwrap(),
|
||||
counter2.get(),
|
||||
counter3.load(Ordering::SeqCst),
|
||||
);
|
||||
HttpResponse::Ok().body(body)
|
||||
}
|
||||
|
||||
#[actix_web::main]
|
||||
async fn main() -> io::Result<()> {
|
||||
std::env::set_var("RUST_LOG", "actix_web=info");
|
||||
env_logger::init();
|
||||
|
||||
// Create some global state prior to building the server
|
||||
#[allow(clippy::mutex_atomic)] // it's intentional.
|
||||
let counter1 = web::Data::new(Mutex::new(0usize));
|
||||
let counter3 = web::Data::new(AtomicUsize::new(0usize));
|
||||
|
||||
// move is necessary to give closure below ownership of counter1
|
||||
HttpServer::new(move || {
|
||||
// Create some thread-local state
|
||||
let counter2 = Cell::new(0u32);
|
||||
|
||||
App::new()
|
||||
.app_data(counter1.clone()) // add shared state
|
||||
.app_data(counter3.clone()) // add shared state
|
||||
.data(counter2) // add thread-local state
|
||||
// enable logger
|
||||
.wrap(middleware::Logger::default())
|
||||
// register simple handler
|
||||
.service(web::resource("/").to(index))
|
||||
})
|
||||
.bind("127.0.0.1:8080")?
|
||||
.run()
|
||||
.await
|
||||
}
|
Reference in New Issue
Block a user