php默认日志位置,Laravel 修改默认日志文件名称和位置的例子

修改默认日志位置

我们平常的开发中可能一直把laravel的日志文件放在默认位置不会有什么影响,但如果我们的项目上线时是全量部署,每次部署都是git中最新的代码,那这个时候每次都会清空我们的日志,显示这不是我们所期望的,好在laravel有提供我们修改的方法。

我们这里以放在/var/log/nginx/app/phphub/phphub.log为例

增加日志处理类#

首先我们新建文件,app/Foundation/Bootstrap/ConfigureLogging.php,代码如下:

namespace 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 修改默认日志文件名称和位置的例子就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/395669.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【转】UITableView详解(UITableViewCell

原文网址:http://www.kancloud.cn/digest/ios-1/107420 上一节中,我们定义的cell比较单一,只是单调的输入文本和插入图片,但是在实际开发中,有的cell上面有按钮,有的cell上面有滑动控件,有的cell上面有开关选项等等,具体参加下面2个图的对比: 我们可以通过…

Android 最简单的MVP案例;

随手撸个发出来: V:界面层 //界面层需要实现P.View方法,然后重写P.View中的方法;M层给的数据就在这些个方法的参数中; // 还要获取到P.Provide的实例,使用P.Provide去调用M层的方法; public cla…

c++编码风格指南_100%正确编码样式指南

c编码风格指南Tabs or spaces? Curly brace on the same line or a new line? 80 character width or 120?制表符或空格? 在同一行或新行上大括号? 80个字符的宽度还是120个字符? Coders love to argue about this kind of stuff. The ta…

Netty源码注释翻译-Channel类

定义为一个通往网络socket或者一个由I/O读写能力的组件。 通道提供: 1,通道的当前状态,打开?已连接? 2,跟通道关联的配置信息ChannelConfig,包括buffer大小等。 3,通道支持的I/O操作…

Today is weekend不是应该一定会输出吗

判断语句 If…else块&#xff0c;请看下面这个例子&#xff1a; <%! int day 3; %>                       //声明变量感叹号 <html> <head><title>IF...ELSE Example</title></head> <body> <% if (day …

时间模块和时间工具

一、time模块 三种格式 时间戳时间&#xff1a;浮点数 单位为秒 时间戳起始时间&#xff1a; 1970.1.1 0:0:0 英国伦敦时间 1970.1.1 8:0:0 我国(东8区) 结构化时间&#xff1a;元组(struct_time) 格式化时间&#xff1a;str数据类型的 1、常用方法 import timetime.sleep(secs…

redux扩展工具_用鸭子扩展您的Redux App

redux扩展工具How does your front-end application scale? How do you make sure that the code you’re writing is maintainable 6 months from now?您的前端应用程序如何扩展&#xff1f; 您如何确定您正在编写的代码从现在起6个月内可维护&#xff1f; Redux took the …

mac下源码安装redis

转载&#xff1a;http://www.jianshu.com/p/6b5eca8d908b 下载安装包 redis-3.0.7.tar.gz 官网地址&#xff1a;http://redis.io/download 解压&#xff1a;tar -zvxf redis-3.0.7.tar.gz 将解压后的文件夹放到 /usr/local目录下 编译测试:接下来在终端中切换到/usr/local/red…

代码扫描工具测试覆盖率工具

测试覆盖率工具转载于:https://www.cnblogs.com/vivian-test/p/5398289.html

php splqueue 5.5安装,解析PHP标准库SPL数据结构

SPL提供了双向链表、堆栈、队列、堆、降序堆、升序堆、优先级队列、定长数组、对象容器SplQueue 队列类进出异端&#xff0c;先进先出<?php $obj new SplQueue();//插入一个节点到top位置$obj->enqueue(1);$obj->enqueue(2);$obj->enqueue(3);/**SplQueue Object…

Beta阶段敏捷冲刺总结

设想和目标 1. 我们的软件要解决什么问题&#xff1f;是否定义得很清楚&#xff1f;是否对典型用户和典型场景有清晰的描述&#xff1f; 在最开始的时候我们就是为了解决集美大学计算机工程学院网页没有搜索引擎的问题。因为没有搜索引擎&#xff0c;在搜索内容时需要根据查找信…

c语言 二进制压缩算法_使用C ++解释的二进制搜索算法

c语言 二进制压缩算法by Pablo E. Cortez由Pablo E.Cortez 使用C 解释的二进制搜索算法 (Binary Search Algorithms Explained using C) Binary search is one of those algorithms that you’ll come across on every (good) introductory computer science class. It’s an …

【LATEX】个人版latex论文模板

以下是我的个人论文模板&#xff0c;运行环境为Xelatex(在线ide&#xff1a;Sharelatex.com) 鉴于本人常有插入程序的需求&#xff0c;故引用了lstlisting \RequirePackage{ifxetex} \ifxetex\documentclass[hyperref, UTF8, c5size, no-math, winfonts&#xff0c;a4paper]{ct…

初识virtual memory

一、先谈几个重要的东西 virtual memory是一个抽象概念&#xff0c;书上的原文是"an abstraction of main memory known as virtual memory"&#xff08;参考资料p776&#xff09;。那么什么是抽象概念。下面说说我个人对这个东西的理解。 所谓抽象概念是指抽象出来的…

java创建mysql驱动,JDBC之Java连接mysql实现增删改查

使用软件&#xff1a;mysql、eclipse链接步骤&#xff1a;1.注册驱动2.创建一个连接对象3.写sql语句4.执行sql语句并返回一个结果或者结果集5.关闭链接(一般就是connection、statement、setresult)这三个连接对象&#xff0c;关闭顺序一般是(setresult ---> statement …

算法第五章作业

1.你对回溯算法的理解&#xff08;2分&#xff09; 回溯法&#xff08;探索与回溯法&#xff09;是一种选优搜索法&#xff0c;又称为试探法&#xff0c;按选优条件向前搜索&#xff0c;以达到目标。但当探索到某一步时&#xff0c;发现原先选择并不优或达不到目标&#xff0c;…

c++编码风格指南_100%正确的编码样式指南

c编码风格指南Here are three links worth your time:这是三个值得您花费时间的链接&#xff1a; The 100% correct coding style guide (4 minute read) 100&#xff05;正确的编码样式指南( 阅读4分钟 ) I wrote a programming language. Here’s how you can, too (10 minu…

xp开机黑屏故障分析

今天装完xp系统之后&#xff0c;重启开机发现竟然黑屏了&#xff0c;查资料发现有很多用户在修改分辨率后&#xff0c;因显示器不支持修改后的分辨率&#xff0c;会出现电脑黑屏的情况。分辨率调高了&#xff0c;超出了屏幕的范围&#xff0c;肯定会黑屏&#xff0c;而且这个问…

应用程序图标_如何制作完美的应用程序图标

应用程序图标by Nabeena Mali通过Nabeena Mali 如何制作完美的应用程序图标 (How to Make the Perfect App Icon) With just 24 app icon slots on the first page of an iPhone home screen, or 28 if you have a fancy iPhone 7, creating the perfect app icon is a vital …

Luogu3702 SDOI2017 序列计数 矩阵DP

传送门 不考虑质数的条件&#xff0c;可以考虑到一个很明显的$DP:$设$f_{i,j}$表示选$i$个数&#xff0c;和$mod\ pj$的方案数&#xff0c;显然是可以矩阵优化$DP$的。 而且转移矩阵是循环矩阵&#xff0c;所以可以只用第一行的数字代替整个矩阵。当然了这道题$p \leq 100$矩阵…