热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

video上传架构设计与实现

video上传架构设计与实现项目需要做一个关于视频上传的功能。整体的流程就是用户通过页面上传视频,然后后台记录上传信息,转码,播放。其实就是和youku,tudou等ugc视频的功能类似的。可能存在的

video上传架构设计与实现

项目需要做一个关于视频上传的功能。整体的流程就是用户通过页面上传视频,然后后台记录上传信息,转码,播放。其实就是和youku,tudou等ugc视频的功能类似的。

可能存在的瓶颈及解决方法:

1.上传的网络瓶颈。(横向扩展,通过添加nginx即可)

2.后台处理的瓶颈,涉及到截图,调整文件位置等后续操作。返回给前端的消息及时性。(延时消息异步,先给前端返回,再进行后续的操作)

3.高并发。

系统架构:

                                                  lvs

                              nginx     nginx   nginx   nginx 

  web_server(tornado)   web_server(tornado)   web_server(tornado)   web_server(tornado)

                                          转码系统

架构如上图很简单,lvs后面挂的nginx。

使用nginx的upload module来进行上传功能。

nginx upstream到后端的server。

关于nginx配置如下:

        location /video/ {
            upload_pass @after_upload;
            upload_store /data1/video_temp;
            #upload_store_access user:rw;

            upload_set_form_field $upload_field_name.name         "$upload_file_name";
            upload_set_form_field $upload_field_name.content_type "$upload_content_type";
            upload_set_form_field $upload_field_name.path         "$upload_tmp_path";

            #Inform backend about hash and size of a file

            upload_aggregate_form_field $upload_field_name.md5          "$upload_file_md5";
            upload_aggregate_form_field $upload_field_name.size         "$upload_file_size";


            upload_pass_form_field "^.*(?!Filedata)$";
  
            #upload_pass_form_field "^.*$";      
            
            error_page 405 =200 @after_upload;
    
            #upload_cleanup 400 404 499 500-505;
        }


        location @after_upload {
            proxy_pass http://videoupload_backend;
        }

2.后端实现使用tornado,一个异步的非阻塞python webframe。

主ti的流程如下:

 1 class Transcode(tornado.web.RequestHandler):
 2     @tornado.web.asynchronous
 3     def post(self):
 4         #tempfile = self.get_argument("Filedata.size")
 5         #print "filedata.size is %s" %tempfile
 6         #getParameter = self.request.arguments
 7         #print "File data size is %s" %getParameter['Filedata.size'][0]
 8         #for (k,v) in getParameter.items():
 9         #    print "dict[%s]=%s" %(k,v)
10         #filename = getParameter['Filedata.name']
11         try:
12             logging.info('Begin ###############Get the Post info')
13             param = {
14                 'watermark':self.get_argument('watermark',default=''),
15                 'ugc':self.get_argument('ugc',default=''),
16                 'Filedata.path':self.get_argument('Filedata.path',default=''),
17                 'Filedata.name':self.get_argument('Filedata.name',default=''),
18                 'Filedata.content_type':self.get_argument('Filedata.content_type',default=''),
19                 'Filedata.md5':self.get_argument('Filedata.md5',default=''),
20                 'Filedata.size':self.get_argument('Filedata.size',default=''),
21                 'enctype':self.get_argument('enctype',default=''),      
22             }
23         except Exception, e:
24             logging.error("Error happens: %s" % str(e))
25             self.finish()
26             return 
27         
28         #pmovefile.doMoveFile(param['Filedata.path'],param,DEST_PATH,callback=self._on_success)
29         
30         movDesPath = pmovefile.doMoveFile(param['Filedata.path'],param,DEST_PATH)
31         
32         self.HandleSnapShotJPG(param,movDesPath,SNAPSHOT_PATH,succ_callback=self.my_on_sucess,fail_callback=self.my_on_fail)
33         

其中异步的操作都是放在返回给前端之前做的。代码太多,就不放上来了。

3.遇到的问题:上传的视频同步的问题。由于前端机器的负载分流,存在截图同步的问题。看youku的做法是直接暴露的ip在外面,应该是用随机用lvs后面的一个ip来进行上传。我们这里还是选择了个域名的方式,然后在后台的nginx之间做了同步。

对rsync的同步效率问题:大视频同步非常慢,是由于比对数据差异引起的,小的数据量很快。由于知道截图的图片地址,自己定义,故使用rsync增量同步的方式。

 
 
 
标签: 架构

当前标签: 架构

 
video上传架构设计与实现 浪迹天涯cc 2013-03-19 16:46 阅读:538 评论:1
推荐阅读
  • 解决nginx启动报错epoll_wait() reported that client prematurely closed connection的方法
    本文介绍了解决nginx启动报错epoll_wait() reported that client prematurely closed connection的方法,包括检查location配置是否正确、pass_proxy是否需要加“/”等。同时,还介绍了修改nginx的error.log日志级别为debug,以便查看详细日志信息。 ... [详细]
  • 个人学习使用:谨慎参考1Client类importcom.thoughtworks.gauge.Step;importcom.thoughtworks.gauge.T ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • ZSI.generate.Wsdl2PythonError: unsupported local simpleType restriction ... [详细]
  • http:my.oschina.netleejun2005blog136820刚看到群里又有同学在说HTTP协议下的Get请求参数长度是有大小限制的,最大不能超过XX ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • Python正则表达式学习记录及常用方法
    本文记录了学习Python正则表达式的过程,介绍了re模块的常用方法re.search,并解释了rawstring的作用。正则表达式是一种方便检查字符串匹配模式的工具,通过本文的学习可以掌握Python中使用正则表达式的基本方法。 ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
  • springmvc学习笔记(十):控制器业务方法中通过注解实现封装Javabean接收表单提交的数据
    本文介绍了在springmvc学习笔记系列的第十篇中,控制器的业务方法中如何通过注解实现封装Javabean来接收表单提交的数据。同时还讨论了当有多个注册表单且字段完全相同时,如何将其交给同一个控制器处理。 ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • 本文讨论了如何在codeigniter中识别来自angularjs的请求,并提供了两种方法的代码示例。作者尝试了$this->input->is_ajax_request()和自定义函数is_ajax(),但都没有成功。最后,作者展示了一个ajax请求的示例代码。 ... [详细]
  • Spring常用注解(绝对经典),全靠这份Java知识点PDF大全
    本文介绍了Spring常用注解和注入bean的注解,包括@Bean、@Autowired、@Inject等,同时提供了一个Java知识点PDF大全的资源链接。其中详细介绍了ColorFactoryBean的使用,以及@Autowired和@Inject的区别和用法。此外,还提到了@Required属性的配置和使用。 ... [详细]
author-avatar
柏慧Bertha
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有