Почему моя галерея NuGet возвращает 500 от Nuget Push? - PullRequest
12 голосов
/ 17 января 2012

Я установил новую галерею NuGet на веб-сервере (под IIS 7.0), где я работаю.Сам сайт настроен и работает нормально.Мы можем регистрировать учетные записи, подтверждать адреса электронной почты и даже загружать новый пакет через сам сайт.

Наши сценарии автоматической сборки должны иметь возможность отправлять вновь созданные пакеты NuGet в галерею.Когда я использую команду push NuGet:

nuget.exe push build\nuget\BaconAndEggs.1.0.0.1.nupkg 1451002a-8c63-4174-b7ed-73dd3e7bcdf0 -Source http://somenearbyserver/

, я получаю следующий результат:

Pushing BaconAndEggs 1.0.0.1 to 'http://somenearbyserver/'...
Failed to process request. 'Internal Server Error'.
The remote server returned an error: (500) Internal Server Error..

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

Request 1: GET http://somenearbyserver/ 200 OK
Request 2: PUT http://somenearbyserver/api/v2/package/ 500 Internal Server Error

Содержание запроса PUT правильное, оно содержит ключ API и полезную нагрузку.Глядя на веб-сервер, в средстве просмотра событий ошибок нет, и elmah ничего не ловит.

Fiddler показывает это как ответ на PUT:

HTTP/1.1 500 Internal Server Error
Content-Type: text/html
Server: Microsoft-IIS/7.0
X-Powered-By: ASP.NET
Date: Wed, 18 Jan 2012 20:21:08 GMT
Connection: close
Content-Length: 1208

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1"/>
<title>500 - Internal server error.</title>
<style type="text/css">
<!--
body{margin:0;font-size:.7em;font-family:Verdana, Arial, Helvetica, sans-serif;background:#EEEEEE;}
fieldset{padding:0 15px 10px 15px;} 
h1{font-size:2.4em;margin:0;color:#FFF;}
h2{font-size:1.7em;margin:0;color:#CC0000;} 
h3{font-size:1.2em;margin:10px 0 0 0;color:#000000;} 
#header{width:96%;margin:0 0 0 0;padding:6px 2% 6px 2%;font-family:"trebuchet MS", Verdana, sans-serif;color:#FFF;
background-color:#555555;}
#content{margin:0 0 0 2%;position:relative;}
.content-container{background:#FFF;width:96%;margin-top:8px;padding:10px;position:relative;}
-->
</style>
</head>
<body>
<div id="header"><h1>Server Error</h1></div>
<div id="content">
 <div class="content-container"><fieldset>
  <h2>500 - Internal server error.</h2>
  <h3>There is a problem with the resource you are looking for, and it cannot be displayed.</h3>
 </fieldset></div>
</div>
</body>
</html>

I'mиспользуя NuGet Version: 1.6.21205.9031 из командной строки.

В чем может быть проблема?

EDIT : после включения подробных страниц ошибок в папке api на сайте я получаюэто с ответом 500, описанным выше:

Server Error in Application "NUGET"

Internet Information Services 7.0

Error Summary
HTTP Error 500.0 - Internal Server Error

The page cannot be displayed because an internal server error has occurred.

Detailed Error Information
Module = LiveStreamingHandler
Notification = MapRequestHandler
Handler = WebDAV

Error Code = 0x80070585
Requested URL = http://somenearbyserver:80/api/v2/package/
Physical Path = M:\path\to\nuget-gallery\api\v2\package\
Logon Method = Anonymous
Logon User = Anonymous

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

Ответы [ 5 ]

22 голосов
/ 12 марта 2012

Я исправил эту проблему, изменив разрешения для пользователя IIS. Я добавил разрешения на запись для IIS_IUSRS.

Щелкните правой кнопкой мыши по сайту в IIS > edit permissions > security

Оттуда вы добавляете пользователя или группу и даете им права на запись.

1 голос
/ 16 августа 2016

В моем случае это был старый локальный сервер nuget.Сообщение, которое я нашел в журналах:

Версия схемы 'YourLib' несовместима с версией 'someVersion.ab' NuGet.Пожалуйста, обновите NuGet до последней версии с http://go.microsoft.com/fwlink/?LinkId=213942.

В моем случае я понизил версию nuget (скачал более старый файл nuget.exe) и заново создал пакет.Толчок теперь работает.Я не хотел мешать процессу в другом месте, и мне нужно было быстрое решение, но, конечно, это зависит от сценария, который у вас есть.В перспективе я буду обновлять nuget.

1 голос
/ 22 января 2012

Я полагаю, вы ссылаетесь на новую галерею: https://github.com/NuGet/NuGetGallery

Можете ли вы попробовать нажать /elmah.axd из учетной записи администратора и посмотреть, получите ли вы больше информации об ошибке?

0 голосов
/ 17 декабря 2018

Я предлагаю вам зайти на хост-сервер IIS и открыть eventvwr, вы должны точно сказать, почему произошла ошибка.посмотри в журнале Windows / Приложение

В моем случае это было из-за полного диска.Сообщение выглядит так:

Application information: 
    Application domain: /LM/W3SVC/4/ROOT-1-131895206439239270 
    Trust level: Full 
    Application Virtual Path: / 
    Application Path: E:\NuGet.Server\src\NuGet.Server\ 
    Machine name: CM 

Process information: 
    Process ID: 1876 
    Process name: w3wp.exe 
    Account name: NT AUTHORITY\SYSTEM 

Exception information: 
    Exception type: IOException 
    Exception message: **There is not enough space on the disk.**
...
...
0 голосов
/ 18 октября 2014

Поскольку это не упомянуто, вот мой сценарий:
Я смог отправить (и получить) большинство пакетов без каких-либо проблем.Но один пакет продолжал вызывать ошибку 404, когда я пытался выдвинуть его.Несколько источников в Интернете указали, что я должен добавить MIME-тип для .nupkg, однако все, что было сделано (независимо от MIME-типа), - превратить ошибку в внутреннюю ошибку сервера 500.

Получается пакетвопрос был немного больше обычного, и IIS ограничивает ограничение по умолчанию для запроса в 30 МБ, , в результате чего сервер nuget возвращает эту неясную ошибку .Изменение параметра system.webServer.security.requestFiltering.requestLimits.maxAllowedContentLength на что-то большее разрешило его для меня (после того, как я удалил добавленный тип пантомимы).

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...