大规模视频网站的计费与流量管理
本次分享将会就大规模视频网站的计费与流量管理这个话题,从操作层面细细进行讲解和分析,为系统工程师们揭示平日里我们没有关心的另一些内容。同时也希望本次分享能揭示行业中的一些“潜规则”,让互联网行业的流量与带宽管理更为开放与简洁。
本次演讲视频录制于QCon杭州2011。
该内容已经被标记书签!
标记书签错误,请重试!

作者 骆古道 发布于 2007年7月6日
本文内容是建立在下面的软件之上,这些软件分别是:
关于软件EL4Ant和GnuWin32的相关安装资料可以参照这里的技术资料[ 1 ]和[ 2 ]。为了我们说明问题简单起见,需要修改和设定下面的环境变量,其中方括号内容需要作相应的修改:
SET EL4ANT_HOME=[EL4Ant软件的安装目录]
SET ANT_HOME=%EL4ANT_HOME%\ant
SET NPP_HOME=[Notepad++的安装目录]
SET PATH=%PATH%;%ANT_HOME%\bin;%NPP_HOME%
为了使得EL4Ant系统可以利用Sun Java SDK 5.0版本,我们需要修改一下软件EL4Ant的样板工程的配置文件bootstrap.properties,该文件在系统终端中利用下面的命令或者其它文本编辑器被打开:
notepad++ %EL4ANT_HOME%\el4ant\project-template\etc\bootstrap.propertie
然后在该文件中找到内容“buildsystem.javac.source”,把其值改为如下所示:
buildsystem.javac.source=1.5
为了系统地阐述EL4Ant系统以及为今后集成HiveMind框架和Spring框架到EL4Ant系统等做好准备,本文的所有内容都是在一个称之为infoq_cn新工程下面,我们将在该工程下创建一个新的模块helloworld作为本文所有Eclipse项目的模块项目,简称模块。首先我们切换到EL4Ant系统的根目录,然后利用EL4Ant系统的工程模板project-template,创建一个我们自己的新工程 infoq_cn。在实际工作中,你可以按照工程的需要创建若干个这样的工程,工程名称也可以根据现实的需要进行命名。接下来为了创建一系列Eclipse项目,在工程目录infoq_cn下我们需要生成一个模块helloworld。这种模块名称也是自己定义的,并且可以产生任意多个这样的模块。以上内容在系统终端下可以利用如下操作命令被完成:
cd %EL4ANT_HOME%
cp -R el4ant\project-template infoq_cn
cd infoq_cn
mkdir helloworld
在这里我们将继续说明,在EL4Ant系统中如何创建一个基于Eclipse集成开发工具的简单Eclipse项目。一般而言,创建这样的一个Eclipse项目大致有三个步骤:产生Eclipse项目的相关目录;修改工程的工程配置文件project.xml;导入创建好的Eclipse项目到Eclipse集成开发环境。下面我们通过实例来说明这样方法。
因为我们在模块helloworld下可以创建很多相关的Eclipse项目,所以一般在实际软件开发中,把一些相关的Eclipse项目(比如该项目的测试Eclipse项目等)存放在某个目录(在一个模块目录下这样的目录,我们称之为Eclipse项目组目录) 下,以便许多Eclipse项目更好地和有序地被管理和控制。先确定自己的Eclipse项目组目录的和Eclipse项目目录。比如我们想把所有模板Eclipse项目在一起管理,就会把所有模板项目生成在目录helloworld/template下。而Eclipse项目的根目录是在 Eclipse项目组目录helloworld/template下的一个子目录basic。要想产生这样的一个Eclipse项目,其执行命令如下:
mkdir helloworld\template\basic
mkdir helloworld\template\basic\java
注意所有下面的命令都是在目录%EL4ANT_HOME%\infoq_cn下被执行。你还看到上面命令中创建了一个java目录,这是EL4Ant的Eclipse项目的Java源代码默认目录。而EL4Ant不用我们关心Eclipse项目的Java代码的编译目录和第三方软件包目录。接下来我们要告诉EL4Ant系统,我们的Eclipse项目在哪里、Eclipse项目的相互关系如何和Eclipse项目需要什么样第三方软件包等等。打开 El4Ant工程infoq_cn的最重要工程配置文件project.xml,其命令如下:
notepad++ project.xml
在你打开了该文件以后,我们把下面的代码加入到该文件的标记ant:project内。其中标记module的path是Eclipse项目的根目录;标记 module的name是你可以自己定义有意义的名称,要是不定义就是path内容,但是不包含path的“/”,比如module的属性path的值是 “helloworld/template/basic”,该module的属性name的值就是“helloworldtemplatebasic”;属性runtime.class的值是你即将创建的包括包名在内的Java类。属性runtime.runnable的值是true说明这个的类Main是可执行的。
<module path="helloworld/template/basic" name="template.basic">
<attribute name="runtime.runnable" value="true">
<attribute name="runtime.class" value="com.hhtong.helloworld.Main">
</module>
在该工程配置文件中,你还可以定义项目需要哪些软件包和哪些相关的Eclipse项目,这样可以十分明确了解所有Eclipse项目之间的相互关系。在把Eclipse项目导入到Eclipse开发工具之前,我们必须执行下面的命令,以达到创建一个Eclipse项目的相关配置文件。现在我们可以进入Eclipse集成开发工具。关于如何把EL4Ant的Eclipse项目导入到Eclipse开发工具方法请看这里[ 1 ]。
ant -f bootstrap.xml
在你导入了Eclipse项目template.basic之后,就可以进行该项目的代码开发和程序运行:
ant jars start.module.eu.helloworld.app
上面我们完成了从EL4Ant工程一直到该工程的Eclipse项目创建的整个过程。为了能够让你更为全面的理解它们之间的相互关系,这里给出了下面三个表。在【表一】中的所有目录都是在EL4Ant根目录下的子目录,这些目录可以分为两大类:一类是工具目录,另一类是EL4Ant工程目录。在我们的实例中,每个EL4Ant工程分别是【表二】的左右表格。【表三】是我们针对工程infoq_cn而给出的,其中Eclipse项目template/hivemind和hivemind/calculator是下一次需要说明的Eclipse项目。从这些表可以清晰地看到所有工程、模块和Eclipse项目的情况和相互关系,便于我们软件管理人员进行软件工程的管理和控制,也给我们软件开发人员对于整个工程有个完整的了解。
【表一】
【表二】

