kong 网关日志格式修改

kong 网关日志格式修改kong网关日志格式修改kong网关默认日志在/usr/local/kong/logs,主要有access.log,admin_access.log,error.log,access.log和nginx的access日志类似,这里会记录所所有通过kong网关的日志。有些时候这些日志并不能满足我们的需要,因此需要修改日志格式。当发现/usr/local/kong/下面有nginx-kon…

大家好,又见面了,我是你们的朋友全栈君。

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]

接下来我们就可以对日志进行进一步处理了。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/135735.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 窗宽窗位

    窗宽窗位转自“CT诊断学”中的窗宽窗位部分。窗宽与窗位CT能识别人体内2000个不同灰阶的密度差别。而人的眼睛却只能分辨16个灰阶度。因此,人眼在CT图像上能分辨的CT值应为125Hu(2000/16)。换句话说,人体内不同组织CT值只有相差125Hu以上,才能为人眼所识别。人体软组织CT值多变化在20-50Hu之间,人眼就无法识别。为此,必须进行分段观察,才能使

    2022年6月15日
    66
  • 高德地图-设置点标注的文本标签「建议收藏」

    高德地图-设置点标注的文本标签「建议收藏」1、问题背景   高德地图中,设置选中位置,并自定义图标和文字提示2、实现源码 高德地图-设置点标注的文本标签 varmap=newAMap.Map(“container”,{ resizeEnable:true, center:[115.397428,41.90

    2022年5月22日
    174
  • 免费开源好用还佛系的国产PDF软件:pdf补丁丁下载 | 含pdf补丁丁使用手册[通俗易懂]

    免费开源好用还佛系的国产PDF软件:pdf补丁丁下载 | 含pdf补丁丁使用手册[通俗易懂]PDF补丁丁(PDFPatcher)是一款绿色免费开源且完全免费的多功能国产PDF软件,基于.NET开发,具有PDF编辑、PDF书签编辑、PDF书签导入/导出、PDF创建、PDF拆分、PDF批量重命名、PDF阅读、PDF合并、光学OCR文字识别、PDF图片和内容提取以及专为开发者同行准备的文档结构谈查起等一系列诸多实用功能,如果大家还不知道什么软件可以修改PDF文件的话,推荐大家务必试试免费开源还佛系并提供最新版本的pdf补丁丁下载。

    2025年8月22日
    3
  • RNN详解及BPTT详解

    RNN详解及BPTT详解 版权声明:转载请注明出处 https://blog.csdn.net/zhaojc1995/article/details/80572098 本文部分参考和摘录了以下文章,在此由衷感谢以下作者的分享!https://zhuanlan.zhihu.com/p/28…

    2022年6月23日
    42
  • win10安装JDK1.8及配置java环境变量详解

    win10安装JDK1.8及配置java环境变量详解首先下载一个jdk,可以通过这个链接下载:https://pan.baidu.com/s/1aP6SdL8UQK_C2GvALLb6Wg接下来就是安装,非常的简单,如下图所示:双击下载的文件,出现该界面,点击下一步。安装路径我们选择默认的,当然,我们也可也修改安装路径,但一定要记得安装路径,这里我们选择默认的。点击下一步。这里我们还是默认的安装路径。点击下一步。到此,安装就完成了…

    2022年7月23日
    7
  • 在pycharm新建项目时配置anaconda环境

    在pycharm新建项目时配置anaconda环境在 pycharm 新建项目时配置 anaconda 环境的解决办法

    2025年6月26日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号