Laravel 修改默认日志文件名称和位置
修改默认日志位置
我们平常的开发中可能一直把laravel的日志文件放在默认位置不会有什么影响,但如果我们的项目上线时是全量部署,每次部署都是git中最新的代码,那这个时候每次都会清空我们的日志,显示这不是我们所期望的,好在laravel有提供我们修改的方法。
我们这里以放在/var/log/nginx/app/phphub/phphub.log为例
增加日志处理类#
首先我们新建文件,app/Foundation/Bootstrap/ConfigureLogging.php,代码如下:
<?phpnamespace App\Foundation\Bootstrap;use Illuminate\Log\Writer;use Illuminate\Contracts\Foundation\Application;class ConfigureLogging{/*** 设置应用的Monolog处理程序** @param \Illuminate\Contracts\Foundation\Application $app* @param \Illuminate\Log\Writer $log* @return void*/public function configureHandlers(Application $app, Writer $log){$method = 'configure'.ucfirst($app['config']['app.log']).'Handler';$this->{$method}($app, $log);}/*** 设置应用single模式下的Monolog处理程序** @param \Illuminate\Contracts\Foundation\Application $app* @param \Illuminate\Log\Writer $log* @return void*/protected function configureSingleHandler(Application $app, Writer $log){$config = $app->make('config');$filename = $config->get('app.log_path', '/var/log/nginx/app/system') . '/' . $config->get('app.log_name', 'laravel') . '.log';$log->useFiles($filename);}/*** 设置应用daily模式下的Monolog处理程序** @param \Illuminate\Contracts\Foundation\Application $app* @param \Illuminate\Log\Writer $log* @return void*/protected function configureDailyHandler(Application $app, Writer $log){$config = $app->make('config');$filename = $config->get('app.log_path', '/var/log/nginx/app/system') . '/' . $config->get('app.log_name', 'laravel') . '.log';$log->useDailyFiles($filename,$app->make('config')->get('app.log_max_files', 5));}/*** 设置应用syslog模式下的Monolog处理程序** @param \Illuminate\Contracts\Foundation\Application $app* @param \Illuminate\Log\Writer $log* @return void*/protected function configureSyslogHandler(Application $app, Writer $log){$log->useSyslog($app->make('config')->get('app.log_name', 'laravel'));}/*** 设置应用errorlog模式下的Monolog处理程序** @param \Illuminate\Contracts\Foundation\Application $app* @param \Illuminate\Log\Writer $log* @return void*/protected function configureErrorlogHandler(Application $app, Writer $log){$log->useErrorLog();}}
配置日志存放路径#
在.env中增加
APP_NAME=phphub
在config/app.php中增加
/*** 应用程序名称*/'name' => env('APP_NAME', 'laravel'),/*** 日志位置*/'log_path' => '/var/log/nginx/app/' . env('APP_NAME', 'laravel'),/*** 日志文件名称*/'log_name' => env('APP_NAME', 'laravel'),/*** 日志文件最大数*/'log_max_files' => '30',
应用我们新的处理类#
修改Bootstrap/app.php,在return $app前增加代码
$app->configureMonologUsing(function($monolog) use ($app) {$configureLogging = new App\Foundation\Bootstrap\ConfigureLogging();$configureLogging->configureHandlers($app, $app->log);});
这时候我们可以使用\Log::info('test log info');测试一下,应该就会将日志记录在/var/log/nginx/app/phphub/phphub.log中了。
Laravel 修改默认日志文件名称和位置的更多相关文章
- springmvc基础篇—修改默认的配置文件名称及位置
springmvc的默认配置文件是放在WEB-INF下的,叫action-servlet.xml.根据咱们编程的习惯,一般都将配置文件放到src的根目录下,那么如何将这个文件迁移过来呢?其实很简单,请 ...
- C# 插件热插拔 .NET:何时应该 “包装异常”? log4.net 自定义日志文件名称
C# 插件热插拔 所谓热插拔就是插件可以 在主程序不重新启动的情况直接更新插件, 网上有很多方案: https://www.cnblogs.com/happyframework/p/3405811 ...
- WAL日志文件名称格式详解
转自:http://blog.osdba.net/534.html WAL日志文件名称格式详解 PostgreSQL的WAL日志文件在pg_xlog目录下,一般情况下,每个文件为16M大小: osdb ...
- log4j配置文件动态指定日志文件名称
我们在项目当中经常会使用log4j进行日志记录,偶尔会遇到一些要求,比如日志文件名称按照启动参数动态配置,而不去修改log4j.xml,比较简单的一种做法是,通过设置系统属性的方式实现,代码: if( ...
- 动态指定log4net日志文件名称
如果是希望日志文件按常见的日期格式动态命名,没什么好说的,直接修改app.config <param name="DatePattern" value="yyyyM ...
- log4j2配置文件动态指定日志文件名称
按照习惯性思维,log4j2中xml中取系统属性应该和log4j一样,但是结果却并不是我们想的这样,存在一定的差别,log4j中的配置可参考 log4j配置文件动态指定日志文件名称 . 现在就来看看到 ...
- Confluence 6 修改日志文件的目标位置
在 log4j 中,一个输出被定义为 'appender'.希望修改 log 文件的目标,你需要停止 Confluence 然后修改设置 log4j.properties 日志配置文件的 'Logg ...
- rabbitmq更换数据文件和日志文件的存放位置
原来的默认位置是/var下 需要将这些文件更换位置 1.先创建数据文件和日志文件存放位置的目录并给权限 mkdir -p /usr/local/rabbitmq/mnesia mkdir -p /us ...
- [PHP] - Laravel - 修改laravel_session的cookie名称
修改Cookie laravel_session的名称方法: 打开文件:config\session.php 找到值:laravel_session 修改为你所需要的cookie名称即可. 当然,还有 ...
随机推荐
- Mysql 5.7.17安装后登录mysql的教程方法
在运行 ./bin/mysqld Cinitialize 初始化数据库时,会生成随机密码,示例: [Note] A temporary password is generated for root@l ...
- transact和onTransact的区别
转:http://blog.csdn.net/sergeycao/article/details/52585411 谈transact 和onTransact需要先聊聊iBinder IBinder是 ...
- 转:CentOS上安装LAMP之第三步:MySQL环境及安装过程报错解决方案(纯净系统环境)
这是AMP运行环境中最后配置的环境: 惯例传送门: 1.编译安装MySQL cd /home/zhangatle/tar tar zxvf mysql-.tar.gz cd mysql- cmake ...
- Java开发中的Memcache原理及实现
Memcached 客户端程序 Memcached的java客户端已经存在三种了: ? 官方提供的基于传统阻塞io由Greg Whalin维护的客户端 ? Dustin Sallings实现的基于 ...
- PLSql 查询结果让数字显示为字符
有时候某些地段太长的话就会默认显示为数字,例如ID字段过长就会显示为4.34E23的形式,遇到这样情况如何还原id字段的本身形式呢? Tools-->preference-->SQL Wi ...
- 【GDOI2017 day2】凡喵识图 二进制切分
题面 100 有一个显然的做法是\(O(n^2)\): 想办法优化这个做法: 我们给一个64位整数,切分成四个16位整数. 那么如果两个64位整数符合汉明距离为3的话,那么两者切分的四个16位整数中: ...
- 你真的了解HTML吗
有这么一段HTML,请挑毛病: <P> 哥写的不是HTML,是寂寞.<br><br> 我说: <br>不要迷恋哥,哥只是一个传说 这是原来雅虎一道笔试题 ...
- python学习笔记08-- socket编程
本节内容: 一.网络基础知识 二.socket概念及相关语法 2.1socket概念 2.2socket解释 2.3socket模块功能介绍 2.4socket粘包问题 2.5Socket多并发 一. ...
- day38 15-Spring的配置文件引入的问题
配置文件内容过多修改起来维护起来很麻烦.Struts 2可以在总的配置文件中引入其他的配置文件.这是一种办法.第二种办法在加载配置文件的时候,里面可以一次性传多个. <?xml version= ...
- 【水滴石穿】github_popular
项目不难,就是文件摆放位置跟别的不一样 https://github.com/chenji336/github_popular //定义入口是app.js ///** @format */ impor ...