ngin进程间的关系

    nginx的进程数量可以通过配置文件来部署,在正式的生产环境中,nginx通常使用一个master进程来管理多个worker进程,一般情况下worker进程的数量等于服务器cpu的核心数。在这种情况下,每个worker进程都是繁忙的,他们在真正的提供互联网服务,而master进程则很清闲,只负责监控worker进程。

    多个worker进程处理互联网请求不但可以提高服务的健壮性,因为一个worker进程出错后,其它worker进程仍然可以正常提供服务,并且master进程可以很快拉起出错进程,恢复正常的服务。同时将worker进程和cpu核心数设置的一样,这样可以为每个进程绑定一个核,避免了进程间切换的开销。这与apache服务器不同,apache服务器的每个进程在一个时刻只处理一个请求,因此,如果需要处理更多的并发请求就需要设置更多的进程或线程,当服务器上拥有很多个进程,大量的进程间的切换将带来很多无谓的系统资源消耗。nginx通过事件驱动机制,一个worker进程可以处理多个请求,并发处理请求数只受限于内存的大小。这样就大大提高了nginx的并发性能。

    ngin进程间的关系_第1张图片

你可能感兴趣的:(nginx)