web-dev-qa-db-ja.com

GoAccessのHaproxyログカスタムフォーマット

リバースプロキシおよびロードバランサーとして機能するHaproxyでGoAccessを使用したいと思います。

私の目標は、Apache2とまったく同じように見えるカスタムログ形式を作成することです(デフォルトのgoaccess設定と互換性があります)。

これまで私はしました

capture request header Referrer len 64

capture request header Content-Length len 10

capture request header User-Agent len 64

log-format %si:%sp\ %ci\ -\ -\ [%t]\ "%r"\ %ST\ %B\ "%%Referrer"\ "%%User-Agent"

私のhaproxyバージョンはHA-Proxyバージョン1.5.14です2015/07/02

キャプチャされたリクエストからリファラーとユーザーエージェントを抽出する方法がわかりません。マニュアルにカスタムログ形式について役立つものが見つかりません。

[〜#〜]編集[〜#〜]

%hrlは、キャプチャされたリクエストヘッダーの文字列リストであることがわかりました。キーまたはインデックスで値を抽出することは可能ですか?

3
daredesm

私は独自のログ形式を作成することでこれを解決しました:

GoAccess

time-format %H:%M:%S

date-format %d/%b/%Y

log-format %^ %^ %^ %^ %^ %^ %h [%d:%t.%^] "%r" %s %b "{%R|%u}"

# %^ - skipped token
# %h - user ip
# %d - date-format
# %t - time-format
# %r - request e.g. GET /something
# %s - server status code
# %b - data response length
# %R - referer - very important if you want to know where your users come from
# %u - user agent

# There is so many skipped tokens because my haproxy put some extra information in every line or rsyslog(?)
# Sample line:
#
# Mar 22 09:09:06 server haproxy[PID]: 10.60.10.50:80 1.2.3.4 [22/Mar/2016:09:08:56.989] "POST /UIDL/?v-uiId=0 HTTP/1.1" 200 334 "{https://www.referer.com/|Mozilla/5.0 (Linux; Android 4.4.4; GT-I9060I Build/KTU84P) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/47.0.2526.83 Mobile Saf}"

Haproxy

capture request header Referer len 128
capture request header User-Agent len 128

log-format %si:%sp\ %ci\ [%t]\ "%r"\ %ST\ %B\ "%hr"

# %si - your server ip - very usefull if you have multiple application
# %sp - your server port
# %ci - user ip
# %t  - datetime in haproxy format
# %r  - request
# %ST - status code
# %B  - data reponse length
# %hr - captured headers separated by "|" (Referer|User-Agent)
3
daredesm