Разработчики и люди, профессионально работающие с веб-приложениями, боятся 500 Internal Server Error . Оптимальный способ её устранения зависит от сервера и того, что на нём запущено. В данной статье приводятся советы по диагностике и исправлению ошибки 500 .
Содержание
Диагностика ошибки 500 Internal Server Error
Важно помнить, что эта ошибка происходит на стороне сервера. Это значит, что HTML-код , выполняемый на стороне клиента, а также JavaScript или любые другие запущенные в браузере объекты, не могут быть источником ошибки 500 Internal Server Error . Само название ( Internal Server Error – ‘внутренняя ошибка сервера’ ) говорит о том, что ошибка происходит на сервере.
Устранение ошибки на популярных платформах
Многие пользователи устанавливают на свой сервер популярные CMS-системы , такие как WordPress , Joomla , Drupal и они не должны вызывать ошибку 500 , если всё настроено правильно. Однако она всё равно всплывает – из-за несовместимости версий, некачественных установок или сбоя прав доступа на сервере.
Вот некоторые распространённые проблемы, которые могут вызывать подобную ошибку в часто используемых CMS :
- Если вы только что обновили движок до новой версии, вероятно, обновление прошло с ошибками и необходимо провести его повторно. Скорее всего, на сайте разработчика есть инструкции, как это правильно сделать.
- Если вы только что активировали новый плагин или новую тему, стоит попробовать отменить эти изменения. Даже профессионально написанные плагины могут конфликтовать с другими и вызывать 500 Internal Server Error nginx
- Если вы обновляли CMS , старые плагины и темы могут быть с ней несовместимы. Единственное, что можно сделать в таком случае — отключать их по очереди, пока ошибка 500 не исчезнет.
- Неправильно заданные права доступа на сервере или ошибки в файле .htaccess . Серверу не удаётся получить доступ к скриптам, файлам и другим ресурсам, поэтому он выдаёт ошибку.
Когда причиной ошибки 500 Internal Server Error являются скрипты и плагины, лучше всего искать ответы на сайтах их разработчиков.
Устранение ошибки на стороне серверных скриптов
Другой причиной ошибки 500 Internal Server Error может стать разработка и тестирование собственных скриптов.
Чтобы справиться с такой ошибкой, попробуйте следующие решения :
- Настройка прав на сервере : часто неверная настройка прав доступа к файлу или папке приводит к тому, что сервер выдаёт ошибку 500 Internal Server Error . Из-за того, что ему не удаётся запустить скрипт. Выясните, какие права должны быть настроены, и выставьте их соответствующим образом.
- Превышено время ожидания : возможно, истекло время ожидания ответа от PHP или другого серверного скрипта. Это происходит из-за того, что недоступен определённый ресурс или коде была допущена ошибка, запускающая бесконечный цикл.
- Превышено время ожидания соединения с сервером: если сервер был занят, перезагружался или потерял соединение, скрипт может выдать ошибку 500 Internal Server Error . Возможно, в следующий раз ошибки не будет. Но если ошибка появляется при тестировании, велика вероятность того, что она встретится и пользователям.
- Ошибки в файле .htaccess: в некоторых случаях ошибку 500 может вызывать код, прописанный в файле .htaccess .
- Ошибки в скрипте: если ошибку выдаёт скрипт, можете запросить у него подробную информацию об ошибке. К примеру, в PHP можно включить вывод ошибок на экран или в лог-файл, добавив директиву display_errors . По умолчанию среда выполнения может скрывать ошибки, но это не очень удобно для отладки программы.
Попросите помощи у системного администратора
В некоторых случаях у разработчиков нет полного контроля над сервером.
Если скрипт запускается на сервере сторонней организации, она может помочь вам в следующем :
- Предоставить документацию о своём сервере и возможных причинах ошибки 500 . В зависимости от используемой операционной системы и настройки оборудования, данная ошибка может возникать по разным причинам.
- Попросите службу поддержки хостинга посмотреть лог-файлы с ошибками — системный администратор сможет определить, был ли сервер во время возникновения ошибки загружен или вовсе « упал ».
Ошибку 500 Internal Server Error довольно легко устранить
500 Internal Server Error — как исправить ? В большинстве случаев причины возникновения ошибки 500 легко исправляются. Проблема заключается в том, что без конкретной информации определение причины возникновения сбоя усложняется. Легче всего справиться с ошибкой, когда разработчик выяснит, что изменилось перед возникновением ошибки.
Не забывайте, что произошедшие изменения могли быть осуществлены и другими людьми — например, администратором сервера. Если же ничего не менялось, вероятно, сам сервер стал причиной возникновения ошибки из-за несовместимости программного обеспечения или проблем с производительностью.
Данная публикация представляет собой перевод статьи « 500 Internal Server Error: What It Is And How To Fix It » , подготовленной дружной командой проекта Интернет-технологии.ру
Мы предлагаем:
Тариф "Минимальный"
Новые тарифы хостинга — "Минимальный" и "Безлимитный"
Тариф "Минимальный"
— Всего 60 рублей за ГОД;
— Идеально подойдет небольшим сайтам;
— Поддержка популярных CMS
Тариф "Безлимитный"
— 190 рублей в месяц;
— Количество сайтов — не ограничено;
— Дисковое пространство — не ограничено;
— Базы данных — не ограничено;
Содержание
Внутренняя ошибка 500 — Internal Server Error
Ошибка с кодом 500 (internal server error) – внутренняя ошибка сервера.
Значение 500 — код статуса протокола HTTP. Причина ошибки с таким кодом — неисправность конфигурации сервера, либо появление информации о том, что произошел отказ компонента. При ошибке 500 программное обеспечение работает, но есть серьезные внутренние проблемы, которые мешают запросам правильно обрабатываться.
Такая ошибка появляется у построенных на разных CMS сайтах.
Причины возникновения 500 ошибки сервера и способы их исправить
Ошибка 500 говорит о некорректной обработке запросов. Из-за этого пользователи и поисковые системы не могут полноценно работать с сайтом. Необходимо выявить и исправить причину, из-за которой возникло сообщение об ошибке. В случае, когда ошибка появляется часто и устраняется только технической поддержкой, стоит сменить хостинг.
Ошибка 500 — внутренняя, поэтому если она возникла на нужном для просмотра сайте, то можно только посетить его позже, когда восстановят работоспособность.
Причин, по которым появляется ошибка 500 — огромное количество. Задача сводится к поиску и устранению неисправности.
Виртуальный хостинг сайтов для популярных CMS:
WordPress
Joomla
OpenCart
OcStore
PrestaShop
Drupal
Magento
Moodle
MODX Revo
DLE
InstantCMS
IPB
Неправильные права доступа
Частая причина возникновения ошибки – установка неправильных прав доступа на файлы скриптов — 777. Из-за этого они блокируются сервером. Такая настройка разрешает всем вносить изменения в файл, что недопустимо с точки зрения обеспечения безопасности. В случае, когда требуется установить такие права, поставщик всегда сообщает об этом заранее.
Как исправить?
С помощью файлового менеждера (на скриншоте — бесплатная программа FileZilla) просмотреть права доступа к файлу или папке на сервере.
В первую очередь надо проверить, каким образом настроены права доступа. Для каждого типа элементов они проверяются индивидуально. Для папок рекомендуется значение 755, для скриптов — 600, а для других файлов — 644.
Оптимальное решение — один человек. который может управлять аккаунтом. Не желательно давать кому-либо права доступа к корневым папкам сайта.
Высокая длительность работы скрипта
Помимо PHP ограничений на время, за которое должен завершить работу скрипт, ограничения есть и от сервера. Появление ошибки возможно, когда нет ответа за указанный в конфигурации промежуток времени. По этой причине работа скрипта будет автоматически прекращена.
Как исправить?
Решение проблемы заключается в оптимизации работы скрипта. Можно использовать специальные сервисы, которые помогают найти медленный участок кода. Если используется выделенный сервер или VPS, можно увеличить промежуток времени ожидания сервера. Маловероятно, что удастся изменить этот параметр при использовании виртуального хостинга. Это возможно только при согласии технической поддержки.
Ошибки htaccess
У файла «.htaccess» определен строгий синтаксис, который нельзя нарушать. Если в нем написаны ошибочные директивы, то это приведет к появлению ошибки 500. Возможно, директива написана правильно, но не поддерживается.
Как исправить?
В корневой папке сайта нужно поискать файл «.htaccess». Если он нашелся, то нужно скопировать его, чтобы не потерять, а затем удалить из папки. После этой процедуры сайт может заработать. В таком случае станет точно известно, что причина была в этом файле. Затем нужно исправить файл (самый простой способ — добавить файл из чистого дистрибутива используемой системы управления сайтом).
Кроме того, есть возможность посмотреть сведения о появившихся ошибках. Ошибки сервера заносятся в специальный файл «error.log». В нем нужно найти строки о том, какая из директив ошибочна. Например, информация «Invalid command ‘RewritRule’» говорит о том, что директива «RewritRule» написана с опечаткой. Исправление на «RewriteRule» убирает эту ошибку.
Нехватка памяти для работы кода
На виртуальном хостине контролируется, какое количество памяти потребляет скрипт. В случае, когда скрипт хочет использовать слишком много памяти, возможно появление сообщения об ошибке 500.
Эта функция предотвращает большую нагрузку на сервер со стороны каждого аккаунта.
Как исправить?
В первую очередь следует определить, нет ли в коде ошибок, за счет которых он требует слишком много памяти. Если скрипт работает правильно, то начать решение проблемы можно с общения с сотрудниками технической поддержки. В некоторых случаях они помогают разрешить этот вопрос. Мы не обязываем клиента переходить на дорогой тариф из-за нехватке памяти, для решения проблемы можно за небольшую плату увеличить кол-во памяти на текущем тарифном плане.
Ошибка в cgi скрптах
Ошибка 500 чаще появляется из-за ошибок в «htaccess», но еще одна её причина – неправильная работа с CGI-скриптами.
Как исправить?
Существует три основных правила, которые могут быть нарушены.
-
Формат окончания каждой из строк — UNIX (n), а не Windows (rn). Для обеспечения такого условия их загрузка проводится по FTP в режиме ASCII. Права доступа для скриптов CGI и папок, где они хранятся — 0755. Такая настройка разрешает процедуру записи исключительно владельцу, чтоб правильно с позиции безопасности. При работе скрипта CGI могут появиться неправильные HTTP-заголовки ответа. Следует проанализировать содержимое файла «error log» на предмет ошибок.
Ошибка 500 при использовании WordPress
В первую очередь рекомендуется определить, имеет ли файл «.htaccess» отношение к возникновению неисправности. Для этого выполнить его резервное копирование, удалить, а затем обновить страницу. Если сайт после этого работает, значит причина найдена и осталось исправить файл.
Файл «.htaccess» используется WordPress в случае, когда обычная структура ссылок была изменена на ЧПУ. Помимо этого, его используют плагины WordPress, которые осуществляют резервное копирование и некоторые другие функции.
Чаще всего файл «.htaccess» создается однократно, но в WordPress это происходит регулярно. Если в файл заносится ошибка, то хостинг считает его поврежденным и появляется "ошибка 500". Записывать лишние данные, которые воспринимаются как повреждения, могут:
-
движок; тема; плагины, которые активированы.
Если приведенные методы не помогли, то в качестве крайнего варианта можно отключить функцию wordpress, которая создает и переписывает файл «.htaccess». Этот метод подходит только как временная мера, поскольку вызывает проблемы при активации плагинов.
Поочередная проверка элементов позволяет отследить, какой из них — причина ошибки. В процессе поиска неисправности постоянно проверяют, не исчезает ли ошибка 500:
-
сменить тему и проверить наличие ошибки; по очереди деактивировать плагины и следить за изменениями; поиск ошибок в сторонних скриптах; поиск проблемы в движке WordPress.
Сбои плагина иногда видно по искажению внешнего вида сайта. Возможно наличие ошибок в работе конкретного плагина или его конфликт с остальными.
Если файл «.htaccess» – не причина проблемы, нужно убедиться, что скрипты работают с нормальной скоростью. Поиск медленно работающиех скриптов можно выполнить самостоятельно, либо попросить помощи у специалистов службы технической поддержки. Файл с обнаруженной ошибкой и временем ее появления отражается в файле «Error Log».
В WordPress частые причины ошибки — файлы плагинов или тем. Можно деактивировать плагин и применить новый. Если причиной неисправности оказалось ядро WordPress, потребуется обновление.
На хостинге выделяется определенный объем оперативной памяти для использования. Ошибка 500 появится и из-за превышения этого допустимого значения. В админ-панели можно убедиться, не превысил ли сайт этот лимит. Там приведены сведения о уровне загруженности сервера. В файле с перечнем появляющихся ошибок видно, какой из файлов вызвал чрезмерную загрузку. Его придется обновить или удалить, если это допустимо.
Увеличить объем памяти возможно путем корректирования файла. В корне хостинга нужно найти «wp.config.php» и после последней строки добавить в него код:«define(‘WP_MEMORY_LIMIT’, ’64M’».
В ряде случаев помогает обновление WordPress до последней версии.
Ошибка 500 при входе в административную панель Joomla
Ошибка 500 иногда возникает после ввода логина и пароля для панели администрирования Joomla – «админки». При этом работоспособность сайта сохраняется. Код ошибки не указывает на конкретную проблему, поэтому требуется её самостоятельный поиск.
Как исправить?
В журнале ошибок хранятся сообщения об ошибках. Он называется «error.php» и лежит в каталоге «logs». При поиске ошибок, которые появились недавно, важно обратить на последние записи в этом файле. Там содержатся сведения о нарушениях в работе модулей, если они происходили.
Другая вероятная причина ошибки — невозможность записи в каталоги «logs» и «tmp». Возможно, потребуется установка полных прав для этих каталогов – 777.
Рекомендуется проверить правильность путей к каталогам «logs» и «tmp» в файле конфигурации «configuration.php». Желательно указать полные пути к этим каталогам.
Если проблема сохраняется, рекомендуется проверить корректность файла «htaccess» и по очереди отключить и включить все логины и плагины через базу данных. В «htaccess» возможны ошибки, опечатки и лишняя информация. Например, ошибка 500 появляется из-за того, что не закомментирована строка Options +FollowSymLinks. При редактировании файла можно не удалять, а комментировать строки и проверять, как изменяется после этого работа сайта.
Если решить проблему самостоятельно не удается, потребуется обращение в службу технической поддержки.
Внутренняя ошибка сервера 500 — это очень общий код состояния HTTP, код означающий, что на сервере сайта что-то пошло не так, но сервер не может быть более конкретным в отношении точной проблемы. То есть сервер не может дать вам точный ответ что пошло не так!
Вы — веб-мастер? Смотрите « Исправление ошибок внутреннего сервера» на вашем собственном сайте в нижней части страницы для получения более подробных рекомендаций, в том случае если вы видите 500 Internal Server Error на одной или нескольких ваших собственных страницах.
Сообщение об ошибке внутреннего сервера 500 можно увидеть любым количеством способов, поскольку каждому веб-сайту разрешено настраивать сообщение.
Вот несколько распространенных способов, с помощью которых можно увидеть ошибку HTTP 500:
2. Как вы можете увидеть ошибку 500
500 — внутренняя ошибка сервера
HTTP 500 — Внутренняя ошибка сервера
Так как на веб-сайте, который вы посещаете, генерируется 500 внутренних ошибок сервера, вы можете увидеть их в любом браузере в любой операционной системе , даже на вашем смартфоне.
В большинстве случаев в окне интернет-браузера отображается внутренняя ошибка сервера 500, как это делают веб-страницы.
3. Причина ошибок HTTP 500
Как я уже упоминал выше, сообщения об ошибках внутреннего сервера показывают, что что-то, в общем, неверно.
В большинстве случаев «неправильный» означает проблему с программированием страницы или сайта, но, безусловно, есть вероятность, что проблема на вашем конце, что мы рассмотрим ниже.
Примечание. Более конкретная информация о причине конкретной ошибки HTTP 500 часто предоставляется, когда она возникает на сервере с использованием программного обеспечения Microsoft IIS. Ищите номера после 500 , как в HTTP-ошибке 500.19 — Внутренняя ошибка сервера , что означает, что данные конфигурации недействительны . См. Дополнительные способы, по которым вы можете увидеть внутреннюю ошибку сервера ниже для полного списка.
4. Как исправить ошибку внутреннего сервера 500
Как я уже упоминал выше, 500 Internal Server Error представляет собой ошибку на стороне сервера , что означает, что проблема, вероятно, связана не с вашим компьютером или интернет-соединением, а с сервером веб-сайта.
Хотя это и не вероятно, возможно , что с вашей стороны тоже что-то не так, и в этом случае мы рассмотрим некоторые вещи, которые вы можете попробовать:
-
1. Перезагрузите страницу. Вы можете сделать это, нажав кнопку обновления / перезагрузки, нажав F5 или Ctrl-R или повторив URL-адрес из адресной строки.
Даже если проблема 500 Internal Server Error является проблемой на веб-сервере, проблема может быть просто временной. Повторное повторение страницы часто проходит успешным.
Примечание. Если во время процесса проверки у онлайн-продавца появляется сообщение 500 Internal Server Error, имейте в виду, что повторные попытки проверки могут привести к созданию нескольких заказов — и нескольких сборов! У большинства продавцов есть автоматическая защита от таких действий, но это все равно то, о чем нужно помнить.
Примечание. Ошибки внутреннего сервера часто возникают из-за проблем с кешированием, но иногда я вижу, что ошибка исчезла после очистки кеша. Это такая легкая и безобидная вещь, чтобы не попробовать, поэтому не пропустите ее.
- 3.Удалите файлы cookie вашего браузера. Некоторые проблемы с внутренней ошибкой 500 могут быть исправлены путем удаления файлов cookie, связанных с сайтом, на котором вы получаете ошибку.
После удаления файлов cookie перезагрузите браузер и повторите попытку.
Это не очень распространено, но некоторые серверы производят 500 внутренних ошибок сервера, когда на самом деле более подходящее сообщение, основанное на причине проблемы, составляет 504 Gateway Timeout.
См. Страницу контактной информации для связи с владельцами ресурса для популярных веб-сайтов. На большинстве сайтов есть учетные записи социальных сетей на основе поддержки, а некоторые даже имеют номера электронной почты и телефонов.
Совет. Если это похоже на то, что сайт полностью отключен, и вы не можете найти способ сообщить об ошибке «Внутренняя ошибка сервера 500» на веб-сайт, это может помочь вашему здравомыслию идти в ногу с отключением в Twitter. Обычно вы можете сделать это, выполнив поиск #websitedown в Twitter, как в #gmaildown или #facebookdown .
- 6. Вернуться позже. К сожалению, на данный момент 500 Internal Server Error, без сомнения, является проблемой вне вашего контроля, которая в конечном итоге будет исправлена кем-то другим.
Если сообщение 500 Internal Server Error появляется во время покупки в Интернете, это может помочь понять, что продажи, вероятно, нарушены — обычно это большой стимул для интернет-магазина, чтобы быстро решить проблему!
Даже если вы получаете ошибку 500 на сайте, который ничего не продает, например YouTube или Twitter, если вы сообщите им об этой проблеме или, по крайней мере, попробуете, вы можете сделать немного больше, чем просто ждать.
5. Исправление ошибки 500 внутреннего сервера на вашем сайте
Внутренняя ошибка сервера 500 на вашем собственном веб-сайте требует совершенно иного действия. Как я уже упоминал выше, большинство 500 ошибок являются ошибками на стороне сервера, а это означает, что, скорее всего, ваша проблема будет исправлена, если это ваш сайт.
Существует множество причин, по которым ваш сайт может показывать errors 500 вашим пользователям, но эти наиболее распространены:
- Ошибка разрешений. В большинстве случаев ошибка 500 внутренних серверов связана с неправильным разрешением одного или нескольких файлов или папок. В большинстве случаев виновато неправильное разрешение на скрипт PHP и CGI . Обычно они должны быть установлены в 0755 (-rwxr-xr-x).
- Тайм-аут PHP (PHP Timeout). Если ваш скрипт подключается к внешним ресурсам и тайм-ауту этих ресурсов, может возникнуть ошибка HTTP 500. Правила тайм-аута или лучшая обработка ошибок в вашем скрипте должны помочь, если это является причиной ошибки 500.
- Ошибка кодирования в .htaccess. Хотя это не так часто, убедитесь, что файл .htaccess вашего сайта правильно структурирован.
Если вы используете WordPress , Joomla или другое управление контентом или систему CMS, обязательно выполните поиск в своих центрах поддержки, чтобы получить более конкретную помощь по устранению ошибки 500 Internal Server Error, также может помочь обновление версии движка.
Если вы не используете готовый движок, ваш веб-хостинг-провайдер, вероятно, имеет на своем сайте форум или страницу с ответами, где есть ответ на ошибку 500 или другие которые могут быть более конкретными для вашей ситуации.
6. Дополнительные способы просмотра внутренней ошибки сервера
В Internet Explorer сообщение, на котором веб-сайт не может отображать страницу, часто указывает на ошибку внутреннего сервера HTTP 500. Ошибка 405 Method Not Allowed — еще одна возможность, но вы можете быть уверены, ища 500 или 405 в заголовке IE.
Когда службы Google, такие как Gmail или Google+, испытывают 500 — внутренняя ошибка сервера, они часто сообщают о временной ошибке (500) или просто 500 .
Когда Центр обновления Windows сообщает о внутренней ошибке сервера, и она отображается как сообщение WU_E_PT_HTTP_STATUS_SERVER_ERROR или как код ошибки 0x8024401F .
Если на веб-сайте, который сообщает об ошибке 500, работает Microsoft IIS, вы можете получить более конкретное сообщение об ошибке:
500,0 — Возникла ошибка модуля или ISAPI.
500,11 — Приложение закрывается на веб-сервере.
500,12 — Приложение перезагружается на веб-сервере.
500,13 — Веб-сервер слишком занят.
500,15 — Прямые запросы для Global.asax запрещены.
500,19 — Неверные данные конфигурации.
500,21 — Модуль не распознан.
500,22 — Конфигурация httpModules ASP.NET не применяется в режиме управляемого канала.
500,23 — Конфигурация ASP.NET httpHandlers не применяется в режиме управляемого канала.
500,24 — Конфигурация олицетворения ASP.NET не применяется в режиме управляемого канала.
500,50 — Во время обработки уведомлений RQ_BEGIN_REQUEST произошла ошибка перезаписи. Произошла ошибка выполнения конфигурации или входящего правила.
500,51 — Ошибка перезаписи произошла при обработке уведомлений GL_PRE_BEGIN_REQUEST. Произошла глобальная ошибка выполнения конфигурации или глобального правила.
500,52 — При обработке RQ_SEND_RESPONSE произошла ошибка перезаписи.Выполнено выполнение исходящего правила.
500,53 — Во время обработки уведомлений RQ_RELEASE_REQUEST_STATE произошла ошибка перезаписи. Произошла ошибка выполнения исходящего правила. Правило настроено для выполнения перед обновлением кэша выходных пользователей.
500,100 — Внутренняя ошибка ASP.
Более подробную информацию об этих кодах, относящихся к IIS, можно найти в коде состояния HTTP HTTP на страницах IIS 7.0, IIS 7.5 и IIS 8.0 .
Ошибки Как ошибка HTTP 500
Многие сообщения об ошибках в браузере похожи на сообщение «Внутренняя ошибка сервера 500», потому что все серверные ошибки, и на такие как 502 Bad Gateway , 503 Service Unavailable и 504 Gateway Timeout .
Также существует множество кодов статуса HTTP на стороне клиента, например, популярная ошибка 404 Not Found . Вы можете увидеть их все в моих списках ошибок кода состояния HTTP .