| 14 |
liveuser |
1 |
<?php
|
|
|
2 |
|
|
|
3 |
#宣告指派命名空間
|
|
|
4 |
namespace qbpwcf;
|
|
|
5 |
|
|
|
6 |
#匯入外部套件
|
|
|
7 |
include("../allInOne.php");
|
|
|
8 |
|
|
|
9 |
#說明正在測試的內容
|
|
|
10 |
echo"<hr>qemu::createSockFile - testCase 1<br>";
|
|
|
11 |
|
|
|
12 |
/*
|
|
|
13 |
|
|
|
14 |
#函數說明:
|
|
|
15 |
#建立供qemu使用的socket檔案.
|
|
|
16 |
#回傳結果:
|
|
|
17 |
#$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
|
|
|
18 |
#$result["error"],錯誤訊息.
|
|
|
19 |
#$result["function"],當前執行的函數名稱.
|
|
|
20 |
#$result["argu"],所使用的參數.
|
|
|
21 |
#$result["content"],socket檔案的位置與名稱.
|
|
|
22 |
#必填參數:
|
|
|
23 |
#無
|
|
|
24 |
#可省略參數:
|
|
|
25 |
#$conf["sockFolder"],字串,socket檔案要儲存在哪邊,預設為"/tmp/qbpwcf/qemu".
|
|
|
26 |
#$conf["sockFolder"]="/tmp/qbpwcf/qemu";
|
|
|
27 |
#$conf["sockFile"],字串,socket檔案的名稱,預設為"亂數產生的5位英數字.sock".
|
|
|
28 |
#$conf["sockFile"]="";
|
|
|
29 |
#$conf["plusSockFileName"],字串,針對亂數產生的socket檔案名稱,是否要增加一些內容,譬如:"[__name]-spice-sock",就代表要在自動產生的[__name]名稱後面加上"-spice-sock"字串.
|
|
|
30 |
#$conf["plusSockFileName"]="[__name]";
|
|
|
31 |
#$conf["fileArgu"],字串,php變數__FILE__的內容,亦即該檔案在檔案系統的絕對路徑
|
|
|
32 |
#$conf["fileArgu"]=__FILE__;
|
|
|
33 |
#備註:
|
|
|
34 |
#建構中...
|
|
|
35 |
$createSockFile=qemu::createSockFile();
|
|
|
36 |
unset($conf);
|
|
|
37 |
|
|
|
38 |
#如果確保sock檔案的路徑失敗
|
|
|
39 |
if($createSockFile["status"]==="false"){
|
|
|
40 |
|
|
|
41 |
#印出內容
|
|
|
42 |
var_dump($createSockFile);
|
|
|
43 |
|
|
|
44 |
}#if end
|
|
|
45 |
|
|
|
46 |
#印出內容
|
|
|
47 |
echo $createSockFile["content"];
|
|
|
48 |
|
|
|
49 |
*/
|
|
|
50 |
|
|
|
51 |
#說明正在測試的內容
|
|
|
52 |
echo"<hr>qemu::createSockFile - testCase 2<br>";
|
|
|
53 |
|
|
|
54 |
/*
|
|
|
55 |
|
|
|
56 |
#函數說明:
|
|
|
57 |
#建立供qemu使用的socket檔案.
|
|
|
58 |
#回傳結果:
|
|
|
59 |
#$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
|
|
|
60 |
#$result["error"],錯誤訊息.
|
|
|
61 |
#$result["function"],當前執行的函數名稱.
|
|
|
62 |
#$result["argu"],所使用的參數.
|
|
|
63 |
#$result["content"],socket檔案的位置與名稱.
|
|
|
64 |
#必填參數:
|
|
|
65 |
#無
|
|
|
66 |
#可省略參數:
|
|
|
67 |
#$conf["sockFolder"],字串,socket檔案要儲存在哪邊,預設為"/tmp/qbpwcf/qemu".
|
|
|
68 |
#$conf["sockFolder"]="/tmp/qbpwcf/qemu";
|
|
|
69 |
#$conf["sockFile"],字串,socket檔案的名稱,預設為"亂數產生的5位英數字.sock".
|
|
|
70 |
#$conf["sockFile"]="";
|
|
|
71 |
#$conf["plusSockFileName"],字串,針對亂數產生的socket檔案名稱,是否要增加一些內容,譬如:"[__name]-spice-sock",就代表要在自動產生的[__name]名稱後面加上"-spice-sock"字串.
|
|
|
72 |
$conf["plusSockFileName"]="qemu::createSockFile-[__name]-spice";
|
|
|
73 |
#$conf["fileArgu"],字串,php變數__FILE__的內容,亦即該檔案在檔案系統的絕對路徑
|
|
|
74 |
#$conf["fileArgu"]=__FILE__;
|
|
|
75 |
#備註:
|
|
|
76 |
#如果要在/tmp與/var/tmp底下建立socket檔案,若在apache環境下則會被作業系統特殊處理,即不等於實際上的路徑.
|
|
|
77 |
$createSockFile=qemu::createSockFile($conf);
|
|
|
78 |
unset($conf);
|
|
|
79 |
|
|
|
80 |
#如果確保sock檔案的路徑失敗
|
|
|
81 |
if($createSockFile["status"]==="false"){
|
|
|
82 |
|
|
|
83 |
#印出內容
|
|
|
84 |
var_dump($createSockFile);
|
|
|
85 |
|
|
|
86 |
}#if end
|
|
|
87 |
|
|
|
88 |
#印出內容
|
|
|
89 |
echo $createSockFile["content"];
|
|
|
90 |
|
|
|
91 |
*/
|
|
|
92 |
|
|
|
93 |
#說明正在測試的內容
|
|
|
94 |
echo"<hr>qemu::run - testCase 1<br>";
|
|
|
95 |
|
|
|
96 |
/*
|
|
|
97 |
|
|
|
98 |
#函式說明:
|
|
|
99 |
#在背景建立qemu虛擬機器
|
|
|
100 |
#回傳結果:
|
|
|
101 |
#$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
|
|
|
102 |
#$result["error"],錯誤訊息.
|
|
|
103 |
#$result["function"],當前執行的函數名稱.
|
|
|
104 |
#$result["argu"],所使用的參數.
|
|
|
105 |
#$result["cmd"],執行的command
|
|
|
106 |
#必填的參數:
|
|
|
107 |
#$conf["fileArgu"],字串,php變數__FILE__的內容,亦即該檔案在檔案系統的絕對路徑
|
|
|
108 |
$conf["fileArgu"]=__FILE__;
|
|
|
109 |
#可省的參數:
|
|
|
110 |
#$conf["architecture"],字串,所使用的處理器架構,可用的有"i386","x86_64"預設為"x86_64".
|
|
|
111 |
#$conf["architecture"]="x86_64";
|
|
|
112 |
#$conf["configFile"],字串,使用讀設定檔的方式來執行qemu,此為設定檔的路徑.
|
|
|
113 |
#$conf["configFile"]="";
|
|
|
114 |
#$conf["storage"],字串陣列,$conf["storage"][$i]代表第$i+1個虛擬硬碟位置與名稱.
|
|
|
115 |
#$conf["storage"]=array();
|
|
|
116 |
#$conf["storageType"],字串陣列,$conf["storageType"][$i]代表第$i+1個虛擬硬碟的類型,可以為ide,sata,scsi,virtio,sd或/dev/開頭的裝置.
|
|
|
117 |
#$conf["storageType"]=array();
|
|
|
118 |
#$conf["memory"],字串,可以使用的記憶體大小,以G為單位,預設為"2",亦即2GB的記憶體.
|
|
|
119 |
$conf["memory"]="1";
|
|
|
120 |
#$conf["vga"],字串,顯示卡類型,可用的有"cirrus","std","vmware","qxl","virtio"預設為"qxl".
|
|
|
121 |
#$conf["vga"]="qxl";
|
|
|
122 |
#$conf["soundhw"],字串,音效卡類型,可用的有"ac97","hda","all"預設為"all".
|
|
|
123 |
#$conf["soundhw"]="";
|
|
|
124 |
#$conf["kvm"],字串,是否使用kvm來加速虛擬機速度,"true"為啟用,"false"為不用kvm加速,預設為"true".
|
|
|
125 |
#$conf["kvm"]="true";
|
|
|
126 |
#$conf["machine"],字串,要用什麼樣的主機板,預設為"q35"(Q35 + ICH9, 2009),可用的還有傳統的"pc"(i440FX+PIIX,1996),知名的xen全虛擬化"xenfv",或半虛擬化"xenpv".
|
|
|
127 |
#$conf["machine"]="";
|
|
|
128 |
#$conf["spiceSock"],字串,是否要透過sock檔案的提供spice服務,此方法必須client端與server端都在同一台機器上,才能透spice協定進行連線,留空代表不使用,副檔名".sock"會自動補上.
|
|
|
129 |
$conf["spiceSock"]="/tmp/qbpwcf/testCase/qemu-run-t1";
|
|
|
130 |
#$conf["spicePort"],字串,要使用spice服務來遠端遙控的port,例如"5901",請與參數$conf["spiceSock"]擇一使用.
|
|
|
131 |
#$conf["spicePort"]="5901";
|
|
|
132 |
#$conf["spicePassword"],字串,要使用spice服務來遠端遙控時所需的密碼,預設為不設定.
|
|
|
133 |
$conf["spicePassword"]="1234567890";
|
|
|
134 |
#$conf["gl"],字串,是否要啟用opengl支援,可以讓spice可以擁有3D加速的功能,"true"為要使用,預設為"false"不啟用.
|
|
|
135 |
#$conf["gl"]="";
|
|
|
136 |
#$conf["userNet"][$i]["cardType"],字串,使用的網卡是什麼型號,預設為"virtio-net",可選的有e1000,e1000-82545em,ne2k_pci,rtl8139等...
|
|
|
137 |
#$conf["userNet"][$i]["cardType"]="";
|
|
|
138 |
#$conf["userNet"][$i]["mac"],字串,第$i+1個user網路類型的網卡mac.
|
|
|
139 |
#$conf["userNet"][$i]["mac"]="";
|
|
|
140 |
#$conf["userNet"][$i]["hostfwd"],二維字串陣列,第$i+1個user網路類型,指定到host::port的封包要轉到guest::port,例如array(array("8080","80"),array("8088","443")),就代表從8080port要進入host的封包會轉送到gust的80port,從8088port要進入host的封包會轉送到gust的443port.
|
|
|
141 |
#$conf["userNet"][$i]["hostfwd"]=array()
|
|
|
142 |
#$conf["bridgeNet"][$i]["cardType"],字串,使用的網卡是什麼型號,預設為"virtio",可選的有e1000,e1000-82545em,ne2k_pci,rtl8139等...
|
|
|
143 |
#$conf["bridgeNet"][$i]["mac"],字串,第$i+1個bridge網路類型的網卡mac.
|
|
|
144 |
#$conf["bridgeNet"][$i]["mac"]="";
|
|
|
145 |
#$conf["bridgeNet"][$i]["brName"],字串,第$i+1個bridge網路類型要接到哪個bridge.
|
|
|
146 |
#$conf["bridgeNet"][$i]["brName"]="";
|
|
|
147 |
#$conf["socketNet"][$i]["cardType"],字串,使用的網卡是什麼型號,預設為"virtio",可選的有e1000,e1000-82545em,ne2k_pci,rtl8139等...
|
|
|
148 |
#$conf["socketNet"][$i]["mac"],字串,第$i+1個socket網路類型的網卡mac.
|
|
|
149 |
#$conf["socketNet"][$i]["mac"]="";
|
|
|
150 |
#$conf["socketNet"][$i]["addr"],字串,第$i+1個socket網路類型的ip與port,預設為"230.0.0.1:1234".
|
|
|
151 |
#$conf["socketNet"][$i]["addr"]="";
|
|
|
152 |
#$conf["monitorLP"],字串,monitor要listen哪個port,預設為10000開始的port.
|
|
|
153 |
#$conf["monitorLP"]="";
|
|
|
154 |
#備註:
|
|
|
155 |
#伺服器須有安裝qemu套件.
|
|
|
156 |
$run=qemu::run($conf);
|
|
|
157 |
unset($conf);
|
|
|
158 |
|
|
|
159 |
#如果運行失敗
|
|
|
160 |
if($run["status"]==="false"){
|
|
|
161 |
|
|
|
162 |
#印出內容
|
|
|
163 |
var_dump($run);
|
|
|
164 |
|
|
|
165 |
#結束程式
|
|
|
166 |
exit;
|
|
|
167 |
|
|
|
168 |
}#if end
|
|
|
169 |
|
|
|
170 |
#印出內容
|
|
|
171 |
var_dump($run);
|
|
|
172 |
|
|
|
173 |
*/
|
|
|
174 |
|
|
|
175 |
#說明正在測試的內容
|
|
|
176 |
echo"<hr>qemu::spice - testCase 1<br>";
|
|
|
177 |
|
|
|
178 |
/*
|
|
|
179 |
|
|
|
180 |
#涵式說明:
|
|
|
181 |
#使用remote-viewer指令進行遠端
|
|
|
182 |
#回傳結果:
|
|
|
183 |
#$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
|
|
|
184 |
#$reuslt["error"],執行不正常結束的錯訊息陣列.
|
|
|
185 |
#$result["function"],當前執行的函式名稱.
|
|
|
186 |
#$result["argu"],所使用的參數.
|
|
|
187 |
#$result["cmd"],執行的指令.
|
|
|
188 |
#$result["config"],連線所用的config檔案內容.
|
|
|
189 |
#必填參數:
|
|
|
190 |
#$conf["type"],字串,"tcp"代表是用網路連線;"sock"代表是用unix socket進行連線,僅限於本機.
|
|
|
191 |
$conf["type"]="sock";
|
|
|
192 |
#$conf["addr"],字串,要連線到的位置,若$conf["type"]是tcp,則可以為IP位置或dns;若$conf["type"]是sock,則可以為socket檔案在本機上的位置.
|
|
|
193 |
$conf["addr"]="/tmp/qbpwcf/testCase/qemu-run-t1";
|
|
|
194 |
#$conf["fileArgu"],字串,__FILE__的內容.
|
|
|
195 |
$conf["fileArgu"]=__FILE__;
|
|
|
196 |
#可省略參數:
|
|
|
197 |
#$conf["username"],字串,要用什麼使用者來執行,預設為執行php的使用者,該參數不適用於apache環境.
|
|
|
198 |
#$conf["username"]="";
|
|
|
199 |
#$conf["password"],字串,與$conf["username"]搭配的使用者密碼,預設不使用密碼,該參數不適用於apache環境.
|
|
|
200 |
#$conf["password"]="";
|
|
|
201 |
#$conf["spicePassword"],字串,連線用的密碼,$conf["type"]為"sock"時不適用.
|
|
|
202 |
$conf["spicePassword"]="1234567890";
|
|
|
203 |
#$conf["port"],字串,$conf["addr"]為tcp時,連線用的port.
|
|
|
204 |
#$conf["port"]="";
|
|
|
205 |
#$conf["title"],字串,遠端視窗的標題要為什麼?預設為連線的位置.
|
|
|
206 |
$conf["title"]="qemu::spice - testCase 1";
|
|
|
207 |
#$conf["fullScreen"],字串,是否一連線就要全螢幕,"true"代表要,"false"代表不要,預設為"false".
|
|
|
208 |
$conf["fullScreen"]="true";
|
|
|
209 |
#備註:
|
|
|
210 |
#僅能在命列執行.
|
|
|
211 |
qemu::spice($conf);
|
|
|
212 |
unset($conf);
|
|
|
213 |
|
|
|
214 |
*/
|
|
|
215 |
|
|
|
216 |
/*
|
|
|
217 |
|
|
|
218 |
#說明正在測試的內容
|
|
|
219 |
echo"<hr>qemu::imgInfo - testCase 1<br>";
|
|
|
220 |
|
|
|
221 |
#涵式說明:
|
|
|
222 |
#取得虛擬硬碟的資訊與檢查是否被使用中
|
|
|
223 |
#回傳結果:
|
|
|
224 |
#$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
|
|
|
225 |
#$result["error"],錯誤訊息.
|
|
|
226 |
#$result["function"],當前執行的函數名稱.
|
|
|
227 |
#$result["argu"],所使用的參數.
|
|
|
228 |
#$result["used"],是否被使用中,"true"代表有;"false"代表沒有.
|
|
|
229 |
#必填參數:
|
|
|
230 |
#$conf["img"],字串,虛擬硬碟檔案的路徑與名稱.
|
|
|
231 |
$conf["img"]="qemuT/test.qcow2";
|
|
|
232 |
#$conf["fileArgu"],字串,php變數__FILE__的內容,亦即該檔案在檔案系統的絕對路徑
|
|
|
233 |
$conf["fileArgu"]=__FILE__;
|
|
|
234 |
$imgInfo=qemu::imgInfo($conf);
|
|
|
235 |
unset($conf);
|
|
|
236 |
|
|
|
237 |
#如果執行失敗
|
|
|
238 |
if($imgInfo["status"]==="false"){
|
|
|
239 |
|
|
|
240 |
#印出結果
|
|
|
241 |
var_dump($imgInfo);
|
|
|
242 |
|
|
|
243 |
#結束執行
|
|
|
244 |
exit;
|
|
|
245 |
|
|
|
246 |
}#if end
|
|
|
247 |
|
|
|
248 |
#印出結果
|
|
|
249 |
var_dump($imgInfo);
|
|
|
250 |
|
|
|
251 |
*/
|
|
|
252 |
|
|
|
253 |
|
|
|
254 |
/*
|
|
|
255 |
|
|
|
256 |
#說明正在測試的內容
|
|
|
257 |
echo"<hr>qemu::imgConvert - testCase 1<br>";
|
|
|
258 |
|
|
|
259 |
#涵式說明:
|
|
|
260 |
#尋找指定路徑下的虛擬硬碟,將之重新轉換與壓縮,再取掉代原有的檔案.
|
|
|
261 |
#回傳結果:
|
|
|
262 |
#$result["status"],執行是否正常,"true"代表正常,"false"代表不正常.
|
|
|
263 |
#$result["error"],錯誤訊息.
|
|
|
264 |
#$result["function"],當前執行的函數名稱.
|
|
|
265 |
#$result["argu"],所使用的參數.
|
|
|
266 |
#$result["found"],是否有找到可以轉換的檔案,"true"代表有;"false"代表沒有.
|
|
|
267 |
#$result["changed"],有改變的虛擬硬碟位置字串陣列.
|
|
|
268 |
#必填參數:
|
|
|
269 |
#$conf["path"],字串,虛擬硬碟檔案的搜尋路徑.
|
|
|
270 |
$conf["path"]="qemuT";
|
|
|
271 |
#$conf["fileArgu"],字串,php變數__FILE__的內容,亦即該檔案在檔案系統的絕對路徑
|
|
|
272 |
$conf["fileArgu"]=__FILE__;
|
|
|
273 |
#備註:
|
|
|
274 |
#目前只支援qcow2格式的虛擬硬碟
|
|
|
275 |
$imgConvert=qemu::imgConvert($conf);
|
|
|
276 |
unset($conf);
|
|
|
277 |
|
|
|
278 |
#運行失敗
|
|
|
279 |
if($imgConvert["status"]==="false"){
|
|
|
280 |
|
|
|
281 |
#印出結果
|
|
|
282 |
var_dump($imgConvert);
|
|
|
283 |
|
|
|
284 |
#結束運行
|
|
|
285 |
exit;
|
|
|
286 |
|
|
|
287 |
}#if end
|
|
|
288 |
|
|
|
289 |
#印出結果
|
|
|
290 |
var_dump($imgConvert);
|
|
|
291 |
|
|
|
292 |
*/
|
|
|
293 |
|
|
|
294 |
?>
|