php小代码---从慢日志文件分离出日志记录并存放于excel文件中
<?php header("Content-type:text/html; charset=UTF-8"); ini_set('max_execution_time', '10000'); ini_set('memory_limit','1024M'); function dealslowContent($content) { $data = array(); preg_match('/#\sUser@Host:(.+)\n#\sThread_id/', $content, $match); $data['User@Host'] = $match[1]; preg_match('/#\sQuery_time:\s(.+)\sLock_time/', $content, $match); $data['Query_time'] = $match[1]; preg_match('/\sLock_time:\s(.+)\sRows_sent/', $content, $match); $data['Lock_time'] = $match[1]; preg_match('/\sRows_examined:\s(.+)\sRows_affected/', $content, $match); $data['Rows_examined'] = $match[1]; preg_match('/\sRows_read:\s(.+)\n#\sBytes_sent/', $content, $match); $data['Rows_read'] = $match[1]; preg_match('/timestamp=(\d+);\s/', $content, $match); $data['timestamp'] = $match[1]; preg_match('/#\sBytes_sent:\s(.+)\sSET/', $content, $match); $data['Bytes_sent'] = $match[1]; $sqlPos = strpos($content, ';'); $data['sql'] = substr($content, $sqlPos + 1, strlen($content)); return $data; } $slowData = array(); $handle = fopen('mysql-slow.log.2', 'r'); $content = ''; $middlerCha = ''; $identifier = '# User@Host'; $identifierLength = strlen($identifier); while (!feof($handle)) { $oneTakeCha = fread($handle, 1); if ($oneTakeCha === '#') { $middlerCha = '#' . fread($handle, $identifierLength - 1); if ($middlerCha === $identifier) { if ($content != '') { $slowData[] = dealslowContent($content); $content = $middlerCha; } else { $content = $middlerCha; } } else { $content.=$middlerCha; } } else { $content.= $oneTakeCha; } } $slowData[] = dealslowContent($content); fclose($handle); include 'libraries/PHPExcel.php'; include 'libraries/PHPExcel/IOFactory.php'; $objPHPExcel = new PHPExcel(); $objPHPExcel->getProperties()->setTitle("export")->setDescription("none"); $objPHPExcel->setActiveSheetIndex(0); $objPHPExcel->getActiveSheet()->getColumnDimension('A')->setWidth(20); $objPHPExcel->getActiveSheet()->getColumnDimension('B')->setWidth(25); $objPHPExcel->getActiveSheet()->getColumnDimension('C')->setWidth(25); $objPHPExcel->getActiveSheet()->getColumnDimension('D')->setWidth(25); $objPHPExcel->getActiveSheet()->getColumnDimension('E')->setWidth(25); $objPHPExcel->getActiveSheet()->getColumnDimension('F')->setWidth(15); $objPHPExcel->getActiveSheet()->getColumnDimension('G')->setWidth(15); $objPHPExcel->getActiveSheet()->getColumnDimension('H')->setWidth(15); $titlearray = array( "主机信息" => 'User@Host', "查询时间" => 'Query_time', "锁表时间" => 'Lock_time' , "查询时检查行数" => 'Rows_examined', "读取行数" => 'Rows_read', "时间" => 'timestamp', "发送字节数" => 'Bytes_sent', "执行的sql" => 'sql' ); $col = 0; foreach ($titlearray as $key => $title) { $objPHPExcel->getActiveSheet()->setCellValueByColumnAndRow($col, 1, $key); $col++; } $j = 2; foreach ($slowData as $key => $sd) { $col = 0; foreach ($titlearray as $key2 => $title) { $objPHPExcel->getActiveSheet()->setCellValueByColumnAndRow($col, $j, $sd[$title]); $col++; } $j++; } $objPHPExcel->setActiveSheetIndex(0); $objWriter = IOFactory::createWriter($objPHPExcel, 'Excel5'); // Sending headers to force the user to download the file header('Content-Type: application/vnd.ms-excel'); header('Content-Disposition: attachment;filename="slowsql.xls"'); header('Cache-Control: max-age=0'); $objWriter->save('php://output');
陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章
刺客信條陰影:貝殼謎語解決方案
3 週前ByDDD
Windows 11 KB5054979中的新功能以及如何解決更新問題
2 週前ByDDD
在哪裡可以找到原子中的起重機控制鑰匙卡
3 週前ByDDD
<🎜>:死鐵路 - 如何完成所有挑戰
4 週前ByDDD
Atomfall指南:項目位置,任務指南和技巧
1 個月前ByDDD

熱工具

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

Atom編輯器mac版下載
最受歡迎的的開源編輯器

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

SublimeText3漢化版
中文版,非常好用

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。