V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
zzztongxue
V2EX  ›  问与答

vue 应用如何部署节省成本?这个月 cdn 花了 4K 有点烧不起了...

  •  
  •   zzztongxue · 2022-11-30 22:57:16 +08:00 · 4171 次点击
    这是一个创建于 752 天前的主题,其中的信息可能已经有所发展或是发生改变。

    目前手上有一个网页社区,经过 5 个月的发展目前百度统计的日 PV 是 80W+,UV 差不多 4W 左右...

    ilZqN.png

    上个月不知道被谁(目测是竞对),ddos 了几次。每次 ip 都进了阿里云黑洞, 没办饭只能给用到的域名都套上了 cdn 。然后流量费用就飞涨了,这个月全部费用加起来要 5K ,但是业务不赚钱,所以只能从成本上考虑节省。

    ilV2V.png

    项目采用前后端分离,前端 uni-app, 编译后包的大小 4.6m ,光前端图片资源就占了 3M+。

    现在考虑的是将静态资源部署到阿里云 oss, 但是不明白该如何部署。我现在前端所有请求都是请求到 a.xxx.com 这个域名,然后用 nginx 将 a.xxx.com/api 请求打到动态请求服务上。如果我上部署到 oss, 该如何解决跨域问题呢?(评论区有懂哥可以说说,不白嫖,采纳的会请喝咖啡)

    还有个 vue 的问题,就是用户前端访问的时候会直接把我 4.6M 的文件全部直接一次性下载吗?还是页面展示的时候发现没有这个资源才会去访问...(目前创业中,全干型切图仔,属于要用到啥就学啥,会的东西不够深入也不够扎实,求助万能的 V 友)

    56 条回复    2022-12-25 14:06:08 +08:00
    daiv
        1
    daiv  
       2022-11-30 23:12:32 +08:00   ❤️ 1
    F12 看一下请求, 不会一次性下载的. 按需的

    坐标在哪里, 什么方面的社区, 有没有可能合作
    cheese
        2
    cheese  
       2022-11-30 23:19:21 +08:00   ❤️ 1
    1.oss 流出流量并不比 cdn 便宜啊,你把静态资源放 oss 不解决你这个问题。关于跨域的问题,OSS 有 CORS 控制,可以自定义允许的跨域访问域名
    2.如果你的图片资源都在首页上,并且没有做懒加载,那就会一次性请求完成。图片考虑压缩,如果移动端用户少并且苹果用户更少的话,可以考虑 webP 格式
    3.vue 如果用了一些第三方的 UI 框架的话,使用按需引入的方式,可以缩减一些打包后的体积
    hefish
        3
    hefish  
       2022-11-30 23:21:24 +08:00   ❤️ 1
    oss 的流量费可贵了,比 cdn 贵多了。我用 oss 都是要套一层 cdn ,因为 oss 到 cdn 是免费的。
    oss 可以自定义域名。
    Aixiaoa
        4
    Aixiaoa  
       2022-11-30 23:27:27 +08:00 via iPhone   ❤️ 1
    找便宜 cdn 压缩图片 按需加载
    zzztongxue
        5
    zzztongxue  
    OP
       2022-11-30 23:29:20 +08:00
    @cheese 不好意思老哥,我没有描述清楚。
    1.为什么考虑放 oss 上,还有个原因是因为现在放在自己服务器上 nginx 处理比较吃内存,目前只是是 4H8G 的小机子,且跑了比较多的定时任务,用户反馈有时候访问前端界面比较卡,靠久不久重启一下 nginx 撑着。只是存在 oss 上,访问的话我还需要套 cdn 吧。
    2.就是一些页面缺省图片啊,图标资源啊... 经一楼的提醒刚才 F12 看了一下发现是按需的
    SQLException
        6
    SQLException  
       2022-11-30 23:30:10 +08:00   ❤️ 1
    我觉得你和 /t/877718 提供的服务很符合 @star7th 或许你俩有合作的可能
    zzztongxue
        7
    zzztongxue  
    OP
       2022-11-30 23:31:34 +08:00
    @SQLException 谢谢指路~!
    qhgongzi
        8
    qhgongzi  
       2022-11-30 23:32:24 +08:00 via Android   ❤️ 1
    Oss 更贵,先把静态资源压缩,精简,增加缓存时间,降低单用户的资源开销

    然后评估下是不是 cdn 按带宽计费会更便宜,如果之前没 cdn 走单服务器成本也不高的话,应该可以优化下来

    在杭州的话有机会的话可以找我当面看看,其他地方就找个资深点的前端分析优化下
    zzztongxue
        9
    zzztongxue  
    OP
       2022-11-30 23:32:47 +08:00
    @daiv 老哥是指技术合作吗还是?坐标倒是不限,都是远程工作
    zzztongxue
        10
    zzztongxue  
    OP
       2022-11-30 23:33:32 +08:00
    @qhgongzi 在厦门,感谢指点~!
    semoon
        11
    semoon  
       2022-11-30 23:47:36 +08:00   ❤️ 1
    看了楼主#5 的回复,按我经验,如果都在阿里云的话,可以试试如下几个操作:
    1 、新增 ecs 主机 1 台,剥离定时任务、跑后端 job
    2 、不清楚 op 具体多少流量,ecs 本身带宽使用情况,可以试试加入 slb ,走 ecs 的流量(弹性),能省比较多
    3 、拆分应用热点页面,图片压缩、懒加载组合拳搞一搞,静态 js 这些拆分减少打包体积

    可以交流交流~
    daiv
        12
    daiv  
       2022-11-30 23:48:37 +08:00
    @zzztongxue #9 我们很近... 商务 /技术 都可以, 聊了才知道有没有可能, 联系
    https://smms.app/image/uLTRJgtvqG8aspM
    可以加我
    vace
        13
    vace  
       2022-12-01 00:00:29 +08:00   ❤️ 1
    我的方案:前后端分离,前端部分是持续集成部署到 oss 的,可以通过配置静态网站托管获得单页应用的路由体验。再从 CDN 绑定域名访问,成本方面从几个方面优化:
    1. 预估访问量,买流量、https 请求数等资源包
    2. 优化前端项目,减少加载体积、加载数量、图片之类的懒加载
    3. 优化资源格式,渐进式缩略图、上面说的 png => webp ,gif => mp4 等等
    4. !!!用客户端缓存资源,我的项目使用 PWA ,用户第一次打开以后,所有资源都会从 ServiceWorker 中拿,更新发版时通过 ServiceWorker 更新资源,更新完后刷新一下页面。
    yestodayHadRain
        14
    yestodayHadRain  
       2022-12-01 00:00:51 +08:00 via iPhone   ❤️ 1
    楼主是觉得 CDN 走的流量不正常,在被人刷流量吗?

    OSS 的下行流量比 CDN 贵,但是可以把静态网站托管在 OSS 再给 OSS 套上 CDN ,OSS 可以设置跨域,不需要担心跨域的问题。

    楼上建议客户 CDN 按带宽计费的想法不太赞同,走带宽的话要看带宽平均使用率,小客户是不会去掉 top5 峰值计费的。另外走服务器带宽后按量付费也不合适,那个比 CDN 价格更贵。

    楼主如果是觉得有人盗刷 CDN 流量的话,可以设置下访问控制。
    yestodayHadRain
        15
    yestodayHadRain  
       2022-12-01 00:02:26 +08:00 via iPhone   ❤️ 1
    对了,CDN 应该支持 gzip 的,把这个加上流量也会少一些
    zzztongxue
        16
    zzztongxue  
    OP
       2022-12-01 00:03:49 +08:00
    @yestodayHadRain 我其实不是很懂阿里云的 DCDN 跟 CDN 区别是啥,我是直接前端直接放源站,然后域名套了 DCDN
    n18255447846
        17
    n18255447846  
       2022-12-01 00:09:05 +08:00   ❤️ 1
    你 cdn 下行流量涨了就得花钱,存 oss 里只是把你的资源从你自己的服务器上移到官方 oss 服务器上,而且还有存储费用。

    DDoS 攻击不知道,自己 google 解决吧。作为前端角度提建议:

    1. 减少请求数。合并资源精灵图,h2 等
    2. 按需 or 懒加载
    3. nginx 或者 cdn 里缓存时间设长点,减少流量,代价就是发布可能不及时
    4. gzip 必开,打包一份后记得 nginx 里开启 static
    5. 跨域其实很简单,加个请求头而已,但是不建议,因为浏览器会多发个 options 请求,还不如 nginx 反代一下。另外不是所有请求都需要处理跨域,像下载图片,加载 script 这些没有同源策略限制
    yestodayHadRain
        18
    yestodayHadRain  
       2022-12-01 00:09:45 +08:00 via iPhone
    @zzztongxue DCDN 是全站加速,相比 CDN 只能做静态资源的内容分发,DCDN 还可以加速接口的请求
    eason1874
        19
    eason1874  
       2022-12-01 00:12:45 +08:00   ❤️ 1
    @zzztongxue 你这一半以上是请求费用,现在立刻马上迁移到不收请求费而且流量便宜的百度智能云或者华为云(注意别开错 DCDN ,普通网页就 CDN 就可以了),啥都不用动就可以省 70%~80%

    静态 HTTPS 请求 0.05 元 /万次+动态 HTTPS 请求费用 0.15 元 /万次:12530*0.05+12078*0.15=2438.2
    eason1874
        20
    eason1874  
       2022-12-01 00:14:59 +08:00
    @yestodayHadRain #18 不是的,CDN 也支持动态请求,只不过不像 DCDN 那样专门优化过链路,CDN 有时候增加时延很明显,几十上百 ms ,但是对普通网页来说基本不影响,只对高时延要求的场景有影响
    zzztongxue
        21
    zzztongxue  
    OP
       2022-12-01 00:15:20 +08:00
    @vace 方案跟你想的差不多,现在执行落地有点疑问,CDN 绑定域名以后,之前的动态请求怎么处理。PWA 第一次听说,又学到了新的知识,感谢指点~
    zzztongxue
        22
    zzztongxue  
    OP
       2022-12-01 00:18:15 +08:00
    @eason1874 老哥留个 V 吗,请你喝一下红牛
    wdlth
        23
    wdlth  
       2022-12-01 00:27:28 +08:00
    先看看是否有大量的境外恶意流量,如果有境外的可以做分区解析把境外的换成 CF 之类的。
    eason1874
        24
    eason1874  
       2022-12-01 00:34:10 +08:00
    @zzztongxue 我不习惯加人,有使用问题在这里问就可以,我最近天天高强度刷 V 站。打赏请用我的微信赞赏码🤣 https://imgur.com/a/NwxFQPo
    zzztongxue
        25
    zzztongxue  
    OP
       2022-12-01 00:39:17 +08:00
    @eason1874 感谢恢复!红牛已安排。刚才看了一下各家的计费文档,动态加速都会收取 https 请求费用,百度会便宜一些,动态 https 是 0.1/万次。为什么套动态加速主要是隐藏一下源站 IP ,被 D 怕了...
    zzztongxue
        26
    zzztongxue  
    OP
       2022-12-01 00:41:28 +08:00
    @wdlth 明人不说暗话,我其实不懂怎么看境外流量 。😂
    eason1874
        27
    eason1874  
       2022-12-01 00:46:39 +08:00
    @zzztongxue 谢谢老哥的红牛

    百度智能云那个只收动态 HTTPS 请求费,你不开动态加速,就用普通加速也可以加速动态请求的,这样就没有请求费,就像我#20 说的那样,时延稍微高一点而已,但是对网页场景影响很小

    记得买流量包,在首页活动页进去,1T 流量包活动也就 106 元,日常得卖 180 元。我看你图表日均 50GB ,一个月也就 1.5TB 流量,跟我一个小网站差不多,我那个网站每月 CDN 成本也就 200 元以内
    zzztongxue
        28
    zzztongxue  
    OP
       2022-12-01 00:48:40 +08:00
    @eason1874 我比较愚钝,还是没太搞懂... 老哥说的是 api 动态请求也可以走普通加速的吗?我最重要目的是为了隐藏我的源站 IP
    eason1874
        29
    eason1874  
       2022-12-01 00:50:39 +08:00
    @zzztongxue 普通 CDN 也可以隐藏源站 IP 的,DCDN 只是在链路上有优化,其他方面跟 CDN 是一样的

    我比较推荐百度智能云,因为它不仅便宜,还支持边缘脚本,可以在 CDN 节点上运行简单的 JS 脚本,可以用来鉴权、动态限流
    zzztongxue
        30
    zzztongxue  
    OP
       2022-12-01 00:51:51 +08:00
    @eason1874 这就太好了!过两天试试看,成功优化后 会回来给老哥追加咖啡的☕️
    zeusho871
        31
    zeusho871  
       2022-12-01 01:07:11 +08:00 via Android
    试试我用的,创宇云
    vace
        32
    vace  
       2022-12-01 01:08:11 +08:00
    @zzztongxue OSS 上面只放静态资源,动态资源看业务类型走接口、回源、函数计算等都行。
    Victorcao
        33
    Victorcao  
       2022-12-01 08:28:34 +08:00 via Android
    现在黄网不挣钱?
    fzleee
        34
    fzleee  
       2022-12-01 08:48:11 +08:00 via iPhone
    楼主说的问题感觉要针对解决,泛泛而谈不能起到实质性的作用。有网站地址吗,说不定我可以帮忙看看
    ypzhou
        35
    ypzhou  
       2022-12-01 09:20:02 +08:00
    @eason1874 老哥 百度云和 qiniu 相比呢 ?
    jack274
        36
    jack274  
       2022-12-01 10:19:33 +08:00
    屏蔽一些 IP 访问过的,一般 IP 同时访问也就 20 个左右, 可以屏蔽比如同时请求超过 50 个的,因为这样的一般是机器或者用特别的爬虫软件
    perfectlife
        37
    perfectlife  
       2022-12-01 10:29:41 +08:00
    其实我感觉别人 ddos 攻击你,怎么都得花钱的
    zzztongxue
        38
    zzztongxue  
    OP
       2022-12-01 11:59:06 +08:00 via iPhone
    @zeusho871 打算先试试百度的
    star7th
        39
    star7th  
       2022-12-01 12:04:44 +08:00
    哎,有人推荐我了。嘿嘿。
    非常鼓励你使用大风云 https://www.dfyun.com.cn
    大风云不收回源费用,不收请求数费用,只收流量费,而且流量单价只有阿里云的四分之一。
    赶紧试用一下吧。这个现在申请,整个 12 月份都是免费试用期,不收你钱。
    tanglu
        40
    tanglu  
       2022-12-01 12:57:49 +08:00
    刚在隔壁看到京东云的不限流量 CDN
    [国内 CDN] 京东星盾 SCDN 招队友 400/月无限流量
    **loc.com/thread-1107964-1-1.html
    400/月 看着挺不错
    zzztongxue
        41
    zzztongxue  
    OP
       2022-12-01 13:21:35 +08:00
    @tanglu 不限量这个感觉有点慌跑路...
    zzztongxue
        42
    zzztongxue  
    OP
       2022-12-01 13:23:35 +08:00
    @star7th 昨天简单看了一下,好像需要用大风云提供的域名访问,我之前的图片资源在 oss 上且绑定了我设置的域名,可以不影响线上访问不停机切换到大风云不
    star7th
        43
    star7th  
       2022-12-01 13:33:38 +08:00
    @zzztongxue

    可以绑定你的域名的,不停机切换也行。
    你先走申请流程,源站地址选择域名,然后填入 oss 的公网域名。提交。通过申请后,会得到一个大风云的加速域名。同时网站管理后台会有绑定你自定义域名的教程。你按教程发 https 证书给我。我部署完毕后,你直接改 dns 解析,即可完美切换。
    tanglu
        44
    tanglu  
       2022-12-01 14:28:31 +08:00
    @zzztongxue 可以月付嘛,不限量是京东推出的,我觉得还是比较划算。之前他也卖过 暂时可能没有问题
    star7th
        45
    star7th  
       2022-12-01 14:42:19 +08:00
    @tanglu 咦,国内 cdn 里,我还真没看到京东星盾有 400 远包月的套餐。我看到的 https://docs.jdcloud.com/cn/starshield/price-overview 是 5800 元 /月。而且流量包 3T 居然要 900 元。
    如果你说的是国外 cdn ,那我不表态了。因为国外 cdn 在国内基本用不了。
    如果 lz 接入 https://www.dfyun.com.cn/ ,按 一个月 400 预算来计 ,则相当于可用 8T 流量。这个流量,对于小站点来讲,怎么折腾都够用了。而且 dfyun 还不会额外收取请求数费用。就只收流量费
    shenqi
        46
    shenqi  
       2022-12-01 15:33:41 +08:00
    试试将那些 external 包用第三方公开 cdn
    eason1874
        47
    eason1874  
       2022-12-01 16:54:32 +08:00   ❤️ 1
    @ypzhou #35 七牛云比百度智能云流量贵,功能少。我不推荐用,除非是企业用户,能拿到大额折扣
    tanglu
        48
    tanglu  
       2022-12-01 21:16:52 +08:00
    @star7th 我不了解 只是他标题写的不限流量,我也没用过 只是被标题吸引推个你,合不合适我没有发言权
    Zy143L
        49
    Zy143L  
       2022-12-02 03:05:55 +08:00 via Android
    图片不存在跨域问题 直接去嫖大厂 cdn 也不是不行
    zzztongxue
        50
    zzztongxue  
    OP
       2022-12-12 11:38:45 +08:00
    @star7th 前几天接入了百度云,百度云 0.2/g ,现在的 CDN 费用已经能接受了。观察一段时间,等日消耗再大些再找你开通,0.05/G 确实很香。。。
    star7th
        51
    star7th  
       2022-12-12 14:42:22 +08:00
    @zzztongxue 额, 白省下来的钱不香嘛,又不需要多少迁移成本,而且是一次接入工作,后续每个月都能省下馆子吃饭的钱。不过既然你觉得 0.2 元 /g 可接受就先接受吧。
    zzztongxue
        52
    zzztongxue  
    OP
       2022-12-24 23:14:16 +08:00 via iPhone
    @eason1874 感谢老哥,切到百度有半个月了,域名直接套普通 cdn ,符合预期,给你追加一杯咖啡☕
    zzztongxue
        53
    zzztongxue  
    OP
       2022-12-24 23:15:54 +08:00 via iPhone
    @zzztongxue 赞赏码失效了😂
    eason1874
        54
    eason1874  
       2022-12-25 13:53:04 +08:00
    @zzztongxue 来了,谢谢🤣 https://ibb.co/B6v5JW7
    zzztongxue
        55
    zzztongxue  
    OP
       2022-12-25 13:59:07 +08:00 via iPhone
    @eason1874 发了一个我的幸运数字
    eason1874
        56
    eason1874  
       2022-12-25 14:06:08 +08:00
    @zzztongxue 收到,谢谢,新年大家都好运!😁
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2831 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 27ms · UTC 11:49 · PVG 19:49 · LAX 03:49 · JFK 06:49
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.