Сбой восстановления ядра asp.net - несколько проектов (ubuntu-16.04-x64)
Я пытаюсь развернуть приложение.NET Core в Ubuntu 16.04. Проект содержит ссылки на другие проекты (т.е. не через nuget), локально приложение работает нормально (win10-x64), однако на сервере при наборе текста dotnet restore
Я получаю следующий журнал:
XXXXXX@ip-XXX-XXX-XXX-X:/home/XXXXXX$ dotnet restore
log : Restoring packages for /home/XXXXXX/project.json...
error: Unable to resolve 'XXXXXX.Configuration (>= 1.0.0)' for '.NETCoreApp,Version=v1.0'.
error: Unable to resolve 'XXXXXX.DataModels (>= 1.0.0)' for '.NETCoreApp,Version=v1.0'.
error: Unable to resolve 'XXXXXX.DAL (>= 1.0.0)' for '.NETCoreApp,Version=v1.0'.
error: Unable to resolve 'XXXXXX.Application (>= 1.0.0-0)' for '.NETCoreApp,Version=v1.0'.
error: Unable to resolve 'XXXXXX.BLL (>= 1.0.0)' for '.NETCoreApp,Version=v1.0'.
log : Lock file has not changed. Skipping lock file write. Path: /home/XXXXXX/project.lock.json
log : /home/XXXXXX/project.json
log : Restore failed in 4546ms.
log : Lock file has not changed. Skipping lock file write. Path:
Я рассмотрел этот совет в соответствующих вопросах здесь, здесь и здесь, однако ни одно из решений, похоже, не решило мою проблему.
Учитывая скорость изменений в платформе Core, я укажу используемые версии и файлы project.json для проектов:
XXXXXX.Configuration (библиотека базовых классов.NET) project.json:
{
"version": "1.0.0-*",
"dependencies": {
"NETStandard.Library": "1.6.1"
},
"frameworks": {
"netstandard1.6": {
"imports": "dnxcore50"
}
}
}
XXXXXX.DataModels (библиотека базовых классов.NET) project.json
{
"version": "1.0.0-*",
"dependencies": {
"NETStandard.Library": "1.6.1",
"XXXXXX.Application": "1.0.0-0"
},
"frameworks": {
"netstandard1.6": {
"imports": "dnxcore50"
}
}
}
XXXXXX.DAL (библиотека базовых классов.NET) project.json
{
"version": "1.0.0-*",
"dependencies": {
"MySql.Data": "7.0.6-IR31",
"NETStandard.Library": "1.6.1",
"XXXXXX.Application": "1.0.0-0",
"XXXXXX.Configuration": "1.0.0-*",
"XXXXXX.DataModels": "1.0.0-*"
},
"frameworks": {
"netstandard1.6": {
"imports": "dnxcore50"
}
}
}
XXXXXX.Application (библиотека базовых классов.NET) poject.json
{
"version": "1.0.0-0",
"dependencies": {
"Microsoft.AspNetCore.Mvc.Abstractions": "1.1.0",
"Microsoft.AspNetCore.Mvc.Core": "1.1.0",
"Microsoft.AspNetCore.Mvc.DataAnnotations": "1.1.0",
"Microsoft.AspNetCore.Mvc.ViewFeatures": "1.1.0",
"MySql.Data": "7.0.6-IR31",
"NETStandard.Library": "1.6.1",
"System.Data.SqlClient": "4.3.0"
},
"frameworks": {
"netstandard1.6": {
"imports": "dnxcore50"
}
}
}
XXXXXX.BLL (библиотека базовых классов.NET) project.json
{
"version": "1.0.0-*",
"dependencies": {
"Microsoft.Extensions.Configuration.Binder": "1.1.0",
"NETStandard.Library": "1.6.1",
"XXXXXX.Application": "1.0.0-*",
"XXXXXX.Configuration": "1.0.0-*",
"XXXXXX.DAL": "1.0.0-*",
"XXXXXX.DataModels": "1.0.0-*"
},
"frameworks": {
"netstandard1.6": {
"imports": "dnxcore50"
}
}
}
И, наконец, проект.NET Core Web UI, который связывает все это вместе:
XXXXXX.WebUI project.json
{
"dependencies": {
"BundlerMinifier.Core": "2.3.327",
"Microsoft.AspNetCore.Server.IISIntegration.Tools": "1.1.0-preview4-final",
"Microsoft.AspNetCore.Mvc": "1.1.1",
"Microsoft.AspNetCore.Razor.Tools": "1.1.0-preview4-final",
"Microsoft.AspNetCore.Routing": "1.1.0",
"Microsoft.AspNetCore.Server.IISIntegration": "1.1.0",
"Microsoft.AspNetCore.Server.Kestrel": "1.1.0",
"Microsoft.AspNetCore.StaticFiles": "1.1.0",
"Microsoft.Extensions.Configuration.EnvironmentVariables": "1.1.0",
"Microsoft.Extensions.Configuration.Json": "1.1.0",
"Microsoft.NETCore.App": {
"version": "1.1.0",
"type": "platform"
},
"Microsoft.AspNetCore.Session": "1.1.0",
"PaulMiami.AspNetCore.Mvc.Recaptcha": "1.1.1",
"Microsoft.AspNetCore.Mvc.Abstractions": "1.1.1",
"Microsoft.Extensions.Options": "1.1.0",
"Microsoft.VisualStudio.Web.BrowserLink.Loader": "14.1.0",
"XXXXXX.DataModels": {
"version":"1.0.0-*",
"target": "project"
},
"XXXXXX.Application": {
"version": "1.0.0-0",
"target": "project"
},
"XXXXXX.Configuration": {
"version": "1.0.0-*",
"target": "project"
},
"XXXXXX.DAL": {
"version": "1.0.0-*",
"target": "project"
},
"XXXXXX.BLL": {
"version": "1.0.0-*",
"target": "project"
}
},
"tools": {
},
"frameworks": {
"netcoreapp1.0": {
"imports": [
"dotnet5.6",
"portable-net45+win8"
]
}
},
"buildOptions": {
"emitEntryPoint": true,
"preserveCompilationContext": true,
"copyToOutput": [ "web.development.environment.json" ]
},
"runtimeOptions": {
"configProperties": {
"System.GC.Server": true
}
},
"runtimes": {
"win10-x64": {},
"ubuntu.16.04-x64": {}
},
"publishOptions": {
"include": [
"wwwroot",
"**/*.cshtml",
"appsettings.json",
"web.config",
"global.json",
"project.json",
"web.development.environment.json"
]
},
"scripts": {
"prepublish": [ "bower install", "dotnet bundle" ],
"postpublish": [ "dotnet publish-iis --publish-folder %publish:OutputPath% --framework %publish:FullTargetFramework%" ]
}
}
У меня также есть global.json, который при публикации находится в корневой папке (на один уровень выше проектов)
{
"projects": [
"src",
"/home/XXXXXX/XXXXXX.Application.dll",
"/home/XXXXXX/XXXXXX.Configuration.dll",
"/home/XXXXXX/XXXXXX.DataModels.dll",
"/home/XXXXXX/XXXXXX.Common.dll",
"/home/XXXXXX/XXXXXX.BLL.dll",
"/home/XXXXXX/XXXXXX.DAL.dll",
"/home/XXXXXX/XXXXXX.Notifications.Client.dll",
"/home/XXXXXX/XXXXXX.Notifications.DataModels.dll",
"/home/XXXXXX/XXXXXX.WebUI.dll"
]
}
РЕДАКТИРОВАТЬ
Публикация / сборка в VS создала следующую иерархию:
/home
/XXXXXX
/bin
/refs
/runtimes
/Views
/wwwroot
global.json
project.json
XXXXXX.Configuration.dll
XXXXXX.Application.dll
XXXXXX.DataModels.dll
XXXXXX.BLL.dll
XXXXXX.DAL.dll
XXXXXX.WebUI.dll
web.config
web.development.environment.json
(+ Many .NET dlls)
Итак, все проекты были построены и размещены на одном уровне - кажется неправильным, но эй, это автоматизировано.
Помогите!
1 ответ
По сути, проблема возникает, когда некоторые сторонние пакеты перешли на поддержку только netcoreapp1.1.
Я воссоздал свои проекты в VS 2017 (используя ye olde .csproj) сделал обновление до 1.1. Теперь все отлично работает.
Мой совет: установите VS 2017 и перенесите любой проект на более старые версии ядра dotnet, чтобы избежать проблем с Nuget позже.
Здесь надеются на большую стабильность в платформе в ближайшие месяцы.