如何解决在 Heroku 上部署 Net core 5.0 API 失败,出现 Docker 错误:无法启动 Kestrel
我尝试在 Heroku 上部署 Net core 5.0 API 并收到此错误: 无法启动 Kestrel。 System.FormatException: Invalid url: '3689' 数字“3689”在部署我的 API 的新版本时随时更改。
这是我的 docker 文件:
FROM mcr.microsoft.com/dotnet/sdk:5.0 AS build-env
WORKDIR /src
COPY Sporteate.API.csproj .
RUN dotnet restore
COPY . .
RUN dotnet publish -c Release -o /app
FROM mcr.microsoft.com/dotnet/aspnet:5.0
WORKDIR /app
COPY --from=build-env /app .
ENTRYPOINT ["dotnet","Sporteate.API.dll"]
CMD ASPNETCORE_URLS=http://*:$PORT dotnet Sporteate.API.dll
这是我的程序文件:
public class Program
{
private static readonly ILog log = LogManager.GetLogger(typeof(Program));
public static void Main(string[] args)
{
try
{
XmlDocument log4netConfig = new XmlDocument();
log4netConfig.Load(File.OpenRead("log4net.config"));
log4net.Config.XmlConfigurator.Configure(log4net.LogManager.GetRepository(Assembly.GetEntryAssembly()),log4netConfig["log4net"]);
CreateHostBuilder(args).Build().Run();
}catch(Exception ex)
{
log.Error(ex.Message);
}
}
public static IHostBuilder CreateHostBuilder(string[] args) =>
Host.CreateDefaultBuilder(args)
.ConfigureWebHostDefaults(webBuldier =>
{
var port = Environment.GetEnvironmentVariable("PORT");
webBuldier.UseStartup<Startup>().UseUrls("http://*:" + port!=null? port : "44308");
});
}
这是我的 Heroku 的 dynos 配置:
web /bin/sh -c ASPNETCORE_URLS\=http://\*:\$PORT\ dotnet\ Sporteate.API.dll
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。