Простой логгер на 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.