- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章自定义Laravel (monolog)日志位置,并增加请求ID的实现由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
修改 bootstrap/app.php 文件 。
1
2
3
4
5
6
7
8
|
$app
->configureMonologUsing(
function
(
$monolog
)
use
(
$app
) {
$monolog
->pushHandler(
(
new
Monolog\Handler\RotatingFileHandler(
'/var/logs/app/laravel'
,
$app
->make(
'config'
)->get(
'app.log_max_files'
, 5)
))->setFormatter(
new
Monolog\Formatter\LineFormatter(null, null, true, true))
);
});
|
添加以后写入日志文件为:
1
2
|
-rw-r--r-- 1 web web 93 Dec 18 15:52 laravel-2017-12-17
-rw-r--r-- 1 web web 279 Dec 18 16:10 laravel-2017-12-18
|
参考:Laravel 的错误和日志记录 。
或者 。
创建app\Providers\LogServiceProvider.php 文件 。
修改 config\app.php providers 增加 。
1
|
App\Providers\LogServiceProvider::
class
|
然后 App\Providers\LogServiceProvider.php 内容如下 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
<?php
namespace
App\Providers;
use
Illuminate\Log\LogServiceProvider
as
SysServiceProvider;
use
Illuminate\Log\Writer;
class
LogServiceProvider
extends
SysServiceProvider
{
protected
function
configureSingleHandler(Writer
$log
)
{
$log
->useFiles(
'/var/logs/app/laravel.log'
,
$this
->logLevel()
);
}
protected
function
configureDailyHandler(Writer
$log
)
{
$log
->useDailyFiles(
'/var/logs/app/laravel.log'
,
$this
->maxFiles(),
$this
->logLevel()
);
}
}
|
增加请求ID request id 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
|
namespace
App\Providers;
use
Illuminate\Support\ServiceProvider;
use
Carbon\Carbon;
class
LogServiceProvider
extends
ServiceProvider
{
protected
$log_file
;
/**
* Bootstrap any application services.
* @return void
*/
public
function
boot()
{
//
}
/**
* Register any application services.
* @return void
*/
public
function
register()
{
$this
->load_request_id();
$this
->log_configure();
}
/**
* 生成 request_id
* @return void
*/
protected
function
load_request_id()
{
define(
'REQUEST_ID'
, config(
'app.log_prefix'
).Carbon::now()->timestamp );
}
/**
* 注册 monolog pushHandler
* @return void
*/
protected
function
log_configure()
{
$log_file
=
$this
->getLogFile();
$log_max_files
=
$this
->getLogMaxFiles();
/**
* @doc https://d.laravel-china.org/docs/5.4/errors#自定义-Monolog-设置
*/
$this
->app->configureMonologUsing(
function
(
$monolog
)
use
(
$log_file
,
$log_max_files
) {
$monolog
->pushHandler(
(
new
\Monolog\Handler\RotatingFileHandler(
$log_file
,
$log_max_files
))->setFormatter(
new
\Monolog\Formatter\LineFormatter(
"[%datetime%] ["
.REQUEST_ID.
"] %channel%.%level_name%: %message% %context% %extra%\n"
, null, true, true))
);
});
}
protected
function
getLogMaxFiles()
{
return
config(
'app.log_max_files'
, 5);
}
/**
* @return mixed
*/
protected
function
getLogFile()
{
if
(
is_null
(
$this
->log_file) )
{
$this
->log_file = rtrim(config(
'app.log_path'
) , DIRECTORY_SEPARATOR ).
"/laravel.log"
;
}
return
$this
->log_file;
}
}
|
优化以后 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
|
namespace
App\Providers;
use
Illuminate\Support\ServiceProvider;
use
Monolog\Formatter\LineFormatter;
use
Monolog\Handler\RotatingFileHandler;
use
Carbon\Carbon;
use
Monolog\Logger;;
use
ReflectionClass;
class
LogServiceProvider
extends
ServiceProvider
{
protected
$log_file
;
/**
* Bootstrap any application services.
*
* @return void
*/
public
function
boot()
{
//
}
/**
* Register any application services.
*
* @return void
*/
public
function
register()
{
$this
->loadRequestId();
/**
* 根据日期来分割日志
*/
$this
->useDailyFiles();
}
protected
function
loadRequestId()
{
define(
'REQUEST_ID'
, config(
'app.log_prefix'
).Carbon::now()->timestamp );
}
/**
* 根据日期来分割日志
*/
protected
function
useDailyFiles()
{
$handler
=
$this
->getDailyHandler()->setFormatter(
$this
->getDefaultFormatter() );
$errorHandler
=
$this
->getDailyHandler(Logger::ERROR)->setFormatter(
$this
->getDefaultFormatter() );
$this
->app->configureMonologUsing(
function
(
$monolog
)
use
(
$handler
,
$errorHandler
)
{
$monolog
->pushHandler(
$handler
);
$monolog
->pushHandler(
$errorHandler
);
});
}
/**
* 设置 日志 行格式
* @return LineFormatter
*/
protected
function
getDefaultFormatter()
{
$format
=
"[%datetime%] ["
.REQUEST_ID.
"] %channel%.%level_name%: %message% %context% %extra%\n"
;
return
new
LineFormatter(
$format
, null, true, true);
}
/**
* 根据日志区分
* @return \Monolog\Handler\RotatingFileHandler
*/
protected
function
getDailyHandler(
$level
= Logger::DEBUG)
{
return
new
RotatingFileHandler(
$this
->logPath().
$this
->logName(
$level
) ,
$this
->maxFiles() ,
$level
);
}
/**
* 日志文件最多个数
* @return int
*/
protected
function
maxFiles()
{
if
(
$this
->app->bound(
'config'
)) {
return
$this
->app->make(
'config'
)->get(
'app.log_max_files'
, 30);
}
return
0;
}
/**
* 日志文件名称
* @return mixed
*/
protected
function
logPath()
{
$logPath
=
$this
->app->storagePath().
"/logs/"
;
if
(
$this
->app->bound(
'config'
))
{
$logPath
=
$this
->app->make(
'config'
)->get(
'app.log_path'
,
$logPath
);
}
return
$logPath
;
}
/**
* log 完整文件名
* @param int $level
* @return string
*/
protected
function
logName(
$level
= Logger::DEBUG )
{
return
$this
->getAppName().
'-'
.
$this
->getLevelName(
$level
).
".log"
;
}
/**
* 获取项目app
* @return mixed
*/
protected
function
getAppName()
{
return
$this
->app->make(
'config'
)->get(
'app.name'
);
}
/**
* 获取log错误级别名称
* @param $level
* @return mixed
*/
protected
function
getLevelName(
$level
)
{
$r
=
new
ReflectionClass( Logger::
class
);
$constants
=
array_flip
(
$r
->getConstants() );
return
$constants
[
$level
];
}
}
|
以上这篇自定义Laravel (monolog)日志位置,并增加请求ID的实现就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我.
原文链接:https://blog.csdn.net/Webben/article/details/78834337 。
最后此篇关于自定义Laravel (monolog)日志位置,并增加请求ID的实现的文章就讲到这里了,如果你想了解更多关于自定义Laravel (monolog)日志位置,并增加请求ID的实现的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我需要从 1024 增加 FD_SETSIZE 值至 4096 .我知道最好使用 poll()/epoll()但我想了解什么是优点/缺点。主要问题是:我要重新编译glibc吗? ?我读了几个线程,其中
已关闭。这个问题是 not reproducible or was caused by typos 。目前不接受答案。 这个问题是由拼写错误或无法再重现的问题引起的。虽然类似的问题可能是 on-top
我在 HTML 文件中有这样的内容: var value = 0; add(x){ x++; do
有没有办法在用户向上滚动时增加变量,并在用户使用 JavaScript 向下滚动时减少变量?变量没有最大值或最小值,如果能够调整灵敏度就好了。我不知道从哪里开始,感谢您的帮助! 编辑:没有滚动条,因为
我是 ios 新手,遇到以下问题。 我想根据表格 View 中元素的数量增加和减少表格 View 的高度大小。如果在输入时客户端在输出时给出 3 个或超过 3 个元素,我希望看到一个比默认行大 2 行
所以我一直在四处搜索,似乎大多数人认为以下列方式递增 indexPath 是正确的方法: NSIndexPath *newIndexPath = [NSIndexPath indexPathForRo
我有一个关于 connSupervisionTimeout 的问题。 我正在使用 CoreBluetooth 编写应用程序。我检查了连接参数和 connSupervisionTimeout = 720
我正在尝试根据页面的滚动位置更改元素的填充;当用户向下滚动页面时,填充会增加,而当他们向上滚动时,填充会减少。 我的主要问题是滚动不是很流畅,有时如果我滚动到页面顶部太快,每次元素的填充大小都不一样。
我正在尝试计算 18456 个基因的相关性度量,但编译器 (Dev C) 在将宏 GENE 或 INDEX 增加到 4000 到 5000 之间的值后退出或大。例如,它适用于: # define GE
我有一个带有 position: absolute 和 CSS3 过渡的圆形元素(a 元素)。在 hover 事件中,我想增加圆的高度和宽度,但我想在所有边上添加像素,而不仅仅是在左侧或右侧。 示例如
为了改善用户体验,我计划在我网站的所有页面(A-、A、A+)上增加/减少/重置字体大小 我面临的问题是页面上不同元素使用的字体大小不统一。有些是 14px,有些是 18px,有些是 12px,有些是
本文实例讲述了Yii框架数据库查询、增加、删除操作。分享给大家供大家参考,具体如下: Yii 数据库查询 模型代码: ?
sql替换语句,用该命令可以整批替换某字段的内容,也可以批量在原字段内容上加上或去掉字符。 命令总解:update 表的名称 set 此表要替换的字段名=REPLACE(此表要替换的字段名, '原
sql不常用函数总结以及事务,增加,删除触发器 distinct 删除重复行 declare @x 申明一个变量 convert(varchar(20),t
要增加我使用的最大可用内存: export SPARK_MEM=1 g 或者我可以使用 val conf = new SparkConf() .setMaster("loca
我正在尝试将文本(自定义文本按钮)放入 AppBar 的前导属性中。但是,当文本太长时,文本会变成多行 Scaffold( appBar: AppBar( centerTi
我正在使用最新版本的 NetBeans,我需要增加输出和菜单的字体大小(不是代码部分)。我试过: netbeans_default_options=".... --fontsize 16" 但是当我将
我必须将 180000 个点绘制到一个 EPS 文件中。 使用标准 gnuplot 输出尺寸点彼此太接近,这使得它们无法区分。有没有办法增加图像的宽度和高度? 最佳答案 是的。 set termina
我有一个带有输入字段的 twitter bootstrap 3 导航栏。我想增加输入字段的宽度。我已尝试设置 col 大小,但它不起作用。 html比较长,请引用bootply http://www.
我正在尝试增加 ggplot 标题中下划线的大小/宽度/厚度。我曾尝试使用大小、宽度和长度,但没有成功。 这是我所做的一个例子。 test <- tibble(x = 1:5, y = 1, z =
我是一名优秀的程序员,十分优秀!