ASP Net Core Linux ERR_CONNECTION_REFUSED

Idu*_*tus 6 linux nginx asp.net-web-api digital-ocean asp.net-core

我正在测试将网络核心应用程序部署到运行 Ubuntu 18.04 和 Nginx 1.14 的 Digitalocean Droplet。为了进行测试,我使用了“dotnet new”中提供的模板。

DOTNET新的网络DOTNET新的MVC 应用程式做工精细。我可以从我的浏览器访问它们。我在使用dotnet new webapi应用程序时遇到问题。然而我试图达到它,我最终得到一个 ERR_CONNECTION_REFUSED 响应。

我为设置 Droplet 所做的简短版本:

wget -q https://packages.microsoft.com/config/ubuntu/18.04/packages-microsoft-prod.deb

须藤 dpkg -i 软件包-microsoft-prod.deb

sudo add-apt-repository 宇宙

sudo apt-get install apt-transport-https

sudo apt-get 更新

须藤 apt-get 安装 dotnet-sdk-2.2

sudo apt install nginx sudo ufw 允许'Nginx HTTP'

/etc/nginx/sites-available/default 内容:

server {
 listen 80;
 location / {
 proxy_pass http://127.0.0.1:5000; #also tried localhost:5000
 proxy_http_version 1.1;
 proxy_set_header Upgrade $http_upgrade;
 proxy_set_header Connection keep-alive;
 proxy_set_header Host $host;
 proxy_cache_bypass $http_upgrade;
 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
 proxy_set_header X-Forwarded-Proto $scheme;
 }
}
Run Code Online (Sandbox Code Playgroud)

curl 的结果(IP 地址有意删除)

curl -I -X GET http://123.123.123.123/api/values

HTTP/1.1 307 Temporary Redirect
Server: nginx/1.14.0 (Ubuntu)
Date: Sun, 19 May 2019 00:32:21 GMT
Content-Length: 0
Connection: keep-alive
Location: https://123.123.123.123:5001/api/values
Run Code Online (Sandbox Code Playgroud)

我的 Nginx 日志给了我这个错误,我用谷歌搜索无济于事:

2019/05/19 00:03:06 [error] 3632#3632: *4 connect() failed (111: Connection refused) while connecting to upstream, client: 12.123.12.123, server: , request: "GET / HTTP/1.1", upstream: "http://127.0.0.1:5000/", host: "123.123.123.117"
Run Code Online (Sandbox Code Playgroud)

为了回答@Oliver 的问题,这里是 netstat -ntlp 的输出

Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name
tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      3527/nginx: master
tcp        0      0 127.0.0.53:53           0.0.0.0:*               LISTEN      605/systemd-resolve
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN      946/sshd
tcp6       0      0 :::22                   :::*                    LISTEN      946/sshd
Run Code Online (Sandbox Code Playgroud)

关于我可能会忽略什么的任何建议?

谢谢!

小智 13

服务器的响应解释了原因。该GET请求http://127.0.0.1:5000被重定向到https://123.123.123.123:5001/api/values,这是因为HTTPS重定向处于活动状态。

解决方法:打开Startup.cs文件。在public void Configure(...)方法中找到以下行并注释掉:

app.UseHttpsRedirection();
Run Code Online (Sandbox Code Playgroud)

在这里你可以阅读更多关于它的信息。