Yii2 возникла внутренняя ошибка сервера

Ошибка 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

Mikayel Margaryan's user avatar

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

Mikayel Margaryan's user avatar

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

Ganesh Patel's user avatar

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

pedro casas's user avatar

Обработка ошибок ¶

Если при обработке запроса к 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 и отображает результаты (можно указать диапазоны дат, а некоторые данные можно отфильтровать по результатам). До сих пор он использовался чуть больше года, без проблем. Недавно мне было предложено реализовать несколько дополнительных запросов, и с тех пор после этого нажатия определенные диапазоны дат возвращают:

Ошибка (№ 8)
Произошла внутренняя ошибка сервера.

Сообщение.

Я везде искал, что это значит, но лучшее, что я могу догадаться, это то, что это как-то связано с нулевыми значениями; который я тщательно протестировал и уверен, что проблема не в этом.

Эта ошибка не возникает на моем экземпляре localhost приложения (который получает с сервера dev, а не с рабочего сервера). Сервер разработчика идентичен производственному серверу за исключением того, что он хранит различную информацию.

Ограничения:

У меня нет доступа к производственному серверу для проверки пользовательских данных, создающих ошибку.

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

Спасибо

2

Решение

Yii определяет и использует константы YII_DEBUG и YII_ENV. И они установлены в «true» и «dev». Это потому, что базовый шаблон приложения подготовил его таким образом в index.php файл. Этот файл также говорит нам, что мы должны удалить эти строки для производственного режима, то есть на производственном компьютере. Затем эти константы устанавливаются в «false» и «prod» по умолчанию. (Более подробную информацию можно найти на Определение констант и констант среды.)

2

Другие решения

Других решений пока нет …

Понравилась статья? Поделить с друзьями:

Не пропустите эти материалы по теме:

  • Яндекс еда ошибка привязки карты
  • Yii2 rest api обработка ошибок
  • Yii2 500 ошибка
  • Yii сообщение об ошибке
  • Yii показывать ошибки

  • 0 0 голоса
    Рейтинг статьи
    Подписаться
    Уведомить о
    guest

    0 комментариев
    Старые
    Новые Популярные
    Межтекстовые Отзывы
    Посмотреть все комментарии