Ubuntu 下 nginx-1.24.0 源码分析 - ngx_init_cycle 函数 - 详解(1)

详解(1)


1. 更新时间

c 复制代码
   ngx_timezone_update();

    /* force localtime update with a new timezone */

    tp = ngx_timeofday();
    tp->sec = 0;

    ngx_time_update();

ngx_timezone_update()更新进程的时区缓存
ngx_timeofday() 获取当前时间缓存对象 tp。
tp->sec = 0 强制标记时间缓存为"已失效"。
ngx_time_update() 重新计算当前时间并更新缓存。

tp->sec = 0; 的作用是强制标记当前时间缓存为无效,从而确保在调用 ngx_time_update() 时会重新调用系统函数来获取最新的时间戳。

如果没有强制刷新时间缓存(即 tp->sec != 0),ngx_time_update() 可能不会真正调用系统函数,而是直接使用缓存值


2. 创建内存池与周期结构

c 复制代码
	log = old_cycle->log;

    pool = ngx_create_pool(NGX_CYCLE_POOL_SIZE, log);
    if (pool == NULL) {
        return NULL;
    }
    pool->log = log;

    cycle = ngx_pcalloc(pool, sizeof(ngx_cycle_t));
    if (cycle == NULL) {
        ngx_destroy_pool(pool);
        return NULL;
    }

    cycle->pool = pool;
    cycle->log = log;
    cycle->old_cycle = old_cycle;

2.1 log = old_cycle->log;

从旧的 Nginx 运行周期(old_cycle)中继承日志对象(log),并将其赋值给当前的局部变量 log

新周期初始化时,尚未解析新的配置文件,无法确定新的日志路径或级别。

若直接使用新配置的日志可能失败(如路径无效),导致错误信息无法记录。

复用旧日志配置,新周期完全初始化前,确保初始化阶段的日志记录可靠。


2.2 pool = ngx_create_pool(NGX_CYCLE_POOL_SIZE, log);

创建一个内存池(memory pool),用于管理 Nginx 运行周期(cycle)中的内存分配

ngx_create_pool 是 Nginx 中用于创建内存池的核心函数。

它的主要功能是预分配一块连续的内存区域,并初始化相关的数据结构,以便后续高效地分配和管理内存。

NGX_CYCLE_POOL_SIZE

这是一个宏定义,表示内存池的初始大小。

log 是一个指向日志对象的指针,用于记录内存池操作中的错误或调试信息。


2.3 if (pool == NULL) { return NULL; }

检查内存池是否创建成功,失败则直接返回。


2.4 pool->log = log;

将内存池的日志对象设置为当前日志。

内存池可能在分配或销毁时记录日志(如调试信息),需确保使用正确的日志配置。

内存操作的日志与当前周期的日志配置保持同步


2.5 cycle = ngx_pcalloc(pool, sizeof(ngx_cycle_t));

从内存池分配并初始化 ngx_cycle_t 结构(核心运行时上下文)。
ngx_cycle_t 是 Nginx 运行时的核心结构,保存所有配置和运行时状态。


2.6 if (cycle == NULL) { ngx_destroy_pool(pool); return NULL; }

检查 cycle 分配是否成功,

分配失败时释放已创建的内存池,避免内存泄漏。

通过返回 NULL 通知上层初始化失败。
ngx_destroy_pool


2.7 cycle->pool = pool;

关联内存池到新周期。

所有后续内存分配均通过此池进行,确保统一管理。


2.8 cycle->log = log;

设置新周期的日志对象。

确保新周期的所有操作使用继承的日志配置,直到新配置生效。


2.9 cycle->old_cycle = old_cycle;

保存旧周期指针到新周期。

在平滑重启或重新配置时,新周期需要访问旧周期的资源(如监听套接字、共享内存)。
资源复用 :通过 old_cycle 复用旧资源(如 SO_REUSEPORT 套接字),实现零停机更新。
渐进式释放:旧周期资源在新周期稳定后逐步清理,避免服务中断。

相关推荐
Monly219 小时前
人大金仓:merge sql error, dbType null, druid-1.2.20
数据库·sql
不宕机的小马达10 小时前
【Mysql|第一篇】Mysql的安装与卸载、Navicat工具的使用
数据库·mysql
float_六七10 小时前
数据库连接池:性能优化的秘密武器
数据库·oracle·性能优化
码界奇点10 小时前
MongoDB vs MySQLNoSQL与SQL数据库的架构差异与选型指南
数据库·sql·mongodb·系统架构
IT 小阿姨(数据库)10 小时前
PgSQL中pg_stat_user_tables 和 pg_stat_user_objects参数详解
linux·运维·数据库·sql·postgresql·oracle
倔强的石头_10 小时前
Windows系统下KingbaseES数据库保姆级安装教程(附常见问题解决)
数据库
朱自清的诗.10 小时前
使用虚拟机Ubuntu搭建mosquito服务器 使esp32、上位机通信
ubuntu·esp32·mosquito
虎头金猫10 小时前
如何在Linux上使用Docker在本地部署开源PDF工具Stirling PDF:StirlingPDF+cpolar让专业操作像在线文档一样简单
linux·运维·ubuntu·docker·pdf·开源·centos
麦兜*11 小时前
MongoDB 常见错误解决方案:从连接失败到主从同步问题
java·数据库·spring boot·redis·mongodb·容器
RestCloud11 小时前
PostgreSQL大表同步优化:如何避免网络和内存瓶颈?
前端·数据库·api