当前位置: 首页 > news >正文

Ubuntu 下 nginx-1.24.0 源码分析 - ngx_monotonic_time函数

声明

在 src\core\ngx_times.c 中:

static ngx_msec_t ngx_monotonic_time(time_t sec, ngx_uint_t msec);

实现 

在 src\core\ngx_times.c 中:

static ngx_msec_t
ngx_monotonic_time(time_t sec, ngx_uint_t msec)
{
#if (NGX_HAVE_CLOCK_MONOTONIC)struct timespec  ts;#if defined(CLOCK_MONOTONIC_FAST)clock_gettime(CLOCK_MONOTONIC_FAST, &ts);
#elseclock_gettime(CLOCK_MONOTONIC, &ts);
#endifsec = ts.tv_sec;msec = ts.tv_nsec / 1000000;#endifreturn (ngx_msec_t) sec * 1000 + msec;
}

通过 gcc -E 处理 预处理指令后

static ngx_msec_t
ngx_monotonic_time(time_t sec, ngx_uint_t msec)
{struct timespec ts;clock_gettime(
# 204 "src/core/ngx_times.c" 3 41
# 204 "src/core/ngx_times.c", &ts);sec = ts.tv_sec;msec = ts.tv_nsec / 1000000;return (ngx_msec_t) sec * 1000 + msec;
}

NGX_HAVE_CLOCK_MONOTONIC 宏

objs/ngx_auto_config.h:287:#define NGX_HAVE_CLOCK_MONOTONIC  1 

在 objs/ngx_auto_config.h 中

#ifndef NGX_HAVE_CLOCK_MONOTONIC
#define NGX_HAVE_CLOCK_MONOTONIC  1
#endif

NGX_HAVE_CLOCK_MONOTONIC 是一个宏定义,

用于指示系统是否支持 clock_gettime() 函数的 CLOCK_MONOTONIC 时钟源

CLOCK_MONOTONIC 是 POSIX 标准中定义的一种时钟类型,表示单调递增的时间。

CLOCK_REALTIME 不同,CLOCK_MONOTONIC 的时间不会因为系统时间的调整(例如用户手动修改系统时间或通过 NTP 同步)而发生跳变。因此,它非常适合用于测量时间间隔或计算超时

NGX_HAVE_CLOCK_MONOTONIC 宏的作用是检查当前系统是否支持 CLOCK_MONOTONIC

如果支持,Nginx 会使用 clock_gettime(CLOCK_MONOTONIC, ...) 来获取高精度的时间戳,从而实现更精确的时间管理

在 Nginx 的构建过程中,通常会通过 configure 脚本来检测系统是否支持 CLOCK_MONOTONIC

  1. 编译时,configure 脚本会尝试编译一段测试代码,调用 clock_gettime() 并传入 CLOCK_MONOTONIC 参数。

  2. 如果编译成功且运行正常,则说明系统支持 CLOCK_MONOTONIC,此时会在生成的配置头文件(如 objs/ngx_auto_config.h)中定义 NGX_HAVE_CLOCK_MONOTONIC 宏。

  3. 如果编译失败或运行异常,则不会定义该宏

CLOCK_MONOTONIC_FAST 宏

未定义

CLOCK_MONOTONIC_FAST 用于替代标准的 CLOCK_MONOTONIC,在保证时间单调递增的前提下,减少时间获取的系统调用开销

  • 在 FreeBSD 等类 Unix 系统中,CLOCK_MONOTONIC_FAST 是系统原生支持的时钟类型(通过 clock_gettime() 使用)。
  • 在 Linux 等不支持该时钟的系统上,Nginx 会通过宏定义将其回退到 CLOCK_MONOTONIC,确保兼容性。

CLOCK_MONOTONIC 表示一种单调递增的时间源,从系统启动(即内核初始化完成)开始计时 

  • 不受系统时间调整的影响 :即使管理员手动修改了系统时间(例如通过 date 命令或 NTP 服务),CLOCK_MONOTONIC 的值也不会受到影响。
  • 单调递增 :该时钟只会随着时间向前推进,不会回退(除非系统重启)。
  • 高分辨率 :通常提供纳秒级别的精度。

所以

clock_gettime(CLOCK_MONOTONIC, &ts);

成立

综上,在我的 Ubuntu 环境下运行的实际代码应该是:

static ngx_msec_t
ngx_monotonic_time(time_t sec, ngx_uint_t msec)
{struct timespec  ts;clock_gettime(CLOCK_MONOTONIC, &ts);sec = ts.tv_sec;msec = ts.tv_nsec / 1000000;return (ngx_msec_t) sec * 1000 + msec;
}

函数的目标是获取一个基于单调时间(monotonic time)的时间戳,以毫秒为单位返回。单调时间的特点是不会受到系统时间调整的影响,适合用于计时和超时检测等场景

定义一个 timespec 结构体变量 ts,用于存储通过 clock_gettime 获取的时间信息

struct timespec 是 POSIX 标准中定义的时间结构体,包含两个字段:

  • tv_sec:秒数部分。
  • tv_nsec:纳秒部分(1 秒 = 10^9 纳秒)。

调用 clock_gettime 函数,获取当前的单调时间,并将结果存储到 ts

CLOCK_MONOTONIC 是一种单调递增的时钟源,不会受到系统时间调整(如手动修改系统时间或 NTP 同步)的影响。

clock_gettime 是 POSIX 标准中的函数,用于获取高精度时间

ts.tv_sec(单调时间的秒数部分)赋值给函数参数 sec

ts.tv_nsec(纳秒部分)转换为毫秒,并赋值给函数参数 msec

将秒数转换为毫秒,并加上毫秒部分,最终返回一个以毫秒为单位的时间戳

clock_gettime 函数

 clock_gettime 是 POSIX 标准中定义的一个函数,用于获取高精度的时间信息。它能够从指定的时钟源(clock source)中读取当前时间,并以纳秒级精度返回结果。

函数原型

#include <time.h>int clock_gettime(clockid_t clk_id, struct timespec *tp);

    clk_id

    指定时钟源(clock source),决定了时间的来源。

    常见的时钟源包括:

    CLOCK_REALTIME :系统实时时间(wall-clock time),可以被手动调整或通过 NTP 同步。

    CLOCK_MONOTONIC :单调递增的时间,从某个固定点开始计时,不受系统时间调整的影响。

    CLOCK_PROCESS_CPUTIME_ID :进程的 CPU 时间。

    CLOCK_THREAD_CPUTIME_ID :线程的 CPU 时间。

    CLOCK_BOOTTIME (Linux 特有):类似于 CLOCK_MONOTONIC,但包括系统休眠时间。

    选择不同的时钟源会影响时间的用途。

    tp

    指向一个 struct timespec 结构体的指针,用于存储获取到的时间信息。

    返回值

    • 成功时返回 0
    • 失败时返回 -1,并设置 errno 表示错误原因。

    相关文章:

    Ubuntu 下 nginx-1.24.0 源码分析 - ngx_monotonic_time函数

    声明 在 src\core\ngx_times.c 中&#xff1a; static ngx_msec_t ngx_monotonic_time(time_t sec, ngx_uint_t msec); 实现 在 src\core\ngx_times.c 中&#xff1a; static ngx_msec_t ngx_monotonic_time(time_t sec, ngx_uint_t msec) { #if (NGX_HAVE_CLOCK_MONOTONIC)st…...

    业务开发 | 基础知识 | Maven 快速入门

    Maven 快速入门 1.Maven 全面概述 Apache Maven 是一种软件项目管理和理解工具。基于项目对象模型的概念&#xff08;POM&#xff09;&#xff0c;Maven 可以从中央信息中管理项目的构建&#xff0c;报告和文档。 2.Maven 基本功能 因此实际上 Maven 的基本功能就是作为 Ja…...

    基于 Python(Flask)、JavaScript、HTML 和 CSS 实现前后端交互的详细开发过程

    以下是一个基于 Python&#xff08;Flask&#xff09;、JavaScript、HTML 和 CSS 实现前后端交互的详细开发过程&#xff1a; --- ### 一、技术选型 1. **后端**&#xff1a;Python Flask&#xff08;轻量级Web框架&#xff09; 2. **前端**&#xff1a;HTML/CSS JavaScript&…...

    STM32 RCC功能说明 复位和时钟控制RCC

    目录 背景 RCC配置时钟主要涉及两方面 程序 第1步、RCC默认初始化 第2步、等待HSE工作稳定 第3步、设置PLL时钟源以及倍频数 第4步、设置AHB总线时钟&#xff08;HCLK&#xff09; 第5步、设置PCLK1(APB1总线) 第6步、设置PCLK2(APB2总线) 第7步、FLASH存储器的配置 …...

    Windows可以永久暂停更新了

    最终效果图&#xff1a; 第一步&#xff1a; winR组合键打开运行对话框&#xff0c;输入“regedit”&#xff0c;点击“确定”或回车&#xff1a; 第二步&#xff1a; 注册表定位到“\HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\WindowsUpdate\UX\Settings”&#xff0c;新建DWO…...

    高级 Python Web 开发:基于 FastAPI 构建高效实时聊天系统与并发控制

    高级 Python Web 开发&#xff1a;基于 FastAPI 构建高效实时聊天系统与并发控制 目录 &#x1f310; WebSocket 实时通讯概述&#x1f4ac; FastAPI 中实现 WebSocket 聊天系统&#x1f527; WebSocket 并发控制与性能优化&#x1f512; WebSocket 安全性与认证机制&#x1…...

    深入理解Java虚拟机(JVM)

    JVM概述 JVM作用 java虚拟机负责装载字节码到其内部&#xff0c;解释/编译为对应平台上的机器码指令执行&#xff0c;通俗说就是将字节码转换为机器码 JVM内部构造 1、类加载部分&#xff1a;负责把硬盘上的字节码加载到内存中&#xff08;运行时数据区&#xff09; 2、运…...

    笔试面试——逻辑题

    1.n从1开始&#xff0c;每个操作可以选择对n加1或者对n加倍&#xff0c;若想获得整数2014&#xff0c;最少需要多少个操作。 2.一个池塘&#xff0c;养龙虾若干&#xff0c;请想一个办法尽量准确的估算其中有多少龙虾? 3. S先生&#xff0c;P先生&#xff0c;Q先生他们知道桌子…...

    【深度学习入门实战】基于Keras的手写数字识别实战(附完整可视化分析)

    ​ 本人主页:机器学习司猫白 ok,话不多说,我们进入正题吧 项目概述 本案例使用经典的MNIST手写数字数据集,通过Keras构建全连接神经网络,实现0-9数字的分类识别。文章将包含: 关键概念图解完整实现代码训练过程可视化模型效果深度分析环境准备 import numpy as np impo…...

    软考高级《系统架构设计师》知识点(一)

    计算机硬件 校验码 码距&#xff1a;就单个编码A:00而言&#xff0c;其码距为1&#xff0c;因为其只需要改变一位就变成另一个编码。在两个编码中&#xff0c;从A码到B码转换所需要改变的位数称为码距&#xff0c;如A:00要转换为B:11&#xff0c;码距为2。一般来说&#xff0c;…...

    用大模型学大模型01-制定学习计划

    提示词&#xff1a;我想学习大模型&#xff0c;需要AI制定一个完整的学习计划&#xff0c;并给出学习路径和学习资料。以教科书目录的方式给出学习路线 第1章&#xff1a;数学与编程基础&#xff08;4-6周&#xff09; 1.1 数学基础 线性代数&#xff08;矩阵运算、特征值分…...

    lvs的DR模式

    基于Linux的负载均衡集群软件 LVS 全称为Linux Virtual Server,是一款开源的四层(传输层)负载均衡软件 Nginx 支持四层和七层(应用层)负载均衡 HAProxy 和Nginx一样,也可同时支持四层和七层(应用层)负载均衡 基于Linux的高可用集群软件 Keepalived Keepalived是Linux…...

    mysql读写分离与proxysql的结合

    上一篇文章介绍了mysql如何设置成主从复制模式&#xff0c;而主从复制的目的&#xff0c;是为了读写分离。 读写分离&#xff0c;拿spring boot项目来说&#xff0c;可以有2种方式&#xff1a; 1&#xff09;设置2个数据源&#xff0c;读和写分开使用 2&#xff09;使用中间件…...

    【C++学习篇】C++11第二期学习

    目录 1. 可变参数模板 1.1 基本语法及原理 1.2 包扩展 1.3empalce系列接⼝ 2. lamba 2.1 lambda的语法表达式 2.2 捕捉列表 2.3 lamba的原理 1. 可变参数模板 1.1 基本语法及原理 1. C11⽀持可变参数模板&#xff0c;也就是说⽀持可变数量参数的函数模板和类模板&…...

    TextWebSocketHandler 和 @ServerEndpoint 各自实现 WebSocket 服务器

    TextWebSocketHandler 和 ServerEndpoint 都可以用于实现 WebSocket 服务器&#xff0c;但它们属于不同的技术栈&#xff0c;使用方式和功能有一些区别。以下是它们的对比&#xff1a; 1. 技术栈对比 特性TextWebSocketHandler (Spring)ServerEndpoint (Java EE/JSR-356)所属框…...

    【C++高并发服务器WebServer】-18:事件处理模式与线程池

    本文目录 一、事件处理模式1.1 Reactor模式1.2 Proactor模式1.3 同步IO模拟Proactor模式 二、线程池 一、事件处理模式 服务器程序通常需要处理三类事件&#xff1a;I/O事件、信号、定时事件。 对应的有两种高效的事件处理模式&#xff1a;Reactor和Proactor&#xff0c;同步…...

    23种设计模式的定义和应用场景-02-结构型模式-C#代码

    23种设计模式的定义和应用场景&#xff1a; 1. 创建型模式&#xff08;共5种&#xff09;&#xff1a; 单例模式&#xff08;Singleton&#xff09;、工厂方法模式&#xff08;Factory Method&#xff09;、抽象工厂模式&#xff08;Abstract Factory&#xff09;、建造者模式…...

    数据脱敏方案总结

    什么是数据脱敏 数据脱敏的定义 数据脱敏百度百科中是这样定义的&#xff1a; 数据脱敏&#xff0c;指对某些敏感信息通过脱敏规则进行数据的变形&#xff0c;实现敏感隐私数据的可靠保护。这样就可以在开发、测试和其它非生产环境以及外包环境中安全地使用脱敏后的真实数据集…...

    自然语言处理NLP入门 -- 第二节预处理文本数据

    在自然语言处理&#xff08;NLP&#xff09;中&#xff0c;数据的质量直接影响模型的表现。文本预处理的目标是清理和标准化文本数据&#xff0c;使其适合机器学习或深度学习模型处理。本章介绍几种常见的文本预处理方法&#xff0c;并通过 Python 代码进行示例。 2.1 文本清理…...

    02.10 TCP之文件传输

    1.思维导图 2.作业 服务器代码&#xff1a; #include <stdio.h> #include <string.h> #include <unistd.h> #include <stdlib.h> #include <sys/types.h> #include <sys/stat.h> #include <fcntl.h> #include <pthread.h> …...

    基于FPGA的PID算法学习———实现PID比例控制算法

    基于FPGA的PID算法学习 前言一、PID算法分析二、PID仿真分析1. PID代码2.PI代码3.P代码4.顶层5.测试文件6.仿真波形 总结 前言 学习内容&#xff1a;参考网站&#xff1a; PID算法控制 PID即&#xff1a;Proportional&#xff08;比例&#xff09;、Integral&#xff08;积分&…...

    oracle与MySQL数据库之间数据同步的技术要点

    Oracle与MySQL数据库之间的数据同步是一个涉及多个技术要点的复杂任务。由于Oracle和MySQL的架构差异&#xff0c;它们的数据同步要求既要保持数据的准确性和一致性&#xff0c;又要处理好性能问题。以下是一些主要的技术要点&#xff1a; 数据结构差异 数据类型差异&#xff…...

    【配置 YOLOX 用于按目录分类的图片数据集】

    现在的图标点选越来越多&#xff0c;如何一步解决&#xff0c;采用 YOLOX 目标检测模式则可以轻松解决 要在 YOLOX 中使用按目录分类的图片数据集&#xff08;每个目录代表一个类别&#xff0c;目录下是该类别的所有图片&#xff09;&#xff0c;你需要进行以下配置步骤&#x…...

    DBAPI如何优雅的获取单条数据

    API如何优雅的获取单条数据 案例一 对于查询类API&#xff0c;查询的是单条数据&#xff0c;比如根据主键ID查询用户信息&#xff0c;sql如下&#xff1a; select id, name, age from user where id #{id}API默认返回的数据格式是多条的&#xff0c;如下&#xff1a; {&qu…...

    C# SqlSugar:依赖注入与仓储模式实践

    C# SqlSugar&#xff1a;依赖注入与仓储模式实践 在 C# 的应用开发中&#xff0c;数据库操作是必不可少的环节。为了让数据访问层更加简洁、高效且易于维护&#xff0c;许多开发者会选择成熟的 ORM&#xff08;对象关系映射&#xff09;框架&#xff0c;SqlSugar 就是其中备受…...

    UR 协作机器人「三剑客」:精密轻量担当(UR7e)、全能协作主力(UR12e)、重型任务专家(UR15)

    UR协作机器人正以其卓越性能在现代制造业自动化中扮演重要角色。UR7e、UR12e和UR15通过创新技术和精准设计满足了不同行业的多样化需求。其中&#xff0c;UR15以其速度、精度及人工智能准备能力成为自动化领域的重要突破。UR7e和UR12e则在负载规格和市场定位上不断优化&#xf…...

    毫米波雷达基础理论(3D+4D)

    3D、4D毫米波雷达基础知识及厂商选型 PreView : https://mp.weixin.qq.com/s/bQkju4r6med7I3TBGJI_bQ 1. FMCW毫米波雷达基础知识 主要参考博文&#xff1a; 一文入门汽车毫米波雷达基本原理 &#xff1a;https://mp.weixin.qq.com/s/_EN7A5lKcz2Eh8dLnjE19w 毫米波雷达基础…...

    【FTP】ftp文件传输会丢包吗?批量几百个文件传输,有一些文件没有传输完整,如何解决?

    FTP&#xff08;File Transfer Protocol&#xff09;本身是一个基于 TCP 的协议&#xff0c;理论上不会丢包。但 FTP 文件传输过程中仍可能出现文件不完整、丢失或损坏的情况&#xff0c;主要原因包括&#xff1a; ✅ 一、FTP传输可能“丢包”或文件不完整的原因 原因描述网络…...

    C# winform教程(二)----checkbox

    一、作用 提供一个用户选择或者不选的状态&#xff0c;这是一个可以多选的控件。 二、属性 其实功能大差不差&#xff0c;除了特殊的几个外&#xff0c;与button基本相同&#xff0c;所有说几个独有的 checkbox属性 名称内容含义appearance控件外观可以变成按钮形状checkali…...

    从实验室到产业:IndexTTS 在六大核心场景的落地实践

    一、内容创作&#xff1a;重构数字内容生产范式 在短视频创作领域&#xff0c;IndexTTS 的语音克隆技术彻底改变了配音流程。B 站 UP 主通过 5 秒参考音频即可克隆出郭老师音色&#xff0c;生成的 “各位吴彦祖们大家好” 语音相似度达 97%&#xff0c;单条视频播放量突破百万…...