Python腳本判斷 Linux 是否運(yùn)行在虛擬機(jī)上
在 WebHostingTalk 論壇上有些國外奸商會把虛擬機(jī)當(dāng)作獨(dú)立服務(wù)器賣,去年7月份的時候就有一位中國同胞上當(dāng)受騙,并在 WHT 上發(fā)帖聲討,證據(jù)確鑿,甚至連服務(wù)商自己也承認(rèn),回帖達(dá)355篇。這家獨(dú)立服務(wù)器/VPS 提供商 HostATree.com 居然大膽的把 OpenVZ VPS 這種一看就知道是虛擬機(jī)的虛擬機(jī)當(dāng)作獨(dú)立服務(wù)器賣,暈,至少也要弄個 VMWare/KVM/Xen HVM 吧(更難發(fā)現(xiàn)是虛擬機(jī)),用 OpenVZ 這種容器也太欺負(fù)人了:)昨天恰好收到網(wǎng)友一封郵件問到了如何判斷自己買的是獨(dú)立服務(wù)器還是虛擬機(jī)的問題。這里 VPSee 簡單介紹一下市面上常用虛擬技術(shù)(包括容器技術(shù))的判別小技巧。
判斷 OpenVZ/Xen PV/UML
判斷 OpenVZ/Xen PV/UML 是最容易的,直接檢查 /proc 下的相關(guān)目錄和文件就可以知道,比如 OpenVZ VPS 上會有 /proc/vz 這個文件;Xen PV 虛擬機(jī)上會有 /proc/xen/ 這個目錄,并且目錄下有一些東西;UML 上打印 /proc/cpuinfo 會找到 UML 標(biāo)志。寫了一個簡單的 Python 腳本來檢測:
#!/usr/bin/python
# check if a linux system running on a virtual machine (openvz/xen pv/uml)
import sys, os
def main():
if os.getuid() != 0:
print "must be run as root"
sys.exit(0)
# check OpenVZ/Virtuozzo
if os.path.exists("/proc/vz"):
if not os.path.exists("/proc/bc"):
print "openvz container"
else:
print "openvz node"
# check Xen
if os.path.exists("/proc/xen/capabilities"):
if (os.path.getsize("/proc/xen/capabilities") > 0):
print "xen dom0"
else:
print "xen domU"
# check User Mode Linux (UML)
f = open("/proc/cpuinfo", "r"); t = f.read(); f.close()
if (t.find("UML") > 0):
print "uml"
if __name__=="__main__":
main()
判斷 VMware/Xen HVM/KVM
如果使用的是 VMware/Xen HVM/KVM 這樣的全虛擬就更難判斷一些,最準(zhǔn)確的辦法是讀取 CPUID 來判斷,Xen 源代碼下面有一段檢測是否是 Xen 的 C 語言代碼 tools/misc/xen-detect.c,這段代碼提供了一個很好的例子,VPSee 重寫了代碼,用宏替代了函數(shù),增加了對 VMware 和 KVM 的識別,用 gcc 編譯后就可以運(yùn)行:
/*
* check if a linux system running on a virtual machine (vmware/xen hvm/kvm)
*/
#include stdio.h
#include string.h
#define HYPERVISOR_INFO 0x40000000
#define CPUID(idx, eax, ebx, ecx, edx) \
asm volatile ( \
"test %1,%1 ; jz 1f ; ud2a ; .ascii \"xen\" ; 1: cpuid" \
: "=b" (*ebx), "=a" (*eax), "=c" (*ecx), "=d" (*edx) \
: "0" (idx) );
int main(void)
{
unsigned int eax, ebx, ecx, edx;
char string[13];
CPUID(HYPERVISOR_INFO, &eax, &ebx, &ecx, &edx);
*(unsigned int *)(string+0) = ebx;
*(unsigned int *)(string+4) = ecx;
*(unsigned int *)(string+8) = edx;
string[12] = 0;
if (strncmp(string, "XenVMMXenVMM", 12) == 0) {
printf("xen hvm\n");
} else if (strncmp(string, "VMwareVMware", 12) == 0) {
printf("vmware\n");
} else if (strncmp(string, "KVMKVMKVM", 12) == 0) {
printf("kvm\n");
} else
printf("bare hardware\n");
return 0;
}
判斷 VirtualBox/Virtual PC
什么?這種家用桌面虛擬機(jī)自己裝的還會不知道?!如果不知道的話也有辦法,在 Linux 下運(yùn)行 dmidecode 工具然后查找 Manufacturer: innotek GmbH, Manufacturer: Microsoft Corporation 關(guān)鍵字就能對應(yīng)上 VirtualBox 和 Virtual PC.
- Windows下Pycharm遠(yuǎn)程連接虛擬機(jī)中Centos下的Python環(huán)境(圖文教程詳解)
- Python使用oslo.vmware管理ESXI虛擬機(jī)的示例參考
- python虛擬機(jī)解釋器及運(yùn)行過程
- Python動態(tài)規(guī)劃實(shí)現(xiàn)虛擬機(jī)部署的算法思想
- Python實(shí)現(xiàn)遺傳算法(虛擬機(jī)中運(yùn)行)
- 虛擬機(jī)下載python是否需要聯(lián)網(wǎng)
- 深入理解Python虛擬機(jī)中元組(tuple)的實(shí)現(xiàn)原理及源碼
- Python虛擬機(jī)棧幀對象及獲取源碼學(xué)習(xí)
- 深入理解?python?虛擬機(jī)
相關(guān)文章
pytorch tensor int型除法出現(xiàn)的問題
這篇文章主要介紹了pytorch tensor int型除法出現(xiàn)的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-04-04Python使用Keras庫中的LSTM模型生成新文本內(nèi)容教程
Python語言使用金庸小說文本庫,對文本進(jìn)行預(yù)處理,然后使用Keras庫中的LSTM模型創(chuàng)建和訓(xùn)練了模型,根據(jù)這個模型,我們可以生成新的文本,并探索小說的不同應(yīng)用2024-01-01Jupyter notebook如何實(shí)現(xiàn)指定瀏覽器打開
這篇文章主要介紹了Jupyter notebook如何實(shí)現(xiàn)指定瀏覽器打開,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-05-05Python光學(xué)仿真理解Jones矩陣學(xué)習(xí)
這篇文章主要為大家介紹了Python光學(xué)仿真理解Jones矩陣的學(xué)習(xí),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪2021-10-10詳解Python如何使用Netmiko進(jìn)行文件傳輸
Netmiko是一個用于連接和管理各種網(wǎng)絡(luò)設(shè)備的Python庫,它是Paramiko的一個擴(kuò)展。本文就來講講如何利用Netmiko實(shí)現(xiàn)文件傳輸功能吧2023-05-05Python高級應(yīng)用實(shí)例對比:高效計算大文件中的最長行的長度
在操作某個很多進(jìn)程都要頻繁用到的大文件的時候,應(yīng)該盡早釋放文件資源(f.close()),只有這樣才能算是一則高效率的代碼,下面我們就來分析下這3種方法的優(yōu)劣2014-06-06python中關(guān)于eval函數(shù)的使用及說明
這篇文章主要介紹了python中關(guān)于eval函數(shù)的使用及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05