回答編集履歴

1 誤字と細かい表現を修正

amanoese

amanoese score 132

2019/04/19 19:19  投稿

```bash
$ cat log_file | sort -nr -t '/' -k7,7
Apr 18 00:14:07 localhost haproxy[19224]: 192.168.1.77:53821 [18/Apr/2019:00:14:06.487] frontend_nxxx xxx_servers/xxx_servers2 3/0/0/1168/1171 200 6754 - - --NI 2/2/0/0/0 0/0 "GET /login HTTP/1.1"
Apr 18 00:14:07 localhost haproxy[19224]: 192.168.1.77:53821 [18/Apr/2019:00:14:06.487] frontend_nxxx xxx_servers/xxx_servers2 3/0/0/300/1171 200 6754 - - --NI 2/2/0/0/0 0/0 "GET /login HTTP/1.1"
Apr 18 00:14:07 localhost haproxy[19224]: 192.168.1.77:53821 [18/Apr/2019:00:14:06.487] frontend_nxxx xxx_servers/xxx_servers2 3/0/0/200/1171 200 6754 - - --NI 2/2/0/0/0 0/0 "GET /login HTTP/1.1"
Apr 18 00:13:06 localhost haproxy[19224]: 192.168.1.77:53780 [18/Apr/2019:00:13:06.501] frontend_xxx xxx_servers/xxx_servers2 4/0/0/155/160 200 6764 - - --NI 2/2/0/0/0 0/0 "GET /login HTTP/1.1"
```
ログをlog_fileというファイルに保存しており、またデータが2行と少なかったので「200」と「300」のログを追加しています。
catの部分を変更すれば標準入力も処理できます。
またhaproxyについて詳しくないで間違っているかもしれないですが、
その場合は冗長ですが下記のコードで処理できます。
```bash
$ cat log_file | awk '{print $10,$0}' | sort -nr -t '/' -k4,4 | cut -d ' ' -f 2-
Apr 18 00:14:07 localhost haproxy[19224]: 192.168.1.77:53821 [18/Apr/2019:00:14:06.487] frontend_nxxx xxx_servers/xxx_servers2 3/0/0/1168/1171 200 6754 - - --NI 2/2/0/0/0 0/0 "GET /login HTTP/1.1"
Apr 18 00:14:07 localhost haproxy[19224]: 192.168.1.77:53821 [18/Apr/2019:00:14:06.487] frontend_nxxx xxx_servers/xxx_servers2 3/0/0/300/1171 200 6754 - - --NI 2/2/0/0/0 0/0 "GET /login HTTP/1.1"
Apr 18 00:14:07 localhost haproxy[19224]: 192.168.1.77:53821 [18/Apr/2019:00:14:06.487] frontend_nxxx xxx_servers/xxx_servers2 3/0/0/200/1171 200 6754 - - --NI 2/2/0/0/0 0/0 "GET /login HTTP/1.1"
Apr 18 00:13:06 localhost haproxy[19224]: 192.168.1.77:53780 [18/Apr/2019:00:13:06.501] frontend_xxx xxx_servers/xxx_servers2 4/0/0/155/160 200 6764 - - --NI 2/2/0/0/0 0/0 "GET /login HTTP/1.1"
```
これで大丈夫でしょうか?

思考するエンジニアのためのQ&Aサイト「teratail」について詳しく知る