ngx lua获取时间戳的几种方式

原创自由de单车 最后发布于2017-02-14 14:58:43 阅读数 18218 收藏

在ngx_lua里,获取时间相关信息的方式大概有4种(见下面代码):

print(string.format("%s, %s, %s, %s", ngx.time(), os.time(), os.clock(), ngx.now()))
ngx.exit(200)

-- 以上代码会输出:1486971340, 1486971340, 209.77, 1486971340.422

可见,通过os.clock()获取到的并不是时间戳,它获取的是一个程序使用CPU时间的一个近似值,而我们的目的是获取时间戳,所以排除掉这种方法。

再看ngx.time()和os.time(),它们返回的都是秒级精度的时间戳,而ngx.now()返回的是毫秒级精度的时间戳。做开发时可以根据实际的精度需要来选择不同的获取方式。

那么,ngx.time()和os.time()有什么区别吗?
有,os.time()会涉及系统调用,而ngx.time()不会,所以ngx.time()的性能会比os.time()高。

但在使用ngx.time()和ngx.now()的时候,有一点是要注意的,就是通过这两种方式获取到的只是nginx缓存起来的时间戳,不是实时的。所以有时候会出现一些比较奇怪的现象,比如下面代码:

local t1 = ngx.now()
for i=1,1000000 do
end
local t2 = ngx.now()
print(t1, ",", t2) -- 输出1487053211.321,1487053211.321
ngx.exit(200)

正常来说,t2应该大于t1才对,但由于nginx没有及时更新(缓存的)时间戳,所以导致t2和t1获取到的时间戳是一样的。那么怎样才能强迫nginx更新缓存呢?调用多一个ngx.update_time()函数即可:

local t1 = ngx.now()
for i=1,1000000 do
end
ngx.update_time()
local t2 = ngx.now()
print(t1, ",", t2) -- 输出1487054647.584,1487054647.586
ngx.exit(200)

可见,获取到的时间戳已经发生了改变。
————————————————
版权声明:本文为CSDN博主「自由de单车」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/ljfrocky/java/article/details/55052079

原文地址:https://www.cnblogs.com/lgj8/p/12642703.html

时间: 2024-10-01 05:27:09

ngx lua获取时间戳的几种方式的相关文章

获取时间戳的三种方式

console.log(new Date().getTime()); console.log(new Date().valueOf()); console.log(+new Date()); console.log(Date.now()); 原文地址:https://www.cnblogs.com/ustc-yy/p/12074499.html

C#获取时间戳的几种方式

Console.WriteLine(Convert.ToDouble(DateTime.UtcNow.Ticks - 621355968000000000) / (10 * 1000 * 1000)); TimeSpan ts1 = DateTime.UtcNow - new DateTime(1970, 1, 1, 0, 0, 0, 0); TimeSpan ts2 = new TimeSpan(DateTime.Now.ToUniversalTime().Ticks - 6213559680

【Struts2】Struts2获取session的三种方式

1.Map<String,Object> map =  ActionContext.getContext().getSession(); 2.HttpSession session = ServletActionContext.getRequest().getSession(); 3.让Action实现SessionAware接口,并实现public void setSession(Map<String, Object> session) {} 方法,Struts2会在实例化Act

AngularJS中获取数据源的几种方式

在AngularJS中,可以从$rootScope中获取数据源,也可以把获取数据的逻辑封装在service中,然后注入到app.run函数中,或者注入到controller中.本篇就来整理获取数据的几种方式. ■ 数据源放在$rootScope中 var app = angular.module("app",[]); app.run(function($rootScope){ $rootScope.todos = [ {item:"",done:true}, {it

java中获取路径的几种方式

总是忘记, 备份一下,方便下次用. 第一种: File directory = new File("");//参数为空 String courseFile = directory.getCanonicalPath() ;System.out.println(courseFile); 结果:C:\Documents and Settings\Administrator\workspace\projectName获取当前类的所在工程路径; 第二种: File f = new File(th

java动态获取WebService的两种方式(复杂参数类型)

java动态获取WebService的两种方式(复杂参数类型) 第一种: @Override public OrderSearchListRes searchOrderList(Order_FlightOrderSearchRequest request) { Object myAllMessage; OrderSearchListRes response = null; try { String endpoint = carGlobalSetting.getEndpoint(); JaxWsD

点击li获取下标的几种方式(原生JS实现)

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" con

Spring在代码中获取bean的几种方式(转:http://www.dexcoder.com/selfly/article/326)

方法一:在初始化时保存ApplicationContext对象 方法二:通过Spring提供的utils类获取ApplicationContext对象 方法三:继承自抽象类ApplicationObjectSupport 方法四:继承自抽象类WebApplicationObjectSupport 方法五:实现接口ApplicationContextAware 方法六:通过Spring提供的ContextLoader 获取spring中bean的方式总结: 方法一:在初始化时保存Applicati

struts2的action从request获取参数值的几种方式

使用jquery框架的ajax能够方便的向后台传递参数,以$.post为例,参数有2种方式字符串和键值对: $.post(url, "name=aty&age=25")和$.post(url, {"name":"aty","age":25}).显然,使用json的方式比使用字符串拼接要方 便.对于后台的action来说,这2种方式是等价的,而且jquery也提供了param.serialize.serialize能够实