Ошибка 500 чаще всего возникает из-за того, что в файл .htaccess вносятся директивы, которые явно противоречат настройкам веб-сервера или их дублируют. Записи о подобных ошибках будут внесены в лог ошибок сайта (в ISPManager, например, в разделе “Журнал”). В частности, это могут быть директивы для изменения настроек php — тогда строка будет начинаться с
php_flag
или
php_value
Поскольку на хостинге php работает в режиме fastCGI, а не mod_apache, то настройки php подобным образом выполнять недопустимо — их следует вносить в файл php.ini
А также директивы связанные с работой с симлинками: к примеру, Options +SymLinksIfOwnerMatch будет выдавать ошибку, строку следует заменить на Options +FollowSymLinks
Эта ошибка может возникнуть и при попытке обработать слишком большой файл, — в этом случае проверьте папки вашего сайта, хранящие логи.
Лучше всего дебажить ошибку через логи веб-сервера, рекомендую погрузится в журналы сервера и детально почитать о чем пытается сообщить веб-сервер.
На крайний случай обратитесь в поддержку хостинга, часто провайдеры помогают перенести сайты на свою площадку, мигрируют как на shared-хостинг так и на виртуальные сервера или выделенные физические железки.
I’m working on Yii2 project from external server. On that server everything work. But when I try to start it locally I get this error on first page.
Error (#8)
An internal server error occurred.
All other pages work except backend page. There I get the same error.
How can I fix it?
asked Jan 13, 2017 at 7:41
5
I changed value of YII_DEBUG to true
defined('YII_DEBUG') or define('YII_DEBUG', true);
in BaseYii.php file, got all errors and fixed them. Now everything works.
answered Jan 13, 2017 at 8:29
1
try this yii2 index.php
defined('YII_ENV') or define('YII_ENV', 'prod');
if (@$_GET['debug'] == 1) {
defined('YII_DEBUG') or define('YII_DEBUG', true);
} else {
defined('YII_DEBUG') or define('YII_DEBUG', false);
}
answered Mar 24, 2018 at 4:15
The last few times I’ve gotten this, it’s been overflowing memory.
update the limit in php.ini
answered Nov 30, 2018 at 16:59
Обработка ошибок ¶
Если при обработке запроса к RESTful API в запросе пользователя обнаруживается ошибка или происходит
что-то непредвиденное на сервере, вы можете просто выбрасывать исключение, чтобы уведомить пользователя о нештатной ситуации.
Если вы можете установить конкретную причину ошибки (например, запрошенный ресурс не существует), вам следует подумать
о том, чтобы выбрасывать исключение с соответствующим кодом состояния HTTP (например, yiiwebNotFoundHttpException,
соответствующее коду состояния 404). Yii отправит ответ с соответствующим
HTTP-кодом и текстом. Он также включит в тело ответа сериализованное представление
исключения. Например:
HTTP/1.1 404 Not Found
Date: Sun, 02 Mar 2014 05:31:43 GMT
Server: Apache/2.2.26 (Unix) DAV/2 PHP/5.4.20 mod_ssl/2.2.26 OpenSSL/0.9.8y
Transfer-Encoding: chunked
Content-Type: application/json; charset=UTF-8
{
"name": "Not Found Exception",
"message": "The requested resource was not found.",
"code": 0,
"status": 404
}
Сводный список кодов состояния HTTP, используемых REST-фреймворком Yii:
200: OK. Все сработало именно так, как и ожидалось.201: Ресурс был успешно создан в ответ наPOST-запрос. ЗаголовокLocation
содержит URL, указывающий на только что созданный ресурс.204: Запрос обработан успешно, и в ответе нет содержимого (для запросаDELETE, например).304: Ресурс не изменялся. Можно использовать закэшированную версию.400: Неверный запрос. Может быть связано с разнообразными проблемами на стороне пользователя, такими как неверные JSON-данные
в теле запроса, неправильные параметры действия, и т.д.401: Аутентификация завершилась неудачно.403: Аутентифицированному пользователю не разрешен доступ к указанной точке входа API.404: Запрошенный ресурс не существует.405: Метод не поддерживается. Сверьтесь со списком поддерживаемых HTTP-методов в заголовкеAllow.415: Не поддерживаемый тип данных. Запрашивается неправильный тип данных или номер версии.422: Проверка данных завершилась неудачно (в ответе наPOST-запрос, например). Подробные сообщения об ошибках смотрите в теле ответа.429: Слишком много запросов. Запрос отклонен из-за превышения ограничения частоты запросов.500: Внутренняя ошибка сервера. Возможная причина — ошибки в самой программе.
Свой формат ответа с ошибкой ¶
Вам может понадобиться изменить формат ответа с ошибкой. Например, вместо использования разных статусов ответа HTTP
для разных ошибок, вы можете всегда отдавать статус 200, а реальный код статуса отдавать как часть JSON ответа:
HTTP/1.1 200 OK
Date: Sun, 02 Mar 2014 05:31:43 GMT
Server: Apache/2.2.26 (Unix) DAV/2 PHP/5.4.20 mod_ssl/2.2.26 OpenSSL/0.9.8y
Transfer-Encoding: chunked
Content-Type: application/json; charset=UTF-8
{
"success": false,
"data": {
"name": "Not Found Exception",
"message": "The requested resource was not found.",
"code": 0,
"status": 404
}
}
Для этого можно использовать событие beforeSend компонента response прямо в конфигурации приложения:
return [
// ...
'components' => [
'response' => [
'class' => 'yiiwebResponse',
'on beforeSend' => function ($event) {
$response = $event->sender;
if ($response->data !== null && !empty(Yii::$app->request->get('suppress_response_code'))) {
$response->data = [
'success' => $response->isSuccessful,
'data' => $response->data,
];
$response->statusCode = 200;
}
},
],
],
];
Приведённый выше код изменит формат ответа (как для удачного запроса, так и для ошибок) если передан GET-параметр
suppress_response_code.
В каждом ответе Http-протокола существует некий 3-х значный код. Он позволяет клиенту правильно трактовать полученный результат. Думаю всем веб-мастерам хорошо известен код «404 — Not found». Кодов на самом деле огромное множество, все они описаны в спецификации Http протокола. Но знать все не обязательно. Главное при создании Exception (исключения) выбрать правильную группу кодов ответа. Групп всего 5:
- 1xx Информационные сообщения
- 2xx Успешное выполнение запроса
- 3xx Перенаправления (редирект)
- 4xx Ошибки клиента
- 5xx Ошибка на сервере
К ошибкам клиента относятся обращения к несуществующей странице, к запрещенной странице, неправильные параметры запроса, вызов не существующего метода, слишком большое количество запросов.
К серверным ошибкам относятся внутренние ошибки сервера, недоступность сервиса или отсутствие поддержки данной версии протокола.
Из всего вышесказанного становится понятно, что разработчику для корректной обработки ошибок нужны коды из 4 группы.
HttpException в Yii2
Зачем вообще нужны Exception? Для того, чтобы в случаи неожиданной ошибки, приложение могло сообщить о том, что его работа прекращена по такой-то причине. Exception можно отлавливать и обрабатывать, например с помощью конструкции try catch.
В Yii2 есть класс yiiwebHttpException с помощью которого можно создать любое исключение.
throw new HttpException(404 ,'User not found');
Так же существуют классы со звучными именами для наиболее часто используемых типов ошибок, благодаря которым вам не нужно запоминать код ответа.
- BadRequestHttpException — 400 ошибка
- UnauthorizedHttpException — 401 ошибка
- ForbiddenHttpException — 403 ошибка
- NotFoundHttpException — 404 ошибка
- MethodNotAllowedHttpException — 405 ошибка
- NotAcceptableHttpException — 406 ошибка
- ConflictHttpException — 409 ошибка
- GoneHttpException — 410 ошибка
- UnsupportedMediaTypeHttpException — 415 ошибка
- TooManyRequestsHttpException — 429 ошибка
- ServerErrorHttpException — 500 ошибка
Все они отнаследованы от yiiwebHttpException и не нуждаются указании кода ответа.
throw new NotFoundHttpException('User not found');
Установить статус ответа можно и с помощью метода setStatusCode() класса yiiwebResponse
Yii::$app->response->setStatusCode(422);
Это удобно тогда, когда есть необходимость передать что-либо в теле ответа.
-
lolka
- Сообщения: 143
- Зарегистрирован: 2013.05.05, 20:59
-
lolka
- Сообщения: 143
- Зарегистрирован: 2013.05.05, 20:59
Re: После установки yii2 выдает ошибку An internal server error occurred.
Сообщение
lolka » 2016.09.02, 16:47
ошибка при выполнении этих команд
Deprecation Notice: The ComposerPackageLinkConstraintMultiConstraint class is deprecated, use ComposerSemverConstraintMultiConstraint instead. in phar:///var/www/site/composer.phar/src/Composer/Package/LinkConstraint/MultiConstraint.php:17
Deprecation Notice: The ComposerPackageLinkConstraintLinkConstraintInterface interface is deprecated, use ComposerSemverConstraintConstraintInterface instead. in phar:///var/www/site/composer.phar/src/Composer/Package/LinkConstraint/LinkConstraintInterface.php:17
Composer could not find a composer.json file in /var/www/site
To initialize a project, please create a composer.json file as described in the https://getcomposer.org/ «Getting Started» section
-
lolka
- Сообщения: 143
- Зарегистрирован: 2013.05.05, 20:59
Re: После установки yii2 выдает ошибку An internal server error occurred.
Сообщение
lolka » 2016.09.02, 17:06
чет не очень , ошибки за ошибками
[ReflectionException]
Class FxpComposerAssetPluginRepositoryNpmRepository does not exist
[ErrorException]
Declaration of FxpComposerAssetPluginRepositoryAbstractAssetsRepository
::whatProvides() should be compatible with ComposerRepositoryComposerRepo
sitory::whatProvides(ComposerDependencyResolverPool $pool, $name, $bypass
Filters = false)
пробовал сделать следующее
php composer.phar global update fxp/composer-asset-plugin —no-plugins
не помогло
-
rugabarbo
- Сообщения: 1063
- Зарегистрирован: 2015.06.21, 16:21
- Контактная информация:
-
lolka
- Сообщения: 143
- Зарегистрирован: 2013.05.05, 20:59
Re: После установки yii2 выдает ошибку An internal server error occurred.
Сообщение
lolka » 2016.09.02, 17:19
ну выводится эта же ошибка
[ReflectionException]
Class FxpComposerAssetPluginRepositoryNpmRepository does not exist
[ErrorException]
Declaration of FxpComposerAssetPluginRepositoryAbstractAssetsRepository
::whatProvides() should be compatible with ComposerRepositoryComposerRepo
sitory::whatProvides(ComposerDependencyResolverPool $pool, $name, $bypass
Filters = false)
при выполнении любой команды
-
rugabarbo
- Сообщения: 1063
- Зарегистрирован: 2015.06.21, 16:21
- Контактная информация:
-
rugabarbo
- Сообщения: 1063
- Зарегистрирован: 2015.06.21, 16:21
- Контактная информация:
Re: После установки yii2 выдает ошибку An internal server error occurred.
Сообщение
rugabarbo » 2016.09.02, 17:44
Есть предположение, что стоит старый плагин композера, который мешает ему работать.
Исходя из этого можно попробовать так:
1. Убрать старый плагин:
Код: Выделить всё
composer global remove "fxp/composer-asset-plugin"
2. Почистить кэш:
А лучше грохнуть целиком папку ~/.composer:
3. Обновить композер:
4. Поставить более новый плагин, например:
Код: Выделить всё
composer global require "fxp/composer-asset-plugin:*"
5. Далее стандартно:
—
Если будете пробовать, то к каждой команде укажите полученный вывод в консоли.
-
rugabarbo
- Сообщения: 1063
- Зарегистрирован: 2015.06.21, 16:21
- Контактная информация:
-
rugabarbo
- Сообщения: 1063
- Зарегистрирован: 2015.06.21, 16:21
- Контактная информация:
The project is running fine on the local system but when i deploying the project on the production server then i got the error which is coming from this path
vendor/yiisoft/yii2/base/ErrorHandler.php
if (YII_DEBUG) {
if (PHP_SAPI === 'cli') {
echo $msg . "n";
} else {
echo '<pre>' . htmlspecialchars($msg, ENT_QUOTES, Yii::$app->charset) . '</pre>';
}
} else {
echo 'An internal server error occurred.';
}
When i hit the url then screen show blank with above error «An internal server error occurred.» and the error coming from above code.
Here is my index.php
<?php
// comment out the following two lines when deployed to production
//defined('YII_DEBUG') or define('YII_DEBUG', true);
//defined('YII_ENV') or define('YII_ENV', 'dev');
require(__DIR__ . '/../vendor/autoload.php');
require(__DIR__ . '/../vendor/yiisoft/yii2/Yii.php');
$config = require(__DIR__ . '/../config/web.php');
(new yiiwebApplication($config))->run();
Обработка ошибок
Если при обработке запроса к RESTful API в запросе пользователя обнаруживается ошибка или происходит
что-то непредвиденное на сервере, вы можете просто выбрасывать исключение, чтобы уведомить пользователя о нештатной ситуации.
Если вы можете установить конкретную причину ошибки (например, запрошенный ресурс не существует), вам следует подумать
о том, чтобы выбрасывать исключение с соответствующим кодом состояния HTTP (например, [[yiiwebNotFoundHttpException]],
соответствующее коду состояния 404). Yii отправит ответ с соответствующим
HTTP-кодом и текстом. Он также включит в тело ответа сериализованное представление
исключения. Например:
HTTP/1.1 404 Not Found
Date: Sun, 02 Mar 2014 05:31:43 GMT
Server: Apache/2.2.26 (Unix) DAV/2 PHP/5.4.20 mod_ssl/2.2.26 OpenSSL/0.9.8y
Transfer-Encoding: chunked
Content-Type: application/json; charset=UTF-8
{
"name": "Not Found Exception",
"message": "The requested resource was not found.",
"code": 0,
"status": 404
}
Сводный список кодов состояния HTTP, используемых REST-фреймворком Yii:
200: OK. Все сработало именно так, как и ожидалось.201: Ресурс был успешно создан в ответ наPOST-запрос. ЗаголовокLocation
содержит URL, указывающий на только что созданный ресурс.204: Запрос обработан успешно, и в ответе нет содержимого (для запросаDELETE, например).304: Ресурс не изменялся. Можно использовать закэшированную версию.400: Неверный запрос. Может быть связано с разнообразными проблемами на стороне пользователя, такими как неверные JSON-данные
в теле запроса, неправильные параметры действия, и т.д.401: Аутентификация завершилась неудачно.403: Аутентифицированному пользователю не разрешен доступ к указанной точке входа API.404: Запрошенный ресурс не существует.405: Метод не поддерживается. Сверьтесь со списком поддерживаемых HTTP-методов в заголовкеAllow.415: Не поддерживаемый тип данных. Запрашивается неправильный тип данных или номер версии.422: Проверка данных завершилась неудачно (в ответе наPOST-запрос, например). Подробные сообщения об ошибках смотрите в теле ответа.429: Слишком много запросов. Запрос отклонен из-за превышения ограничения частоты запросов.500: Внутренняя ошибка сервера. Возможная причина — ошибки в самой программе.
Свой формат ответа с ошибкой
Вам может понадобиться изменить формат ответа с ошибкой. Например, вместо использования разных статусов ответа HTTP
для разных ошибок, вы можете всегда отдавать статус 200, а реальный код статуса отдавать как часть JSON ответа:
HTTP/1.1 200 OK
Date: Sun, 02 Mar 2014 05:31:43 GMT
Server: Apache/2.2.26 (Unix) DAV/2 PHP/5.4.20 mod_ssl/2.2.26 OpenSSL/0.9.8y
Transfer-Encoding: chunked
Content-Type: application/json; charset=UTF-8
{
"success": false,
"data": {
"name": "Not Found Exception",
"message": "The requested resource was not found.",
"code": 0,
"status": 404
}
}
Для этого можно использовать событие beforeSend компонента response прямо в конфигурации приложения:
return [ // ... 'components' => [ 'response' => [ 'class' => 'yiiwebResponse', 'on beforeSend' => function ($event) { $response = $event->sender; if ($response->data !== null && !empty(Yii::$app->request->get('suppress_response_code'))) { $response->data = [ 'success' => $response->isSuccessful, 'data' => $response->data, ]; $response->statusCode = 200; } }, ], ], ];
Приведённый выше код изменит формат ответа (как для удачного запроса, так и для ошибок) если передан GET-параметр
suppress_response_code.
/06 Tips /How to fix “An internal server error occurred” in Yii
If you’re running into a near empty screen showing, “An internal server error occurred” in Yii2, check your error logs. It’s a simple fix.
My logs showed:
An Error occurred while handling another error:nexception 'yii\base\InvalidConfigException' with message 'The directory is not writable by the Web process: /var/www/mp/backend/web/assets' in /var/www/mp/vendor/yiisoft/yii2/web/AssetManager.php:213
You can resolve it by opening up permissions on your asset directory:
sudo chmod -vR 0777 assets/
Я создал панель мониторинга, используя php-фреймворк Yii2 и mysql 5.3
Это довольно простое приложение, которое просто извлекает данные из БД с помощью mysql и отображает результаты (можно указать диапазоны дат, а некоторые данные можно отфильтровать по результатам). До сих пор он использовался чуть больше года, без проблем. Недавно мне было предложено реализовать несколько дополнительных запросов, и с тех пор после этого нажатия определенные диапазоны дат возвращают:
Ошибка (№ 
Произошла внутренняя ошибка сервера.
Сообщение.
Я везде искал, что это значит, но лучшее, что я могу догадаться, это то, что это как-то связано с нулевыми значениями; который я тщательно протестировал и уверен, что проблема не в этом.
Эта ошибка не возникает на моем экземпляре localhost приложения (который получает с сервера dev, а не с рабочего сервера). Сервер разработчика идентичен производственному серверу за исключением того, что он хранит различную информацию.
Ограничения:
У меня нет доступа к производственному серверу для проверки пользовательских данных, создающих ошибку.
Если бы кто-то уже сталкивался с этой проблемой и решил ее, или мог бы указать мне правильное направление, чтобы выяснить причину этого, я был бы очень благодарен.
Спасибо
2
Решение
Yii определяет и использует константы YII_DEBUG и YII_ENV. И они установлены в «true» и «dev». Это потому, что базовый шаблон приложения подготовил его таким образом в index.php файл. Этот файл также говорит нам, что мы должны удалить эти строки для производственного режима, то есть на производственном компьютере. Затем эти константы устанавливаются в «false» и «prod» по умолчанию. (Более подробную информацию можно найти на Определение констант и констант среды.)
2
Другие решения
Других решений пока нет …
