《Disney +》 迪士尼、Marvel、彼思、星球大戰…  今年的「Day of Play」也將照常舉辦!這次不再只是特賣而已!   「矢琶羽」&「朱紗丸」參戰決定!「鬼滅之刃 火之神血風譚」免費更新第2彈情報公開!   「Pokémon GO」4月的社群日主角是「藤藤蛇」!另外「天氣週」活動現正舉行中!   《Ratchet & Clank: Rift Apart》的跨次元旋律將於7月11日登場   PS4™『Virtua Fighter 5 Ultimate Showdown』於今日在PS Plus每月遊戲上推出!帶來嶄新視覺圖像與功能的最新作!   「魔物獵人 特別節目 2021.5.26」確定播出!更新情報與最新短片!   「Riot Games Store Japan」開店決定!「英雄聯盟」及「特戰英豪」官方周邊商品可以在日本國內購買!   SAMURAI SPIRITS × GUILTY GEAR!獨眼・獨臂女劍士梅喧參戰! 

AWK 取得欄位的「最後」與「倒數第二個值」的方法

商業

使用 AWK Parse access.log,在某些特定條件會發生抓錯欄位的情況(若使用 空白 切割,沒使用 " 搭配切割,就容易抓錯欄位)

不過經常快速處理,都是使用空白切割即可,那要抓最後的欄位,比較簡單的方式就是一樣「空白切割」或「" 切割」,只是資料抓法是從後面往前抓。

  • AWK 要取得最後一個欄位的值是使用: $NF
  • AWK 要取得倒數第二個欄位的值是使用: $(NF-1)
  • 由後往前取,就繼續 -2、-3... 下去即可

所以要抓 access.log 倒數第二欄 和 第二欄,範例如下:

  • cat access.log | awk -F" '{print $(NF-2),$2}' # 使用 " 切割

想抓超過 500ms 的網址(註:elapsed 並不是預設就有,需要另外加上)

  • cat access.log | awk -F" '{print $NF,$2}' | awk '{print $1,$3}' | sed 's/elapsed=//' | sed 's/us//' | awk '{if ($1 > 500000) {print $1, $2}}'
  • cat access.log | awk -F" '{print $(NF-2),$2}' | awk '{print $1,$3}' | sed 's/elapsed=//' | sed 's/us / /' | awk '{if ($1 > 500000) {print $1, $2}}'
Tsung

隨機商業新聞

Disney Plus