Я полностью застрял в простом приложении .net-core 3.1 на IIS 10, которое упорно выдает внутреннюю ошибку 500, но отказывается давать какие-либо журналы или любые другие подсказки по проблеме.
Приложение прекрасно работает в dev env и при запуске с dotnet myapp.dll.
- Я использую только http-порт 80, чтобы он заработал, и удалил app.UseHttpsRedirection (); из Startup.cs
- Я установил ASP.NET Core 3.1 Runtime (v3.1.3) - Windows Hosting Bundle на сервере Windows 2016
- В пуле приложений нет управляемого кода и интегрированного конвейера.
- Сайт в IIS отвечает на простые html-страницы
- Приложение было опубликовано в папке как приложение в IIS, как интегрированная платформа, так и как автономное.
- Как я вижу, разрешения для всех каталогов верны во всех аспектах.
- Каталоги журналов (я помещаю их повсюду, на всякий случай) созданы и представлены всем, у кого есть доступ для записи, а web.config:
<aspNetCore processPath=".\MyApp.exe" stdoutLogEnabled="true" stdoutLogFile=".\logs\stdout" hostingModel="inprocess" />
- Я тестировал как .UseKestrel (), так и не в Program.cs
Тот факт, что я могу запустить его и запустить с помощью dotnet myapp.dll, говорит мне, что с самим приложением все в порядке.
Есть ли способ получить некоторые журналы или лучшую страницу 500 внутренних ошибок? НИЧЕГО нет ни в журналах событий Windows, ни в журналах W3C, ни в каком-либо каталоге. \ Logs. Просто проклятые 500 внутренних ошибок, которые не дают ключа к разгадке реальной проблемы.
Буду бесконечно благодарен за несколько мудрых предложений.
// Мартин
Приложение, класс Startup с рядом комментариев, которые появлялись и исчезали во время тестирования:
public class Startup
{
public Startup(IConfiguration configuration)
{
Configuration = configuration;
}
public IConfiguration Configuration { get; }
// This method gets called by the runtime. Use this method to add services to the container.
public void ConfigureServices(IServiceCollection services)
{
services.AddControllersWithViews();
services.AddTransient<AppDb>(_ => new AppDb(Configuration["ConnectionStrings:validAndWorkingString"]));
services.AddDistributedMemoryCache();
services.AddSession(options =>
{
options.IdleTimeout = TimeSpan.FromSeconds(10);
options.Cookie.HttpOnly = true;
options.Cookie.IsEssential = true;
});
}
// This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
//if (env.IsDevelopment())
//{
app.UseDeveloperExceptionPage();
//}
//else
//{
// app.UseExceptionHandler("/Home/Error");
// // The default HSTS value is 30 days. You may want to change this for production scenarios, see https://aka.ms/aspnetcore-hsts.
// app.UseHsts();
//}
app.UseSession();
// app.UseHttpsRedirection();
app.UseStaticFiles();
app.UseRouting();
app.UseAuthorization();
app.UseEndpoints(endpoints =>
{
endpoints.MapControllerRoute(
name: "default",
pattern: "{controller=Home}/{action=Index}/{id?}");
});
}
}
И FWIW класс Program, в котором я тестировал использование бота Kestrel, а не с таким же поведением:
public class Program
{
public static void Main(string[] args)
{
bool useKestrel = true;
if (useKestrel)
{
var host = new WebHostBuilder()
.UseKestrel()
.UseContentRoot(Directory.GetCurrentDirectory())
.UseIISIntegration()
.UseStartup<Startup>()
.Build();
host.Run();
}
else
{
CreateHostBuilder(args).Build().Run();
}
}
public static IHostBuilder CreateHostBuilder(string[] args) =>
Host.CreateDefaultBuilder(args)
.ConfigureWebHostDefaults(webBuilder =>
{
webBuilder.UseStartup<Startup>();
});
}