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 套接字),实现零停机更新。
渐进式释放:旧周期资源在新周期稳定后逐步清理,避免服务中断。

相关推荐
令狐少侠201123 分钟前
ai之对接电信ds后端服务,通过nginx代理转发https为http,对外请求,保持到达第三方后请求头不变
nginx·ai·https
钢铁男儿25 分钟前
PyQt5高级界而控件(容器:装载更多的控件QDockWidget)
数据库·python·qt
阿蒙Amon3 小时前
C# Linq to SQL:数据库编程的解决方案
数据库·c#·linq
牧以南歌〆7 小时前
在Ubuntu主机中修改ARM Linux开发板的根文件系统
linux·arm开发·驱动开发·ubuntu
互联网搬砖老肖7 小时前
运维打铁: MongoDB 数据库集群搭建与管理
运维·数据库·mongodb
典学长编程8 小时前
数据库Oracle从入门到精通!第四天(并发、锁、视图)
数据库·oracle
积跬步,慕至千里9 小时前
clickhouse数据库表和doris数据库表迁移starrocks数据库时建表注意事项总结
数据库·clickhouse
极限实验室9 小时前
搭建持久化的 INFINI Console 与 Easysearch 容器环境
数据库
cuijiecheng20189 小时前
Ubuntu下布署mediasoup-demo
linux·运维·ubuntu
白仑色10 小时前
Oracle PL/SQL 编程基础详解(从块结构到游标操作)
数据库·oracle·数据库开发·存储过程·plsql编程