【表三】
下次我们有机会再探讨如何集成Google Guice框架到的EL4Ant系统中。
从软件开发的角度来看,软件工程的管理和控制实际上是如何把一个现实软件工程如何分割成若干个开发工具的项目比如Eclipse项目或者NetBeans项目。为了实现这一目标,EL4Ant系统给与了我们很好的基本架构。如何把不同的框架或者软件包集成在一起,并且有效地在一起工作(具体地说被一个Eclipse项目或者NetBeans项目所利用)是一个很复杂的工作。
Another Build System like Maven?
纠正文章中的两处错误:
1. 少了<attribute> XML Element的结束符
<module path="helloworld/template/basic" name="template.basic">
<attribute name="runtime.runnable" value="true"/>
<attribute name="runtime.class" value="com.hhtong.helloworld.Main"/>
<module></module>
2. 在系统下执行的命令应该为
ant jars start.module.eu.template.basic
用下来感觉可以作为中小型项目的软件构建工具,但因为其本身还是来源于Ant,所以还是具有Ant的缺点,仅仅是构建工具而不能通过项目模型来构建项目,还是依赖于大量的脚本来执行一个个target,可以看作是Ant向Maven过渡的产品,我称之为Ant的企业版。</attribute>
本次分享将会就大规模视频网站的计费与流量管理这个话题,从操作层面细细进行讲解和分析,为系统工程师们揭示平日里我们没有关心的另一些内容。同时也希望本次分享能揭示行业中的一些“潜规则”,让互联网行业的流量与带宽管理更为开放与简洁。
本次演讲视频录制于QCon杭州2011。
Jeffrey Richter以其多本Windows核心技术的经典著作而闻名,同时,他深入掌握微软的.NET等一系列核心技术,2012年1月,Jeffrey Richter在北京接受了InfoQ中文站的专访,谈到Windows 8和WinRT编程,并就异步编程、Windows编程中的可扩展性、性能和安全性方面给出自己的建议。
云计算平台的可用性,相比传统互联网服务而言,更加复杂和困难,也更具有挑战性。本文借助新浪SAE云平台为读者讲述了云平台可用性的定义、如何打造高可用的平台,以及对云计算的用户提出了建议。
淘宝高度重视Java平台的健康发展,组建了一个团队专注于Java平台的底层部分的性能、功能与稳定性改进;工作主要基于OpenJDK中的HotSpot VM开展,其中一些通用的功能随后也会逐渐反馈给OpenJDK社区。希望能与使用Java平台开发应用的大家交流经验。
本次演讲视频录制于QCon杭州2011。
2011年4月21日至22日是值得云计算从业者纪念的日子。Amazon的IaaS服务出现故障,导致许多商业网站的服务中断,影响非常严重。作为云计算用户,我们需要思考的是,如何保证即便在云服务不可用的情况,我们的应用架构仍然能够屹立不倒?本文正是站在云计算用户的角度试图探讨这一问题。
12人的技术团队,4组刀片服务器,每月20亿的访问量,每日1次准时部署,99.9%的可用性。这可能吗?当然。想知道如何做的吗?百姓网将与您分享他们在DevOps实践过程中的经验和技巧。
本次演讲视频录制于QCon杭州2011。
篱笆作为一家起源于社区的电子商务公司,反映到技术层面就是同时要面对产品和业务,以及经营战略的变化调整。如何在产品和业务的夹缝之间完成技术架构的抽象与平衡,寻找更有效的价值定位,这当中有些经验教训和个人感悟愿与众人分享。
本次演讲视频录制于QCon杭州2011。
本文将对特性注入以及相关方法做一个扫盲性的介绍。我们会解释这个框架的关键要素,并附上实例来证实它们。为了让文章保持相对较短,我们不会深入到某个工具或方法中,而是会给出一些参考资料,以便大家做进一步的研究。
2 条回复
关注此讨论 回复