Master进程启动时从父shell继承环境变量,Worker进程默认不继承,需在main上下文用env指令显式声明才能供Worker使用。

Nginx多进程架构中Master进程获取系统环境变量

Master进程在启动时读取并继承操作系统环境变量,但Worker进程默认不继承这些变量。

Master进程如何获取环境变量

当Nginx以命令行方式启动(如 nginxnginx -c /path/to/nginx.conf),Master进程会直接从父shell环境中继承所有已设置的环境变量。这包括通过 export VAR=value 设置的变量,以及系统级环境(如 PATHUSER 等)。

注意:该行为发生在Master进程创建之初,即解析配置文件之前。因此,如果配置中使用了 $ENV_VAR 这类语法(需配合 env 指令),Nginx必须明确“知道”哪些变量需要传递给后续上下文。

Worker进程默认不继承环境变量

出于安全与隔离考虑,Nginx Worker进程在fork+exec启动时会清空大部分环境变量。即使Master读到了某个变量,Worker也不会自动拥有它。

让Worker访问特定环境变量的方法

若模块或Lua脚本(如 ngx_lua)需在Worker中读取环境变量,必须提前告知Nginx:

重启Nginx后,Worker进程即可通过 os.getenv("MY_API_KEY")(Lua)或 getenv("MY_API_KEY")(C模块)安全读取。

调试环境变量是否生效

验证变量是否成功注入Worker:

本文转载于:互联网 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。