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)
在这里你可以阅读更多关于它的信息。