当前位置: 首页 > news >正文

成都网站建设新线加电子工程网站

成都网站建设新线加,电子工程网站,长沙推广软件,网站建设 技术方案公司之前开发一个网盘系统, 可以上传文件, 打包压缩下载文件, 但是在处理大文件的时候, 服务器遇到了性能问题, 主要是这个项目是单机部署.......(离谱), 然后带宽只有100M, 现在用户比之前多很多, 然后所有人的压缩下载请求都给到这一台服务器了, 比如多个人下载的时候带宽问…

        公司之前开发一个网盘系统, 可以上传文件, 打包压缩下载文件, 但是在处理大文件的时候, 服务器遇到了性能问题, 主要是这个项目是单机部署.......(离谱),  然后带宽只有100M, 现在用户比之前多很多, 然后所有人的压缩下载请求都给到这一台服务器了, 比如多个人下载的时候带宽问题, 服务器内存占用问题, 下载速度和没开会员的百度云网盘有一拼, 用户苦不堪言,

        所以考虑到使用阿里的 serverless 函数计算, 把从OSS的下载和压缩, 以及压缩后的客户端对文件下载, 这些压力全给到 serverless

一.  使用的阿里云 serverless 函数计算 FC 

阿里云登录 - 欢迎登录阿里云,安全稳定的云计算服务平台

        使用之前我们需要开发一个传统的 springboot 项目,  代码没什么保密的东西, 都是抄的chatgpt, 项目地址 :   GitHub - canxiusi/zip-to-oos

        拉下来就可以直接运行的那种, 需要在配置文件里补全你的OSS信息

 1. 之后我们把项目打成jar包, 并压缩成zip

 2. 之后登录阿里云的 serverless, 再服务列表点击创建服务

3. 然后在自动弹出的页面中点击创建函数

4. 选择第二个, 使用springboot项目, 的zip压缩包上传

5.  这里一定要勾选 处理HTTP请求, 因为我们这是传统的 springboot 项目, 手白了就是 controller 层要接收上游系统的请求

 6. 运行环境选择 java8, 把项目的zip压缩上传上去, 启动命令就是 java -jar, 注意带上 jvm 的运行参数 

7. 高级配置这里直接把配置拉满, 市区选择北京/上海时间

8. 触发器这里选择支持的请求方式, 就是接口上 @PostMapping, @GetMapping 一类的, 签名根据自己的需要配置

9. 在函数详情页面点击测试函数, 这里就是请求 controller 我们定义的接口

10. 在触发器管理页面, 我们可以看到函数的外网请求地址, 这样我们就可以在其他项目调用接口了

11. 调用方系统请求serverless的部分代码

 因为这里要压缩的文件比较大, 所以在请求头这里设置了异步请求

        异步请求 serverless, 把OSS的文件路径和调用方系统回调地址作为参数

        后续就是等待 serverless 从OSS下载并压缩文件后, 通过http请求, 把 zip 文件在 serverless 的临时路径返回给调用方系统, 调用方系统进行入库处理, (这里没在内存做压缩, 因为文件过大会OOM)

        调用方系统通过客户端轮询请求, 查询临时文件路径存不存在, 在拿到临时文件的路径后, 再重定向到 serverless 直接下载文件

         下图的 controller 其实就是 serverless 在处理完 zip 文件后的回调地址, 逻辑就是把 serverless 的 zip 文件的路径入库

   

         下图的 downloadZipFile 就是前面的 serverless 的外网请求地址, 加上 serverless 部署的代码的 controller 层, 根据文件路径下载文件的接口路径

 

         重定向的下载路径就是这个样子了, 这样从OSS下载打包成压缩文件, 和后面的客户端下载压缩文件, 的压力都给到了 serverless

https://(这里是你的函数计算的外网请求地址, 后面是controller层的接口路径, 带上临时文件的路径) /zipServicePlatform/downloadZipFile?filePath=/tmp/c2090e89-a8fe-4f2d-b1fb-2ba185f44801730030168136097284.zip

        经过测试, serverless 的请求处理速度还是很快的, 因为和OSS对接有专网, (这个要注意 servereless 的地域要和 OSS 的地域一样)

        5个gb的零零散散的文件, 有很多文件路径,  逐个请求OSS下载, 再把文件流写入到磁盘临时文件, 然后返回给调用方系统临时文件的路径, 大概花费了4分多, 注意这里只是返回了在 serverless 的压缩包的临时文件路径, 后续要再次通过重定向到 serverless 的下载文件接口, 下载临时文件

http://www.15wanjia.com/news/180599.html

相关文章:

  • 做二手房的端口网站wordpress切换固定链接404
  • 注册号域名后 怎么建设网站成都建设网站哪家好
  • 在哪里买空间做网站郑州集团网站建设
  • 中国建设手机银行网站推广型网站建设模板
  • 在360怎么做网站群晖nas安装wordpress安装
  • 上海市住宅建设发展中心网站怎么做线上推广
  • 专门做ppt的网站斧头wordpress获取页面的当前位置
  • 企业设计网站公司哪家好用什么做网站更快捷方便
  • 比较好的微网站开发平台小程序代码大全
  • 怎么做网站一张图PS做网站页面尺寸
  • 网站可以做砍价软件吗做外贸网站卖什么东西好
  • 新手做网站做什么样的seo综合查询什么意思
  • 装修网站建设优缺点仿网站工具
  • 杭州设计企业网站高端公司wordpress怎么把图片存七牛
  • 如何进行公司网站的建设交网站建设域名计入什么科目
  • 单页网站设计欣赏快速做效果图的网站叫什么区别
  • 手机免费资源下载网站模板配置wordpress七牛
  • 网站开发与设计实训总结产品网上推广的方法有哪些
  • 做单页网站要多少钱优质的武进网站建设
  • 微网站定制logo设计公司怎么去跟客户谈
  • 关于网站开发专业的ppt30天网站建设 视频
  • 公司网站首页怎么制作wordpress下载管理器
  • 电话开发网站建设话术wordpress 模板 设置
  • 如何在手机上搭建网站公司邮箱格式
  • 做知识问答的网站网站页面做多宽
  • 大连网站的建设怎么优化WordPress主题
  • 厦门企业做网站电子商务网站费用预算
  • 用phython做网站新手搭建论坛己做网站
  • 承德信息网58上海自动seo
  • cod建站平台推销一个产品的方案