1
0
mirror of https://github.com/fafhrd91/actix-web synced 2025-01-18 05:41:50 +01:00

add StopWorker message

This commit is contained in:
Nikolay Kim 2017-12-28 13:07:29 -08:00
parent 6a2bb9a473
commit 3f4898a6d1
2 changed files with 44 additions and 9 deletions

View File

@ -15,28 +15,24 @@ use mio;
use num_cpus; use num_cpus;
use net2::TcpBuilder; use net2::TcpBuilder;
#[cfg(feature="tls")]
use futures::{future, Future};
#[cfg(feature="tls")] #[cfg(feature="tls")]
use native_tls::TlsAcceptor; use native_tls::TlsAcceptor;
#[cfg(feature="tls")] #[cfg(feature="tls")]
use tokio_tls::{TlsStream, TlsAcceptorExt}; use tokio_tls::TlsStream;
#[cfg(feature="alpn")] #[cfg(feature="alpn")]
use futures::{future, Future}; use openssl::ssl::{SslMethod, SslAcceptorBuilder};
#[cfg(feature="alpn")]
use openssl::ssl::{SslMethod, SslAcceptor, SslAcceptorBuilder};
#[cfg(feature="alpn")] #[cfg(feature="alpn")]
use openssl::pkcs12::ParsedPkcs12; use openssl::pkcs12::ParsedPkcs12;
#[cfg(feature="alpn")] #[cfg(feature="alpn")]
use tokio_openssl::{SslStream, SslAcceptorExt}; use tokio_openssl::SslStream;
#[cfg(feature="signal")] #[cfg(feature="signal")]
use actix::actors::signal; use actix::actors::signal;
use helpers; use helpers;
use channel::{HttpChannel, HttpHandler, IntoHttpHandler}; use channel::{HttpChannel, HttpHandler, IntoHttpHandler};
use worker::{Conn, Worker, WorkerSettings, StreamHandlerType}; use worker::{Conn, Worker, WorkerSettings, StreamHandlerType, StopWorker};
/// Various server settings /// Various server settings
#[derive(Debug, Clone)] #[derive(Debug, Clone)]
@ -604,14 +600,21 @@ impl<T, A, H, U> Handler<StopServer> for HttpServer<T, A, H, U>
U: 'static, U: 'static,
A: 'static, A: 'static,
{ {
fn handle(&mut self, _: StopServer, ctx: &mut Context<Self>) -> Response<Self, StopServer> fn handle(&mut self, msg: StopServer, ctx: &mut Context<Self>) -> Response<Self, StopServer>
{ {
// stop accept threads
for item in &self.accept { for item in &self.accept {
let _ = item.1.send(Command::Stop); let _ = item.1.send(Command::Stop);
let _ = item.0.set_readiness(mio::Ready::readable()); let _ = item.0.set_readiness(mio::Ready::readable());
} }
ctx.stop(); ctx.stop();
// stop workers
let dur = if msg.graceful { Some(Duration::new(30, 0)) } else { None };
for worker in &self.workers {
worker.send(StopWorker{graceful: dur})
}
// we need to stop system if server was spawned // we need to stop system if server was spawned
if self.exit { if self.exit {
Arbiter::system().send(msgs::SystemExit(0)) Arbiter::system().send(msgs::SystemExit(0))

View File

@ -5,7 +5,22 @@ use tokio_core::net::TcpStream;
use tokio_core::reactor::Handle; use tokio_core::reactor::Handle;
use net2::TcpStreamExt; use net2::TcpStreamExt;
#[cfg(feature="tls")]
use futures::{future, Future};
#[cfg(feature="tls")]
use native_tls::TlsAcceptor;
#[cfg(feature="tls")]
use tokio_tls::TlsAcceptorExt;
#[cfg(feature="alpn")]
use futures::{future, Future};
#[cfg(feature="alpn")]
use openssl::ssl::SslAcceptor;
#[cfg(feature="alpn")]
use tokio_openssl::SslAcceptorExt;
use actix::{Actor, Arbiter, AsyncContext, Context, Handler, Response, StreamHandler}; use actix::{Actor, Arbiter, AsyncContext, Context, Handler, Response, StreamHandler};
use actix::msgs::StopArbiter;
use helpers; use helpers;
use channel::{HttpChannel, HttpHandler}; use channel::{HttpChannel, HttpHandler};
@ -18,6 +33,12 @@ pub(crate) struct Conn<T> {
pub http2: bool, pub http2: bool,
} }
/// Stop worker
#[derive(Message)]
pub(crate) struct StopWorker {
pub graceful: Option<time::Duration>,
}
pub(crate) struct WorkerSettings<H> { pub(crate) struct WorkerSettings<H> {
h: RefCell<Vec<H>>, h: RefCell<Vec<H>>,
enabled: bool, enabled: bool,
@ -108,6 +129,17 @@ impl<H> Handler<Conn<net::TcpStream>> for Worker<H>
} }
} }
/// `StopWorker` message handler
impl<H> Handler<StopWorker> for Worker<H>
where H: HttpHandler + 'static,
{
fn handle(&mut self, _: StopWorker, _: &mut Context<Self>) -> Response<Self, StopWorker>
{
Arbiter::arbiter().send(StopArbiter(0));
Self::empty()
}
}
#[derive(Clone)] #[derive(Clone)]
pub(crate) enum StreamHandlerType { pub(crate) enum StreamHandlerType {
Normal, Normal,