Простой логгер на PHP7+, сохраняющий отладочную информацию в файл вместе с данными об объеме используемой оперативной памяти и прошедшем времени.
- PHP >= 7.0;
- Произвольный автозагрузчик классов, реализующий стандарт PSR-4.
Установка через composer:
$ composer require andrey-tech/debug-logger-php:"^2.0"
или добавить
"andrey-tech/debug-logger-php": "^2.0"
в секцию require файла composer.json.
Класс \App\DebugLogger\DebugLogger обеспечивает логирование отладочной информации в файл.
При возникновении ошибок выбрасывается исключение класса \App\DebugLogger\DebugLoggerException.
static instance(string $logFileName = 'debug.log'): DebugLogger
Возвращает единственный объект классаDebugLoggerдля заданного лог-файла$logFileName.$logFileName- имя лог-файла.
save(mixed $info, object $object = null, string $header = null): voidСохраняет подлежащую логированию информацию в файл.$info- строка, массив или объект для логирования;$object- ссылка на объект класса в котором выполняется логирование;$header- строка заголовка для сохраняемой в лог файл информации.
Дополнительные параметры устанавливаются через публичные свойства класса \App\DebugLogger\DebugLogger:
| Нестатическое свойство | По умолчанию | Описание |
|---|---|---|
$isActive |
false | Включает или выключает логирование для конкретного файла, задаваемого параметром $logFileName метода instance() |
| Статическое свойство | По умолчанию | Описание |
|---|---|---|
$logFileDir |
temp/ |
Устанавливает каталог, в котором сохраняются лог-файлы |
mkdirMode |
0755 | Устанавливает режим доступа для создаваемых каталогов для хранения лог файлов в виде восьмеричного числа |
$uniqIdLength |
7 | Длина уникального буквенно-цифрового [a-z0-9]+ идентификатора объекта класса DebugLogger для сохранения в лог файле, позволяющего находить записи, созданные одним и тем же процессом |
use App\DebugLogger\DebugLogger;
use App\DebugLogger\DebugLoggerException;
try {
// Устанавливаем каталог для сохранения лог-файлов
DebugLogger::$logFileDir = 'logs/';
$logFileName = 'debug_extensions.log';
$logger = DebugLogger::instance($logFileName);
// Включаем логирование
$logger->isActive = true;
// Сохраняем информацию о всех скомпилированных и загруженных модулях PHP
$logger->save(get_loaded_extensions(), null, 'PHP modules');
// Сохраняем версию движка Zend PHP
$logger->save(zend_version(), null, 'Zend engine');
} catch (DebugLoggerException $e) {
printf('Ошибка (%d): %s' . PHP_EOL, $e->getCode(), $e->getMessage());
}*** ytoqjz5 [2020-06-14 12:57:18.420258 +00:00 Δ- s, 0.69/2.00 MiB] ********************
PHP modules
[
"Core",
"bcmath",
"calendar",
"ctype"
]
*** ytoqjz5 [2020-06-14 12:57:18.421359 +00:00 Δ0.001101 s, 0.69/2.00 MiB] ********************
Zend engine
3.2.0
*** ytoqjz5 [2020-06-14 12:57:18,421359 +00:00 Δ0.001101 s, 0.69/2.00 MiB] ********************
Zend engine
3.2.0
ytoqjz5- уникальный буквенно-цифровой [a-z0-9]+ идентификатор объекта классаDebugLogger, позволяющий находить в лог файле записи, созданные одним и тем же процессом;2020-06-14 12:57:18.421359 +00:00- дата и время сохранения информации с точностью до микросекунд;Δ0.001101 s- время, прошедшее с момента предыдущего сохранения информации в секундах и микросекундах;0.69/2.00 MiB- данные об используемой оперативной памяти в единицах количества информации с двоичными приставками:0.69- максимальный объем памяти, который был выделен PHP-скрипту системой;2.00- реальный объем памяти, выделенный PHP-скрипту системой;
- 'Zend engine' - заголовок для сохраняемой информации, задаваемый параметром
$headerметодаsave(); - '3.2.0' - сохраняемая информация, задаваемая параметром
$infoметодаsave().
© 2019-2022 andrey-tech
Данная библиотека распространяется на условиях лицензии MIT.