zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    【CF1015D】Walking Between Houses(构造,贪心)
    【CF1068D】Array Without Local Maximums(计数DP)
    【CF1068C】Colored Rooks(构造)
    172.处理机控制与杂项指令
    171.控制转移指令
    170.串处理指令
    169.逻辑指令
    168.算术指令
    Volume 1. Big Number(uva)
    Volume 1. String(uva)
  • 原文地址:https://www.cnblogs.com/lgj8/p/12642703.html
Copyright © 2011-2022 走看看