当前位置:首页 > 科技  > 软件

Nginx map 实现时间格式转换

来源: 责编: 时间:2023-09-18 21:42:26 222观看
导读哈喽大家好,我是咸鱼最近我们需要把 Nginx 的日志接入到自研的日志采集平台上,但是这个平台只支持 JSON 格式,所以需要把 Nginx 日志格式改成 JSON 格式例如下面这样的效果刚开始在主配置文件 nginx.conf 中定义了一个名

哈喽大家好,我是咸鱼KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

最近我们需要把 Nginx 的日志接入到自研的日志采集平台上,但是这个平台只支持 JSON 格式,所以需要把 Nginx 日志格式改成 JSON 格式KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

例如下面这样的效果KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

刚开始在主配置文件 nginx.conf 中定义了一个名叫 json 的日志格式字段KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

验证的时候其他内容没啥问题,但是时间是2023-09-12T13:54:22+08:00 这样子的,不太符合预期KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

咸鱼想着把 $time_iso8601 变量中的年月日时分秒分别提取出来然后用变量去接受它,如下所示:KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

我自定义了一个时间格式 $year-$month-$day $hour:$minutes:$seconds:000,然后接着用了一个 if 语句用于检查请求的时间是否匹配 ISO8601 时间格式(例如:2023-09-12T13:54:22+08:00)KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

如果匹配,它将执行其中的代码块。在代码块中,使用正则表达式提取时间的年、月、日、小时、分钟和秒,并将它们赋值给变量 $year、$month、$day、$hour、$minutes 和 $secondsKkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

但是 nginx -t 检测的时候我发现 if 语句不能够放在 http 块内,否则会报错KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

在 Nginx 中,if 语句主要用于在 server 或 location 块内设置条件,以便根据请求的属性来执行不同的配置。if 语句通常应该包含在 server 或 location 块内,而不是直接放在 http 块中KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

如果将 if 语句放在一个一个 server 块中,这不得累死我(有很多个 server 块),而且后期维护也不方便KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

所以如何将自定义变量在全局配置中生效则成为了一个问题KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

map

KkW28资讯网——每日最新资讯28at.com

map 指令是由 ngx_http_map_module 模块提供的,是 Nginx 配置文件中的一种用于创建变量映射的指令KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

模块链接:https://nginx.org/en/docs/http/ngx_http_map_module.htmlKkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

它允许我们将一个或多个输入值映射到一个输出值,类似于字典或哈希表的概念。map 指令通常用于根据特定条件为请求设置自定义变量,或者执行基于请求属性的条件控制KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

比较常见的 map 用法是通过 map 来实现允许多个域名跨域访问的问题KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

语法如下:KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

其中:KkW28资讯网——每日最新资讯28at.com

  • $variable 输入变量,通常是 nginx 的内置变量。
  • $new_variable 输出变量,它将根据输入值的映射设置为特定的结果。
  • value1, value2, ... 输入值,可以列出多个值。
  • result1, result2, ... 与相应输入值相关联的输出结果。
  • default 一个可选项,表示如果没有匹配的输入值,将使用默认结果

KkW28资讯网——每日最新资讯28at.com

需要注意的是,map 只能放在 http 块中KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

有了 map,我们就可以轻易的把 $time_iso8601 变量中的 ISO 8601 格式的时间戳转换为指定的时间格式,然后存储到自定义变量 $log_time 中KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

我们可以看到:KkW28资讯网——每日最新资讯28at.com

  • 输入变量为 $time_iso8601,输出变量为 $log_time;
  • default "":如果没有匹配任何条件,将使用空字符串作为 $log_time 的值
  • "~^(?<year>/d{4})-(?<month>/d{2})-(?<day>/d{2})T(?<hour>/d{2}):(?<minutes>/d{2}):(?<seconds>/d{2})":这是一个正则表达式条件,它用于匹配 ISO 8601 格式的时间戳。该正则表达式包含了多个捕获组(使用 ?<name> 语法),用于从时间戳中提取年、月、日、小时、分钟和秒的值
  • "${year}-${month}-${day} ${hour}:${minutes}:${seconds}":这是与正则表达式条件匹配时设置的输出值。当正则表达式条件匹配时,它会将捕获组中提取的年、月、日、小时、分钟和秒的值组合成一个自定义的时间格式,然后将该值设置为 $log_time 变量的值

