wsl 2 unbuntu 部署 asp.net core 使用 nginx 做反向代理,调试文件上传失败
继上一篇 asp.net core 3.1多种身份验证方案,cookie和jwt混合认证授权 的公司内部项目上线后发现文件上传功能有问题。
上传的文件超过50M以后前端就报错了,没有状态返回,也没有响应。只有浏览器 Console 里面能看到一条 net::ERR_CONNECTION_RESET
错误。
50M以内的都能传输,第一反应肯定是配置或者参数限制了。因为是部署的Linux,然后 nginx 做反向代理,检查了代码,运行程序的方面的大小限制是已经解除了的。
然后就是nginx限制,让运维修改了大小限制,但是仍然不行。因为开发人员接触不到部署环境,运维又说配置已经修改了,最后只得我自己在本地模拟线上环境调试找问题了(本地测试使用的IIS部署)。
由于我机器安装了 wsl 2,所以准备用 wsl 2 来部署测试玩一玩,关于 wsl 2 的安装可以看这个 Windows10上安装Linux子系统(WSL2,Ubuntu),配合Windows Terminal使用
接口和服务修改上传限制
对于程序需要修改两个地方,一个是接口的请求大小限制,在方法上面打上 [DisableRequestSizeLimit]
另外一个是kestrel服务器 MultipartBodyLengthLimit
大小限制,Startup里面修改大小。
独立方式部署
一般本地测试环境 .NET Core 会使用预先安装运行时来部署,但是如果使用容器一般是自包含运行时的,所以使用独立方式部署走一波。
可以使用命令方式发布,有vs就直接操作下就行了。
右键发布,设置独立部署
模式,选择目标运行时 Linux-x64。
wsl 安装 unbuntu 后,本地几个盘就已经挂载在了mnt下面。所以直接可以访问windows上的目录启动程序,这也是wsl方便的地方。
我们进入到程序的目录,然后执行主程序就行了。注意: 如果已经在程序所在目录了,执行时要加 ./ 然后 ./xxx 的形式才能执行。
不需要安装任何东西或者依赖,程序已经启动了。接下来我们安装 nginx
nginx 安装和配置
使用 apt-get 安装 Nginx。
sudo apt-get install nginx
安装完成后启动nginx
sudo service nginx start
nginx 默认使用的是80端口,但是我启动后提示端口被占用。由于 wsl 与 Windows 是共用端口。
查看 iis 配置了80端口站点,停掉 iis 后再启动还是占用,搜索是 SQL Server Reporting Services 服务停止后就可以了。
测试环境如果你不是非要用80端口,可以在配置里面将 nginx 端口改成其它的,以防常用端口冲突。
Nginx 配置为反向代理将请求转接到 ASP.NET Core 应用,修改配置 /etc/nginx/sites-available/default。
sudo vim /etc/nginx/sites-available/default
使用vim修改配置为如下,我修改了 nginx 的端口为5000
server {
listen 5000;
location / {
proxy_pass http://localhost:5004;
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;
}
}
完成配置 Nginx 后,运行 sudo nginx -t
来验证配置文件的语法。 如果配置文件测试成功,通过运行 sudo nginx -s reload
重新加载。
测试与发现问题
上面的两步走完后,直接在 Windows 浏览器里面访问 http://localhost:5000 地址就行了,然后进行测试。
上传文件报 413 requset entity too large,但是 kestrel 并没有报错,所以将 nginx 配置 client_max_body_size
设置成 3000m。
再次上传几百兆的文件都可以,当我上传 1.5G 的文件时又报了一个错误。
504 超时,修改配置 设置 proxy_read_timeout
大小为 3600s,至于其它的一些 nginx 时间设置不用修改,比如网上有人修改链接超时时间什么的,其实没什么关系。
配置修改后同上,需要运行 sudo nginx -s reload
最后测试了 2G 以内各种大小的上传都能成功上传了。
最后
我将本地的测试情况给运维说明了情况,起码保证了程序是没问题的,以及nginx会出问题的点。
当然线上环境比我这个测试环境复杂,还需要运维去排查(可能是配置没生效或者配置不对),我这儿只是分享简单的部署安装和找问题过程。
另外还有一个注意点:
部署后启动服务报 Microsoft.Data.SqlClient.dll 目标平台不支持。最后将运行时里面的复制替换到程序下面就没问题了,而且运行时里面的文件是1M多,生成的只有几百k。
这个是为什么?暂时我还不得而知,有没知道的道友,后续我找到原因会更新在文章中。
wsl 2 unbuntu 部署 asp.net core 使用 nginx 做反向代理,调试文件上传失败的更多相关文章
- Asp.Net Core 轻松学-一行代码搞定文件上传 JSONHelper
Asp.Net Core 轻松学-一行代码搞定文件上传 前言 在 Web 应用程序开发过程中,总是无法避免涉及到文件上传,这次我们来聊一聊怎么去实现一个简单方便可复用文件上传功能:通过创建 ...
- Asp.Net Core使用Nginx实现反向代理
---恢复内容开始--- 前两篇文章介绍了使用Docker作为运行环境,用Nginx做反向代理的部署方法,这篇介绍一下使用Nginx配合.Net Core运行时直接在Liunx上裸奔的方法. 一.安装 ...
- Asp.Net Core 轻松学-一行代码搞定文件上传
前言 在 Web 应用程序开发过程中,总是无法避免涉及到文件上传,这次我们来聊一聊怎么去实现一个简单方便可复用文件上传功能:通过创建自定义绑定模型来实现文件上传. 1. 实现自定义绑定模型 1 ...
- 关于.net core使用nginx做反向代理获取客户端ip的问题
1.正常情况下.net core获取客户端ip是比较简单的 /// <summary> /// 获取客户Ip /// </summary> /// <param name ...
- 同一个服务器部署两个Tomcat并用Nginx实现反向代理
需求场景:由于服务器只有80端口可供外网访问,但需要部署两台tomcat来运行两个不同的项目,所以选择了nginx做反向代理 一个upstream tomcat_server对应一个 locatio ...
- ASP.NET Core 实战:使用 Docker 容器化部署 ASP.NET Core + MySQL + Nginx
一.前言 在之前的文章(ASP.NET Core 实战:Linux 小白的 .NET Core 部署之路)中,我介绍了如何在 Linux 环境中安装 .NET Core SDK / .NET Core ...
- 在 .NET Core项目中使用UEditor图片、文件上传服务
在.NET Framework中使用UEditor时,只需要将UEditor提供的后端服务,部署为一个子程序,即可直接使用文件上传相关的服务,但是UEditor官方并未提供.Net Core的项目,并 ...
- Asp.Net Core 使用Docker进行容器化部署(二)使用Nginx进行反向代理
上一篇介绍了Asp.Net 程序在Docker中的部署,这篇介绍使用Nginx对Docker的实例进行反向代理 一.修改Nginx配置文件 使用winscp链接Liunx服务器,在/ect/nginx ...
- docker部署Asp.Net Core、Nginx、MySQL
2019/10/24,docker19.03.4, .netcore 3.0,CentOS7.6 摘要:asp.net core 3.0 网站项目容器化部署,使用docker-compose编排Ngi ...
随机推荐
- windy数(数位dp)
https://www.luogu.com.cn/blog/virus2017/shuweidp https://www.luogu.com.cn/problem/P2657 #include < ...
- Eclipse开发Web项目连接MySQL时找不到驱动的解决办法
当我们使用Eclipse开发Web项目连接MySQL时后台报找不到驱动的错误,如下:解决办法: 1.这时我们首先要检查我们是否导入了连接MySQL数据库的jar包,如图,是否已经将jar包复制到项目下 ...
- Spring Boot+Socket实现与html页面的长连接,客户端给服务器端发消息,服务器给客户端轮询发送消息,附案例源码
功能介绍 客户端给所有在线用户发送消息 客户端给指定在线用户发送消息 服务器给客户端发送消息(轮询方式) 项目搭建 项目结构图 pom.xml <?xml version="1.0&q ...
- 在 Laravel 中通过自定义分页器分页方法实现伪静态分页链接以利于 SEO
我们知道,Laravel 自带的分页器方法包含 simplePaginate 和 paginate 方法,一个返回不带页码的分页链接,另一个返回带页码的分页链接,但是这两种分页链接页码都是以带问号的动 ...
- redis启动报错:The Windows version of Redis allocates a memory mapped heap for sharing with
windows系统下通过cmd命令:redis-server.exe redis.windows.conf 启动redis报错,控制台报错如下: The Windows version of Redi ...
- pandas巩固
导包 import pandas as pd 设置输出结果列对齐 pd.set_option('display.unicode.ambiguous_as_wide',True) pd.set_opti ...
- The JOIN operation -- SQLZOO
The JOIN operation 注意:where语句中对表示条件的需要用单引号, 下面的译文使用的是有道翻译如有不正确,请直接投诉有道 01.Modify it to show the matc ...
- P5979 [PA2014]Druzyny dp 分治 线段树 分类讨论 启发式合并
LINK:Druzyny 这题研究了一下午 终于搞懂了. \(n^2\)的dp很容易得到. 考虑优化.又有大于的限制又有小于的限制这个非常难处理. 不过可以得到在限制人数上界的情况下能转移到的最远端点 ...
- ABC 162 F Select Half dp 贪心
LINK:Select Half 考试的时候调了一个小时给调自闭了 原来是dp的姿势不太对. 首先 容易发现 奇数最多空2个位置 偶数最多空1一个位置 然后 设f[i][j][k]表示第i个数选了没有 ...
- Spring bean作用范围
1,singleton Spring ioc 容器中仅有一个 Bean 实例,Bean 以单例的方式存在:2,prototype 每次从容器中调用 Bean 时,都返回一个新的实例:3,request ...