[发明专利]一种云程序设计方法有效
申请号: | 201210023266.9 | 申请日: | 2012-02-02 |
公开(公告)号: | CN102609257A | 公开(公告)日: | 2012-07-25 |
发明(设计)人: | 张桂刚;李超;张勇;邢春晓 | 申请(专利权)人: | 清华大学 |
主分类号: | G06F9/44 | 分类号: | G06F9/44;G06F9/45 |
代理公司: | 西安智大知识产权代理事务所 61215 | 代理人: | 贾玉健 |
地址: | 100084 北京市海淀区1*** | 国省代码: | 北京;11 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 程序设计 方法 | ||
技术领域
本发明属于云环境下的程序设计领域,特别涉及一种云程序设计方法。
背景技术
随着IT技术的发展,数字化社会每时每刻都在产生新的海量数据,并且生产模式发生了一些变化,越来越多的企业和其业务是以海量数据驱动,并且从中获益。很多应用的数据量都达到了TB级别甚至PB级别,如:Google已经在全球部署了100多万台服务器用来处理它庞大的数据量;FaceBook每天上载的照片均超过了1亿张以上,每天照片的浏览量超过150亿张以上,随着FaceBook最近的进入中国市场的步伐加快,其数据量将更加面临着一个直线的上升。2010年9月份图片共享网站Flickr所收录的上传图片数量超过了50亿张。Twitter在2010年4月14日地的统计情况是,每月搜索量达190亿次;在2010年7月6日地统计情况是,每月搜索量达240亿次;在2010年10月6日的统计情况是,每月搜索量达310亿次。至今,Twitter每天的搜索量达10亿次,平均每秒1.2万次。截至2010年12月底,谷歌每月搜索量达880亿次,雅虎每月搜索量为94亿次,必应每月搜索量为41亿次。所有的这些数据存储在不同的数据中心、集群和服务器中,这是一个非常复杂的异构环境。如何编写程序处理并分析这些存储在云环境下的海量的数据,将面临一个巨大的困难和挑战。
发明内容
为了克服上述现有技术的不足,本发明的目的在于提供一种云程序设计方法,可以实现让包括非专业程序员在内的大部分人都能够在云环境下编写程序,并通过程序获取自己所需要的云环境下的各种服务和资源,从而更好地服务于人类需求。
为了实现上述目的,本发明采用的技术方案是:
一种云程序设计方法,用户在编程接口上编写云程序,并将所编写的云程序送入到云程序编译器进行编译,并在编译过程中调用函数库的相应函数,被调用的函数向数据库发出数据需求请求,
在所述函数库中包含了原子函数f[a],f[b],f[c],……,f[k],f[m],f[n];
云程序调用的函数为F[1],F[2],……,F[Q]总共Q个函数,且按照F[1],F[2],……,F[Q]的先后顺序调用;
其中,F[1],F[2],……,F[Q]为原子函数或者组合函数。
所述函数库中包括Map函数、Reduce函数以及用户自定义函数UDF,所述云程序编译器能够调用上述三种函数。
所述云程序编译器进行编译之后,将结果返回到编程接口。
所述编程接口为PC机或者手机或者其它任何终端。
所述云程序是一种基于类自然语言的程序设计语言。
所述数据库为云文件系统或者云数据库。
所述云文件系统包含现有的分布式文件系统,如Google的GFS文件系统以及Hadoop的HDFS文件系统。
所述云数据库包括Google的BigTable数据库以及Hadoop的Hbase数据库。
所述组合函数是由一个以上的所述原子函数通过组合算法实现,所述组合算法为现有的BPEL的Web服务组合算法。
与现有技术相比,本发明提供一种云程序方法,可以实现让包括非专业程序员在内的大部分人都能够在云环境下编写程序,并通过程序获取自己所需要的云环境下的各种服务和资源,从而更好地服务于人类需求。
附图说明
图1为本发明一种云程序设计方法体系架构框图。
图2为本发明所述云编译器工作流程示例图。
具体实施方式
下面结合附图和实施例对本发明做进一步详细说明。
如图1所示,为本发明一种云程序设计方法体系架构框图,本实施例为所有能够在云环境下由包括非专业程序员在内的大部分人都能够在云环境下编写程序,并通过程序获取自己所需要的云环境下的各种服务和资源的一种云程序设计方法,共包括如下9个步骤:
(1)用户使用各种编程接口。这里的用户是指包含农民在内的各种非专业程序员,这里的编程接口是指普通PC机,手机及其他任何终端。
(2)用户在各种编程接口上编写云程序。
(3)将各种云程序送入到云程序编译器进行编译。云程序编译器的工作流程见图2。
(4)云程序编译器在编译过程中需要给函数库发出调用函数指令,该指定用于调用函数库里所需的各种Map函数、Reduce函数或者用户自定义函数UDF。
(5)云程序编译器根据不同的应用找到所需的各种Map函数、Reduce函数或者用户自定义函数UDF函数后,将函数返回给云程序编译器编译器。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于清华大学,未经清华大学许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201210023266.9/2.html,转载请声明来源钻瓜专利网。