KkW28资讯网——每日最新资讯28at.com

例如,如果 $time_iso8601 的值是 "2023-09-09T14:30:00",则 $log_time 将被设置为 "2023-09-09 14:30:00"KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

然后我们再把 $log_time 放进我们自定义的日志格式里面,完整配置如下KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

最后我们验证一下KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

KkW28资讯网——每日最新资讯28at.com

本文链接://www.dmpip.com//www.dmpip.com/showinfo-26-10492-0.htmlNginx map 实现时间格式转换

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 反驳来了!放弃TypeScript?说明你无知!

下一篇: 19个JavaScript数组常用方法总结! 赶快收藏吧!

标签:
  • 热门焦点
  • 一加Ace2 Pro真机揭晓 钛空灰配色质感拉满

    一加Ace2 Pro真机揭晓 钛空灰配色质感拉满

    终于,在经过了几波预热之后,一加Ace2 Pro的外观真机图在网上出现了。还是博主数码闲聊站曝光的,这次的外观设计还是延续了一加11的方案,只是细节上有了调整,例如新加入了钛空灰
  • 5月iOS设备性能榜:M1 M2依旧是榜单前五

    5月iOS设备性能榜:M1 M2依旧是榜单前五

    和上个月一样,没有新品发布的iOS设备性能榜的上榜设备并没有什么更替,仅仅只有跑分变化而产生的排名变动,刚刚开始的苹果WWDC2023,推出的产品也依旧是新款Mac Pro、新款Mac Stu
  • JavaScript 混淆及反混淆代码工具

    JavaScript 混淆及反混淆代码工具

    介绍在我们开始学习反混淆之前,我们首先要了解一下代码混淆。如果不了解代码是如何混淆的,我们可能无法成功对代码进行反混淆,尤其是使用自定义混淆器对其进行混淆时。什么是混
  • 虚拟键盘 API 的妙用

    虚拟键盘 API 的妙用

    你是否在遇到过这样的问题:移动设备上有一个固定元素,当激活虚拟键盘时,该元素被隐藏在了键盘下方?多年来,这一直是 Web 上的默认行为,在本文中,我们将探讨这个问题、为什么会发生
  • Temu起诉SHEIN,跨境电商战事升级

    Temu起诉SHEIN,跨境电商战事升级

    来源 | 伯虎财经(bohuFN)作者 | 陈平安日前据外媒报道,拼多多旗下跨境电商平台Temu正对竞争对手SHEIN提起新诉讼,诉状称Shein&ldquo;利用市场支配力量强迫服装厂商与之签订独家
  • 共享单车的故事讲到哪了?

    共享单车的故事讲到哪了?

    来源丨海克财经与共享充电宝相差不多,共享单车已很久没有被国内热点新闻关照到了。除了一再涨价和用户直呼用不起了。近日多家媒体再发报道称,成都、天津、郑州等地多个共享单
  • 三星Galaxy Z Fold/Flip 5国行售价曝光 :最低7499元/12999元起

    三星Galaxy Z Fold/Flip 5国行售价曝光 :最低7499元/12999元起

    据官方此前宣布,三星将于7月26日也就是明天在韩国首尔举办Unpacked活动,届时将带来带来包括Galaxy Buds 3、Galaxy Watch 6、Galaxy Tab S9、Galaxy
  • iQOO Neo8 Pro真机谍照曝光:天玑9200+和V1+旗舰双芯加持

    iQOO Neo8 Pro真机谍照曝光:天玑9200+和V1+旗舰双芯加持

    去年10月,iQOO推出了iQOO Neo7系列机型,不仅搭载了天玑9000+,而且是同价位唯一一款天玑9000+直屏旗舰,一经上市便受到了用户的广泛关注。在时隔半年后,
  • 亲历马斯克血洗Twitter,硅谷的苦日子在后头

    亲历马斯克血洗Twitter,硅谷的苦日子在后头

    文/刘哲铭  编辑/李薇  马斯克再次挥下裁员大刀。  美国时间11月14日,Twitter约4400名外包员工遭解雇,此次被解雇的员工的主要工作为内容审核等。此前,T
Top
Baidu
map