kong 網關日誌格式修改

kong 網關日誌格式修改


kong網關默認日誌在/usr/local/kong/logs,主要有access.log,admin_access.log,error.log,access.log和nginx的access日誌類似,這裏會記錄所所有通過kong網關的日誌。

有些時候這些日誌並不能滿足我們的需要,因此需要修改日誌格式。
當發現/usr/local/kong/下面有nginx-kong.conf,nginx.conf,nginx-kong-stream.conf這些配置文件時,以爲這就是日誌的配置文件,結果不管怎麼修改這些日誌格式,重啓後,配置文件都會還原。
最後查詢原因才得知,這些文件時kong網關啓動時通過模板渲染方式生成的,每次重啓都會重新生成,而真正的配置文件卻在另外一個地方。
這裏要介紹下kong的安裝方式:
本文的服務器環境爲ubuntu,安裝請參考:https://docs.konghq.com/install/ubuntu/

一、修改配置

修改路徑:/usr/local/share/lua/5.1/kong/templates/nginx_kong.lua

upstream kong_upstream {
    server 0.0.0.1;
    balancer_by_lua_block {
        Kong.balancer()
    }

# injected nginx_http_upstream_* directives
> for _, el in ipairs(nginx_http_upstream_directives) do
    $(el.name) $(el.value);
> end
}
###添加log_format日誌格式
log_format  main  'remote_addr=[$remote_addr] http_x_forward=[$http_x_forwarded_for] time=[$time_local] request=[$request] '
        'status=[$status] byte=[$bytes_sent] elapsed=[$request_time] upstream_connect_time=[$upstream_connect_time] upstream_header_time=[$upstream_header_time] upstream_response_time=[$upstream_response_time] ' 'refer=[$http_referer] ua=[$http_user_agent] gzip=[$gzip_ratio] ' 'msec=[$msec] http_host=[$http_host] http_accept=[$http_accept|$http_accept_encoding|$http_accept_language]';

###
server {
    server_name kong;
> for i = 1, #proxy_listeners do
    listen $(proxy_listeners[i].listener);

修改完上面的配置後,還需要在同一個配置文件中添加兩處配置,見下面操作:

 #修改兩處access.log文件配置
 ·····第一處配置·····
 server {
    server_name kong;
> for i = 1, #proxy_listeners do
    listen $(proxy_listeners[i].listener);
> end
    error_page 400 404 408 411 412 413 414 417 494 /kong_error_handler;
    error_page 500 502 503 504 /kong_error_handler;

    access_log ${{PROXY_ACCESS_LOG}} main;    ##此行結尾處添加main
    error_log ${{PROXY_ERROR_LOG}} ${{LOG_LEVEL}};

    client_body_buffer_size ${{CLIENT_BODY_BUFFER_SIZE}};
 ··················    
 ······第二處配置·····
  if #admin_listeners > 0 then
server {
    server_name kong_admin;
> for i = 1, #admin_listeners do
    listen $(admin_listeners[i].listener);
> end

    access_log ${{ADMIN_ACCESS_LOG}} main;      ##此行結尾處添加main
    error_log ${{ADMIN_ERROR_LOG}} ${{LOG_LEVEL}};
 ······

二、重啓kong,查看access.log日誌格式

執行下面命令重啓kong
# kong reload /etc/kong/kong.conf
查看日誌:

remote_addr=[39.96.130.100] http_x_forward=[118.74.245.171, 112.124.159.116] time=[17/Oct/2019:18:32:27 +0800] request=[GET /coach_core/api/v2/klass/node?app_version=2.5.4&coach_id=39709c50-a793-11e9-959e-49d70ecedf82&device_name=iPad%20mini%204&device_system=iOS13.1.2&device_type=2&end_date=2020-02-17&start_date=2019-10-17&time_zone=8 HTTP/1.1] status=[200] byte=[1762] elapsed=[0.018] upstream_connect_time=[0.000] upstream_header_time=[0.012] upstream_response_time=[0.012] refer=[-] ua=[KPL_teacher_appstore/2.5.4 (iPad; iOS 13.1.2; Scale/2.00)] gzip=[-] msec=[1571308347.571] http_host=[p.coach.kuaipeilian.com] http_accept=[application/vnd.lumen.v1+json|gzip, deflate|zh-Hans-CN;q=1]

接下來我們就可以對日誌進行進一步處理了。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章