2012-01-17 3 views
12

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

Наши автоматизированные скрипты сборки должны иметь возможность вставлять недавно созданные пакеты NuGet в галерею. Когда я использую 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 с запуском скрипта, он выполняет два последовательных запроса при выполнении команды push. Кажется, что он касается сайта, чтобы убедиться, что он есть, а второй - фактическая команда push.

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

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

Скрипач показывает это как ответ на 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> 

Я использую NuGet Version: 1.6.21205.9031 из командной строки.

В чем проблема?

EDIT: После включения подробных страниц ошибок на папке АФИ в месте, я получаю это с 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 

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

ответ

22

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

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

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

+0

+1. Обратите внимание, что имя группы - 'IIS_IUSRS' (с дополнительным' i'). – Cameron

+0

нет прав на редактирование при щелчке правой кнопкой мыши на сайте –

1

Я предполагаю, что вы имеете в виду новой галереи: https://github.com/NuGet/NuGetGallery

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

+0

Да, я имею в виду новую галерею. Я проверил, не видел ли Элма что-нибудь, и ничего не получилось. Я даже проверил в папке приложения файлы ошибок xml, и ничего. –

+0

Я попытался бы установить точку прерывания в запросе начала, чтобы увидеть, удаляет ли код управления вообще. Если нет, это может быть проблема конфигурации IIS. –

+0

Я запустил проект на своей локальной машине-разработчике и попытался использовать NuGet.exe для локального распространения пакета, и он работал отлично. Я думаю, что это определенно проблема конфигурации IIS. Любые мысли о том, что неправильно настроено? –

0

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

Оказалось, что пакет, о котором идет речь, был немного больше обычного, а IIS закрывает ограничение по умолчанию на 30 МБ, causing the nuget server to return this obscure error.Изменение настройки system.webServer.security.requestFiltering.requestLimits.maxAllowedContentLength на что-то большее разрешило это для меня (после того, как я удалил тип mime, который я добавил).

1

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

версия схемы «YOURLIB» несовместимо с версией «someVersion.a.b» из NuGet. Обновите NuGet до последней версии от http://go.microsoft.com/fwlink/?LinkId=213942.

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

+0

, в каком журнале вы нашли сообщение? –

 Смежные вопросы

  • Нет связанных вопросов^_^