CloudSim介紹和使用
本文主要介紹一下CloudSim,希望能對有需要的朋友們有所幫助~
2009年4月8日,澳大利亞墨爾本大學(xué)的網(wǎng)格實驗室和Gridbus項目宣布推出云計算仿真軟件,稱為CloudSim。它是在離散事件模擬包SimJava上開發(fā)的函數(shù)庫,可在Windows和Linux系統(tǒng)上跨平臺運行,CloudSim繼承了GridSim的編程模型,支持云計算的研究和開發(fā),并提供了以下新的特點: (1)支持大型云計算的基礎(chǔ)設(shè)施的建模與仿真;(2)一個自足的支持?jǐn)?shù)據(jù)中心、服務(wù)代理人、調(diào)度和分配策略的平臺。其中CloudSim 獨特功能有:一是提供虛擬化引擎,旨在數(shù)據(jù)中心節(jié)點上幫助建立和管理多重的、獨立的、協(xié)同的的虛擬化服務(wù);二是在對虛擬化服務(wù)分配處理核心時能夠在時間共享和空間共享之間靈活切換。CloudSim平臺有助于加快云計算的算法、方法和規(guī)范的發(fā)展。CloudSim的組件工具均為開源的。CloudSim的軟件結(jié)構(gòu)框架和體系結(jié)構(gòu)組件包括SimJava、GridSim、CloudSim、UserCode四個層次。
CloudSim是在GridSim模型基礎(chǔ)上發(fā)展而來,提供了云計算的特性,支持云計算的資源管理和調(diào)度模擬。云計算與網(wǎng)格計算的一個顯著區(qū)別是云計算采用了成熟的虛擬化技術(shù),將數(shù)據(jù)中心的資源虛擬化為資源池,打包對外向用戶提供服務(wù),CloudSim體現(xiàn)了此特點,擴(kuò)展部分實現(xiàn)了一系列接口,提供基于數(shù)據(jù)中心的虛擬化技術(shù)、虛擬化云的建模和仿真功能。通常,數(shù)據(jù)中心的一臺主機的資源可以根據(jù)用戶的需求映射到多臺虛擬機上,因此,虛擬機之間存在對主機資源的競爭關(guān)系。CloudSim提供了資源的監(jiān)測、主機到虛擬機的映射功能。CloudSim的CIS(Cloud Information Service)和DataCenterBroker實現(xiàn)資源發(fā)現(xiàn)和信息交互,是模擬調(diào)度的核心。用戶自行開發(fā)的調(diào)度算法可在DataCenterBroker的方法中實現(xiàn),從而實現(xiàn)調(diào)度算法的模擬。
依據(jù)CloudSim源代碼介紹幾個核心類:
(1)Cloudlet類:構(gòu)建云環(huán)境下的任務(wù)。
(2)DataCenter類:數(shù)據(jù)中心,提供虛擬化的網(wǎng)格資源,處理虛擬機信息的查詢,包含虛擬機對資源的分配策略,云計算采用VMProvisioner處理虛擬機。
(3)DataCenterBroker類:隱藏了虛擬機的管理,如創(chuàng)建、任務(wù)提交、虛擬機的銷毀等。
(4)Host類:擴(kuò)展了機器對虛擬機除處理單元(PE)之外的參數(shù)分配策略,如帶寬、存儲空間、內(nèi)存等,一臺Host可對應(yīng)多臺虛擬機。
(5)VirtualMachine類:虛擬機類,運行在Host上,與其它虛擬機共享資源,每臺虛擬機由一個擁有者所有,可提交任務(wù),并由VMScheduler類定制該虛擬機的調(diào)度策略。
(6)VMScheduler類:虛擬機的調(diào)度策略,用來管理執(zhí)行任務(wù),實現(xiàn)了任務(wù)接口。
(7)VMCharacteristics類:提供虛擬機描述。
(8)VMMAllocationPolicy類:虛擬機監(jiān)視器策略類,描述同一Host上的多臺虛擬機共享資源的策略。
(9)VMProvisioner類:實現(xiàn)數(shù)據(jù)中心的主機到虛擬機的映射。
2、CloudSim環(huán)境配置
(1)JDK安裝和配置
從http://java./ 下載JDK最新版本jdk1.6.0_13,CloudSim需要運行在JDK1.6版本以上。安裝下載的JDK,設(shè)置環(huán)境變量。在Path中加入路徑:C:\Program Files\Java\jdk1.6.0_13\bin; ClassPath中加入路徑:C:\Program Files\Java\jdk1.6.0_13\lib\dt.jar; C:\Program Files\Java\jdk1.6.0_13\lib\tools.jar; 。
(2)CloudSim配置
從http://www./cloudsim/ 下載CloudSim 1.0 beta版,下載的是一個Zip包,解壓壓縮包即可。設(shè)置環(huán)境變量,在ClassPath中加入路徑:C:\CLOUDSIM\jars\cloudsim.jar; C:\CLOUDSIM\jars\gridsim.jar; C:\CLOUDSIM\jars\simjava2.jar; 。
3、CloudSim的擴(kuò)展
CloudSim是開源的,可以在windows Xp和linux上運行,用戶可以根據(jù)自己的研究內(nèi)容自行擴(kuò)展CloudSim,加入自己的代碼后,需要重新編譯并發(fā)布平臺。下面給出編譯和生成平臺的方法:
從http://ant./ 下載Ant工具,解壓到目錄D:\apache-ant-1.7.1,設(shè)置環(huán)境變量,在PATH中加入:D:\apache-ant-1.7.1\bin;。將命令行切換到擴(kuò)展的CloudSim路徑(build.xml所在目錄),在命令行下鍵入命令D:\CloudSim>ant,批量編譯CloudSim源文件,生成的文件按照build.xml的設(shè)置存儲到指定位置,編譯成功后在命令行下鍵入D:\CloudSim>ant makejar命令打包生成new_cloudsim.jar。擴(kuò)展的CloudSim平臺生成成功。重設(shè)環(huán)境變量,在ClassPath中增加路徑:D:\CloudSim\jars\new_cloudsim.jar;D:\CloudSim\jars\cloudsim.jar;D:\CloudSim\jars\g-ridsim.jar; D:\CloudSim\jars\simjava2.jar;,下一步在新的平臺下編寫自己的仿真驗證程序。
4、使用CloudSim仿真的一般步驟
(1) 初始化GridSim 庫
GridSim.init(num_user, calendar, trace_flag, exclude_from_file,exclude_from_processing, report_name);
(2) 創(chuàng)建數(shù)據(jù)中心,在CloudSim仿真平臺中,一個數(shù)據(jù)中心由一個或多個Machine組成,一個Machine是由一個或多個PEs或CPUs組成。
DataCenter datacenter0 = createDatacenter("Datacenter_0");
(3) 創(chuàng)建代理Broker
DatacenterBroker broker = createBroker();
int brokerId = broker.get_id();
(4) 創(chuàng)建虛擬機
vmlist = new VirtualMachineList();
//創(chuàng)建時為虛擬機指定Broker
VirtualMachine vm1 = new VirtualMachine(
new VMCharacteristics(vmid,brokerId,size,memory,bw,vcpus,priority,vmm,
new TimeSharedVMScheduler()));
//將虛擬機加入虛擬機列表
vmlist.add(vm1);
//向相應(yīng)代理Broker提交虛擬機列表
broker.submitVMList(vmlist);
(5) 創(chuàng)建云任務(wù)
cloudletList = new CloudletList();
//創(chuàng)建時指定任務(wù)的用戶ID,BrokerID
Cloudlet cloudlet1 = new Cloudlet(id, length, file_size, output_size);
cloudlet1.setUserID(brokerId);
……
//將任務(wù)加入任務(wù)列表
cloudletList.add(cloudlet1);
……
//向代理Broker提交任務(wù)列表
broker.submitCloudletList(cloudletList);
(6) 啟動仿真
GridSim.startGridSimulation();
(7) 在仿真結(jié)束后統(tǒng)計結(jié)果
CloudletList newList = broker.getCloudletList();
GridSim.stopGridSimulation();
printCloudletList(newList);
datacenter0.printDebts();
若是根據(jù)自己研究對平臺進(jìn)行了擴(kuò)展,平臺重生成后,就可以在仿真程序中調(diào)用自己編寫的類、方法、成員變量等。
本文來自CSDN博客,轉(zhuǎn)載請標(biāo)明出處:http://blog.csdn.net/rolinzcy12/archive/2009/07/21/4367631.aspx