PHP: запись (ведение) лога ошибок в файл

Практика




PHP при обнаружении ошибок может легко выводить их на экран. Когда-то это нужно, когда-то - нет. В особенности, при работе сайта на боевом сервере вывод мелких ошибок на экран бывает ненужным, но вот ведение некоего лог-файла таких ошибок - может пригодиться. Например, все вроде работает, но через неделю стоит глянуть в этот файл - а вдруг где-то, в каком-то месте затаилась бяка, которую сразу и не видно.

По-умолчанию PHP такой файл не ведет, но здесь мы научимся его использование включать.


Включаем запись ошибок в файл

Итак, открываем файл php.ini  /etc/php7/

и находим в нем директиву log_errors. Выставляем эту директиву в положение On:

log_errors = On

Теперь спускаемся ниже и находим еще одну директиву: error_log. Она по-умолчанию закомментирована, а значение по-умолчанию - пустое. Что-ж, зададим ее сами и установим в качестве параметра полный путь к файлу - где хранить логи ошибок:

error_log = /var/log/apache2/php_errors.log

Не забудьте убедиться, что по указанному адресу создание файла вообще возможно (т.е. проверьте, что для этого достаточно прав). Файл создается от имени веб-сервера.

Все, теперь перезапускаем веб-сервер и смотрим в указанное выше место.


Выключаем отображение ошибок на экране

Если нужно выключить отображение ошибок на экране - находим опцию display_errors и ставим ее в Off. Так-же рекомендую перевести в данном случае контент отображения (опция error_reporting) в положение E_ALL & ~E_DEPRECATED (как рекомендуется в самом файле php.ini).

error_reporting = E_ALL & ~E_DEPRECATED
display_errors = Off


Указываем отдельный файл ошибок для отдельного сайта

Можно, конечно, указать и отдельный файл ошибок для отдельного сайта. Для этого нужно прописать PHP опцию error_log в настройках веб-сервера для данного сайта. На примере Apache это будет выглядеть так:

<VirtualHost .....>
  php_value error_log "/www/mysite/logs/php_errors.log"
</VirtualHost>
 
Актуально для: PHP 5.2.x, 5.3.x
создано: 2017-05-09
обновлено: 2026-03-08
706



Помог ли вам этот ответ?
Нажмите оценку и напишите коротко почему. Так мы сможем сделать следующие ответы точнее и полезнее.
Насколько вы довольны ответом?
Ваш отзыв напрямую влияет на качество следующих подсказок и ответов.


Поделиться:
Пожаловаться

Найди готовое или заработай

С нашими удобными сервисами без комиссии*

Как это работает? | Узнать цену?

Найти исполнителя
$0 / весь год.
  • У вас есть задание, но нет времени его делать
  • Вы хотите найти профессионала для выполнения задания
  • Возможно применение функции гаранта на сделку
  • Приоритетная поддержка
  • идеально подходит для студентов, у которых нет времени для решения заданий
Готовое решение
$0 / весь год.
  • Вы можете продать (как исполнитель) или купить (как заказчик) готовое решение
  • Вам предоставят готовое решение
  • Будет предоставлено в минимальные сроки т.к. задание уже готовое
  • Вы получите базовую гарантию 8 дней
  • Вы можете заработать на материалах
  • подходит как для студентов так и для преподавателей
Я исполнитель
$0 / весь год.
  • Вы профессионал своего дела
  • У вас есть опыт и желание зарабатывать
  • Вы хотите помочь в решении задач или написании работ
  • Возможно применение функции гаранта на сделку
  • подходит для опытных студентов так и для преподавателей

Комментарии

Оставить комментарий

Если у вас есть какое-либо предложение, идея, благодарность или комментарий, не стесняйтесь писать. Мы очень ценим отзывы и рады услышать ваше мнение.
To reply

Лекции и учебник по "Выполнение скриптов на стороне сервера PHP (LAMP) NodeJS (Backend) "

Термины: Выполнение скриптов на стороне сервера PHP (LAMP) NodeJS (Backend)