=encoding utf-8 =head1 Name C - manage the nginx processes for OpenResty/ngx_lua. =head1 Status This Lua module is production ready. =head1 Synopsis Enables privileged agent process, gets process type, and then gets the master process PID: # http config init_by_lua_block { local process = require "ngx.process" -- enables privileged agent process local ok, err = process.enable_privileged_agent() if not ok then ngx.log(ngx.ERR, "enables privileged agent failed error:", err) end -- output process type ngx.log(ngx.INFO, "process type: ", process.type()) } init_worker_by_lua_block { local process = require "ngx.process" ngx.log(ngx.INFO, "process type: ", process.type()) } server { # ... location = /t { content_by_lua_block { local process = require "ngx.process" ngx.say("process type: ", process.type()) ngx.say("master process pid: ", process.get_master_pid() or "-") } } } The example config above produces an output to C when server starts: [lua] init_by_lua:11: process type: master [lua] init_worker_by_lua:3: process type: privileged agent [lua] init_worker_by_lua:3: process type: worker The example location above produces the following response body: process type: worker master process pid: 8261 =head1 Functions =head2 type B I B I Returns the type of the current Nginx process. Depending on the calling context and current process, the type can be one of: =over =item * C: returned when this function is called from within the master process =item * C: returned when this function is called from within a worker process =item * C: returned when Nginx is running in the single process mode =item * C: returned when Nginx is running as a signaller process =item * C: returned when this funtion is called from within a privileged agent process =back For example: local process = require "ngx.process" ngx.say("process type:", process.type()) -- RESPONSE: worker =head2 enable_privileged_agent B I B I> Enables the privileged agent process in Nginx. The privileged agent process does not listen on any virtual server ports like those worker processes. And it uses the same system account as the nginx master process, which is usually a privileged account like C. The C directive handler still runs in the privileged agent process. And one can use the L function provided by this module to check if the current process is a privileged agent. The argument connections sets the maximum number of simultaneous connections that can be opened by privileged agent process. In case of failures, returns C and a string describing the error. =head2 signal_graceful_exit B I B I Signals the I nginx (worker) process to quit gracefully, i.e., after all the timers have expired (in time or expired prematurely). Note that this API function simply sets the nginx global C variable C to signal the nginx event loop directly. No UNIX signals or IPC are involved here. WARNING: the official NGINX core does not perform the graceful exiting procedure when the L directive is turned C. The OpenResty's NGINX core has a L applied, which fixes this issue. =head2 get_master_pid B I B I Returns a number value for the nginx master process's process ID (or PID). This function requires NGINX 1.13.8+ cores to work properly. Otherwise it returns C. This feature first appeared in lua-resty-core v0.1.14. =head1 Community =head2 English Mailing List The L mailing list is for English speakers. =head2 Chinese Mailing List The L mailing list is for Chinese speakers. =head1 Bugs and Patches Please report bugs or submit patches by =over =item 1. creating a ticket on the L, =item 2. or posting to the L. =back =head1 Author Yuansheng Wang Emembphis@gmail.comE (membphis), OpenResty Inc. =head1 Copyright and License This module is licensed under the BSD license. Copyright (C) 2017, by Yichun "agentzh" Zhang, OpenResty Inc. All rights reserved. Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met: =over =item * Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer. =back =over =item * Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution. =back THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. =head1 See Also =over =item * the L library. =item * the ngx_lua module: https://github.com/openresty/lua-nginx-module =item * OpenResty: https://openresty.org =back