### 2018 年 10 月 25 日 發布
日志是一個應用必不可少的功能組件,在某種程度上來說甚至具有不可替代的作用,無論是調試模式還是部署模式。
ThinkPHP5的日志功能非常強大,足以滿足大部分的應用場景。
## 日志記錄
除了系統自動生成的日志外,如果你需要添加自己的應用日志,可以使用`trace`助手函數或者`Log`類記錄日志。
```
trace('日志信息', '日志類型');
// 或者使用
\think\facade\Log::record('日志信息', '日志類型');
// 實時寫入日志
\think\facade
```
>[info] 日志記錄對于命令行和WEB訪問有一個明顯的差別就是命令行的日志記錄是實時寫入日志文件的(原因是為了避免內存中的日志記錄開銷過大,`Swoole`和`Workerman`也屬于命令行常駐運行),而WEB訪問則在每次請求完成后統一寫日志文件。
按照`PSR-3`日志規范,日志的級別從低到高依次為: `debug`, `info`, `notice`, `warning`, `error`, `critical`, `alert`, `emergency`,ThinkPHP額外增加了一個`sql`日志級別僅用于記錄`SQL`日志(并且僅當開啟數據庫調試模式有效)。當然,你仍然可以增加自己的額外日志類型。
原則上,在開發調試階段,我們不應該錯過任何的錯誤信息,而在部署階段,可以有選擇的記錄某些日志類型從而避免日志文件過大。
調整日志配置文件的配置參數:
```
// 允許記錄的日志類型
'level' => ['error', 'critical', 'alert', 'emergency'],
```
>[danger] 敏感信息應該盡量記錄在`debug`日志類型中,系統在部署模式下,默認會自動忽略`debug`類型的日志(除非你明確允許記錄`debug`類型日志),確保日志泄露后可能造成的安全性。
## 日志管理
日志文件最好有一個統一的管理策略,例如在項目中規范日志的大小、數量以及采用的日志記錄類型。
目前框架內置的日志記錄類型包括文件類型和`Socket`類型,`Socket`類型主要用于遠程調試,具體用法可以參考官方的快速入門教程的[API調試](http://www.hmoore.net/thinkphp/thinkphp5_quickstart/478323)一章,這里不再敘述。我們主要以文件類型日志為例來講述日志管理。
日志管理策略主要包含如下配置參數,你可以根據你的實際需求進行配置。
### 日志大小(`file_size`)
默認的日志文件大小是2097152字節(2M),超過設置的日志大小,會自動生成日志備份文件。實際應用中建議適當調大一些,可以避免日志文件過多。
### 日志數量(`max_files`)
默認情況下,日志是永久保存(直到存儲占滿為止),為了避免日志文件過大(一個月下來幾十個G都有),建議設置一個最大日志文件數量,例如保留最近`50`個日志文件,超過后會自動刪除最早的一個日志文件。
### 獨立類型日志(`apart_level`)
如果你需要,可以設置某些級別的日志信息單獨文件記錄,方便你直接查看相關類型的問題,例如:
```
// error和sql日志單獨記錄
'apart_level' => ['error', 'sql'],
```
設置后,就會單獨生成`error`和`sql`兩個類型的日志文件,主日志文件中將不再包含這兩個級別的日志信息。
如果需要所有日志類型單獨記錄文件的話,可以直接設置`apart_level`為`true`。
### 單一日志(`single`)
默認情況下的日志是按照日期為目錄,按天為文件生成的(例如`201809/03.log`這種)但如果希望僅生成單個文件(方便其它的工具或者服務讀取以及分析日志)。
```
'single' => true,
```
開啟生成單個文件后,`file_size`、`apart_level`和`max_files`參數依然有效,超過文件大小限制后,系統會自動生成備份日志文件。
所以,一般開啟單一日志后,建議調大日志大小(例如10M)。
>[info] 如果需要和阿里云的日志服務對接,可以設置為單一日志,更加方便阿里云的日志文件讀取。
### JSON日志(`json`)
為了方便日志的后期分析,你可以設置使用`JSON`格式記錄日志,開啟后每次記錄的日志會統一編碼成`JSON`格式(目前`5.0`最新版本也支持`JSON`格式日志了)。
在日志配置文件中,添加
```
'json' => true,
```
即可開啟JSON格式記錄,對于命令行的日志記錄同樣有效。
>[danger] JSON格式記錄日志的時候,獨立記錄日志級別參數`apart_level`無效。
## 告警通知
如果你需要加上錯誤日志的告警通知,可以利用日志類提供的兩個鉤子。
鉤子|描述|參數
---|---|---
log_level|不同類型的日志寫入|[ 日志類型, 日志信息(數組)]
log_write|write方法或者命令行日志寫入|日志信息
我們可以添加行為來進行日志的通知,下面是一個很簡單的發送郵件通知的行為類。
```
<?php
namespace app\index\behavior;
class SendMail
{
public function run($params)
{
// 發送郵件通知
list($type, $message) = $params;
if ('error' == $type) {
mail('admin@mail.com', '系統日志通知', implode(' ', $message));
}
}
}
```
綁定行為
```
\think\facade\Hook::add('log_level', 'app\index\behavior\SendMail');
```
這樣就可以在發生錯誤日志的時候自動郵件通知管理員。
`5.0`版本沒有`log_level`鉤子,但你仍然可以用`response_end`鉤子,然后在行為里面獲取當前的日志信息來進行處理。
```
<?php
namespace app\index\behavior;
use think\facade\Log;
class SendMail2
{
public function run($params)
{
// 發送郵件通知
$logs = Log::getLog('error');
mail('admin@mail.com', '系統日志通知', implode(' ', $logs));
}
}
```
>[danger] 以上方法同樣也適用于`5.1`版本。如果你的應用壓力較大,也可以通過把日志告警通知加入隊列,在行為中不做具體的通知,只是加入通知隊列。
如果你已經使用了阿里云的[日志服務](https://www.aliyun.com/product/sls/),那么可以對接ThinkPHP的日志文件,最好是開啟JSON日志格式,便于阿里云的分析和查詢,那么可以直接使用阿里云的日志告警和通知服務,具體可以參考阿里云的產品服務文檔。
## 擴展驅動
如果你覺得內置的日志驅動仍然不能滿足你的日志調試或者通知需求,你還可以自己擴展日志驅動。
擴展一個日志驅動很簡單,只需要在應用類庫中擴展不需要修改核心。下面是一個很簡單的使用`SeasLog`記錄日志的驅動。
```
<?php
namespace app\driver\log;
use think\App;
class SeasLog
{
protected $config = [];
// 實例化并傳入參數
public function __construct(App $app, $config = [])
{
$this->config = array_merge($this->config, $config);
\SeasLog::setBasePath($this->config['path']);
if ($this->config['logger']) {
\SeasLog::setLogger($this->config['logger']);
}
}
/**
* 日志寫入接口
* @access public
* @param array $log 日志信息
* @param bool $append 是否追加請求信息
* @return bool
*/
public function save(array $log = [], $append = false)
{
foreach ($log as $type => $val) {
\SeasLog::log($type, implode("\n\r", $val));
}
return \SeasLog::flushBuffer();
}
```
更詳細的實現可以參考`think-seaslog`擴展。
最后,你只需要在`log.php`配置文件中設置`type`參數為
```
'type' => 'app\driver\log\SeasLog',
```
- 值得升級到5.1的18個理由
- 5.1.7版本新特性
- JSON字段類型在ORM中的使用
- 文件下載響應對象
- 教你使用5.1的數組對象查詢
- 模型三大利器之一:搜索器
- 在ThinkPHP中使用Yaconf
- 掌握命令行的表格輸出
- 5.1.25查詢參數綁定的改進
- ThinkPHP安全規范指引
- 巧用數據集的排序功能實現統計排序
- think-orm ——基于5.1的獨立ORM庫
- think-template——基于ThinkPHP的獨立模板引擎
- ThinkPHP5.1.26版本發布——修正版本,包含安全更新
- ThinkPHP5.0和3.2再發安全更新
- 官宣:ThinkPHP發布首個LTS版本
- 你真的了解Db類和模型的正確使用姿勢么?
- 如何更有效的記錄和管理日志
- 模型三大利器之二:修改器
- ThinkPHP5.1.28版本發布——修正上一版本問題,改進關聯查詢
- 模型三大利器之三:獲取器
- API版本控制的幾種思路
- ThinkPHP5.2第一個Beta版本發布測試
- 讓你少犯錯的數據查詢基本原則
- ThinkPHP發布5.1.29版本——常規更新
- 這15個好習慣讓你更容易升級到5.2
- 如何有效提高ThinkPHP的應用性能
- 讓你提高開發效率的查詢技巧
- 模型關聯查詢不完全指南
- 5.2發布Beta2版本——統一和精簡大量用法
- ThinkPHP發布5.1.30版本——支持微秒時間字段寫入
- ThinkPHP的數據緩存使用
- ThinkPHP5.2安裝及入口文件
- ThinkPHP榮獲2018 年度最受歡迎中國開源開發框架第1名
- 5.1路由使用心得技巧
- ThinkPHP5.*版本發布安全更新
- ThinkPHP項目及代碼規范指北
- 5.2版本的設計規范指導
- ThinkPHP5.1.32版本發布——圣誕快樂
- 利用Trait特性給模型增加樂觀鎖功能
- 5.2數據庫和模型的變化(摘要)
- ThinkPHP模板引擎實現和常見問題
- ThinkPHP5.0.24版本發布——安全更新
- 不忘初心,方得始終——ThinkPHP十三周年報告
- ThinkPHP5+相關資源匯總
- 異步社區ThinkPHP周年慶專享優惠活動
- 5.2路由的調整和改進
- ThinkPHP發布5.1.33版本——包含安全更新
- ThinkPHP擴展開發指南
- ThinkPHP發布5.2Beta3版本
- ThinkPHP發布5.1.34版本——喜迎新年
- ThinkPHP發布5.2RC1版本
- ThinkPHP發布5.1.35版本——常規更新
- 5.2配置類的調整
- 5.2時間查詢的改進和優化
- 5.2RC版本升級不完全指導(僅供學習參考)
- ThinkPHP5.2版本正式變更為6.0版本
- ThinkPHP百度云云虛擬主機專享免費活動
- 事件系統以及查詢事件、模型事件的使用
- ThinkPHP6.0RC2版本發布——架構升級、精簡核心
- ThinkPHP5.1.36LTS版本發布——常規更新
- 新版Session和Cookie設計變化
- ThinkPHP5.1.37版本發布——常規更新
- ThinkPHP6.0RC3版本發布——細節完善,體驗優化
- 6.0中間件使用詳解
- Composer各大廠商鏡像地址
- ThinkPHP6.0發布計劃公告
- 「ThinkPHP開發者周刊」招募志愿者
- ThinkPHP6.0日志變化
- ThinkPHP5.1.38版本發布——常規更新
- ThinkPHP6.0RC4版本發布——ORM獨立,日志多通道支持
- ThinkORM2.0開發指南上線
- ThinkPHP6.0RC5版本發布——多應用模式獨立,中間件機制調整
- ThinkPHP6.0版本發布——程序員節福利
- ThinkPHP5.1.39LTS版本發布——常規更新
- ThinkPHP6.0.1版本發布——圣誕快樂!
- 回顧2019,展望2020!
- ThinkPHPV6.0.2版本發布——2020新春快樂!
- 周年福利系列:Swoole合作優惠
- 億速云成為ThinkPHPV6.0獨家贊助發布商??
- 新冠疫情工具和限免資源專題(保持更新中)
- 周年福利系列:創宇信用認證合作優惠
- 周年福利系列:碼云企業版限時10%優惠
- 周年福利系列:想天短說抵現優惠
- think-swoole直播:從零開始掌握swoole開發
- 周年福利系列:B2C開源電商ShopXO授權8折優惠
- 周年福利系列:LayuiAdmin 永久授權限時優惠
- ThinkPHP資源導航站上線——構建生態 服務未來
- ThinkPHP官方技術支持服務和應用服務市場上線公測
- ThinkPHP市場精選——推廣基本要素
- ThinkPHP市場精選——客服聊天專題
- ThinkPHPV6.0.3版本發布——端午安康
- ThinkPHP開發者扶持計劃
- 6.0.3版本關鍵更新及升級事項
- 「ThinkPHP開發者周刊」改版重啟
- ThinkPHP市場精選——企業建站專題
- ThinkPHP 提供統一API接口服務
- ThinkPHP市場精選——直播電商專題
- ThinkAPI服務SDK發布
- 官方服務市場啟用獨立子域名
- ThinkPHP市場精選——刷臉支付專題
- ThinkAPI推出會員服務計劃
- ThinkPHPV6.0.4版本發布——中秋國慶雙節快樂
- ThinkPHPV5.1.40版本發布——常規更新
- 1024程序員節福利走一波
- ThinkPHP V6.0.5版本發布——兼容Composer2.0
- 知識圖譜應用場景——源論技術沙龍
- ThinkPHP5.*版本改進Composer2.0的兼容
- 官方市場雙十一精選推薦
- 技術人做產品有機會么(文末送課程)
- 本周秒殺——古德云售后獲客營銷系統
- ThinkAPI服務更新——支持接口分組和PHP版本依賴調整
- PHP8新特性盤點
- PHP8新特性系列:構造器屬性提升使用及注意事項
- ThinkPHP2021新年寄語
- ThinkPHP V6.0.6&V5.1.41版本發布——兼容PHP8.0
- PHP如何更優雅地調用API接口
- ThinkPHP V6.0.7發布——修正版本
- ThinkAPI服務更新——IP白名單
- 最新版ThinkORM對于時間字段的調整
- ThinkAPI短信接口正式上線
- ThinkPHP V6.0.8版本發布——多環境變量配置支持
- 頂想云寫作服務開啟第一次公測
- ThinkSSL上線——官方SSL/TLS證書服務
- MDBootstrap國內用戶福利——ThinkPHP官方市場首發
- ThinkPHP V6.0.9版本發布——常規更新
- ThinkORM功能盤點——虛擬模型
- 全面支持主流GIT版本庫——云寫作服務第二次公測
- 云寫作服務私有化部署方案之:版本庫私有化
- 看云雙十一活動
- ThinkPHP V6.0.10LTS發布——兼容PHP8.1
- ThinkPHP V6.0.12發布——命令行兼容8.1
- 頂想云知識管理上線公測——構建企業文檔中心和知識庫
- 頂想云上線——助力生態數字化建設
- 618活動進行中——官方市場迎來一波更新
- 頂想云知識管理正式上線——看云文檔啟動遷移服務
- ThinkPHP V6.0.13發布——常規更新
- 頂想云網站助理服務上線——構建產品支持服務
- ThinkPHP發布6.1.0&6.0.14版本——安全更新
- ThinkPHP新版社區上線試運營
- ThinkAPI上架人臉核身接口——助力網站實名認證
- 辭舊迎新——舊版社區停止注冊及發帖
- ThinkPHP6.1.2版本發布——兼容PHP8.2