Nginx:通过nginx代理加载js文件很慢但直接访问很快的问题

本地部署一个vue的demo项目,用npm运行web服务的访问端口是8888

问题

直接在浏览器访问http://localhost:8888/,打开速度很快,在1s左右。

部署nginx,并做如下配置,用于前端web和后台服务保持在同一域名下。

    server {
        listen       9090;
        server_name  localhost;

        #charset koi8-r;
        #access_log  logs/host.access.log  main;
	location / {
        #前端地址
            proxy_pass http://localhost:8888/;
        }
	location /sys{
        #后台服务地址
            proxy_pass http://localhost:8088/sys/;
        }       
       }

浏览器访问http://localhost:9090/可以正常跳转到前端端口8888的地址页面,但加载时间很久超过30s。

查看控制台后发现是加载js文件非常慢,但其实每个js文件都很小,排除了文件大小和带宽问题。

解决

将proxy_pass后的地址 localhost替换为127.0.0.1,修改后配置如下

    server {
        listen       9090;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;
	location / {
        #前端地址
            proxy_pass http://127.0.0.1:8888/;
        }

	location /powersys {
        #后台服务地址
            proxy_pass http://127.0.0.1:8088/powersys/;
        }   
}

重启nginx服务后,再次访问http://localhost:9090/,用时1s左右,访问正常了。

 

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
是的,Nginx服务器可能导致JS文件加载慢的问题。以下是一些可能的原因: 1. 配置问题Nginx服务器的配置可能不正确,导致性能下降。例如,未正确配置缓存、压缩、连接池等参数,或者没有启用适当的优化模块。 2. 资源限制:如果Nginx服务器的硬件资源(如CPU、内存)有限,或者同时处理大量请求导致负载过高,可能会导致JS文件加载慢。 3. 带宽限制:如果Nginx服务器的网络带宽有限,或者与客户端之间的网络连接存在瓶颈,可能会导致JS文件下载速度变慢。 4. 静态文件处理:如果Nginx服务器未正确配置静态文件处理(如gzip压缩、缓存控制等),或者未启用适当的静态文件缓存机制,会导致JS文件加载速度变慢。 为了解决这些问题,你可以尝试以下方法: - 优化Nginx配置:检查Nginx服务器配置,确保启用了适当的优化选项和模块,并进行必要的调整。 - 资源扩展:增加Nginx服务器的硬件资源,如CPU、内存和网络带宽,以提高服务器的处理能力和响应速度。 - 静态文件缓存:配置适当的缓存头信息,启用静态文件缓存,减少对后端服务器的请求次数。 - 使用CDN:考虑使用CDN来加速静态文件的传输,通过将文件缓存在CDN节点上,使其离用户更近,提高加载速度。 请注意,具体的解决方法可能因环境和具体情况而有所不同。建议根据实际情况进行调整和优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

奋斗鱼

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值