TranslateProject/sources/tech/20180322 How To Find If A CPU Supports Virtualization Technology (VT).md

179 lines
7.4 KiB
Markdown
Raw Normal View History

2018-03-27 08:53:02 +08:00
translating---geekpi
How To Find If A CPU Supports Virtualization Technology (VT)
======
![](https://www.ostechnix.com/wp-content/uploads/2018/03/Virtualization-Technology-720x340.png)
We already knew how to [**check if your Linux OS is 32 bit or 64 bit**][1] and how to [**find if your Linux system is physical or virtual machine**][2]. Today, we are going to learn yet another useful topic how to find if a CPU supports virtualization technology (VT) or not? This should be first thing you might want to verify before installing virtualization applications such as VirtualBox or VMWare workstation to run virtual machines on your Linux system. Now let us go and find out if your computer supports VT or not. Trust me, it is really easy!
### Find If A CPU Supports Virtualization Technology (VT)
We can check if the CPU supports VT in several methods. Here I present you four methods.
#### Method 1: Using “egrep” command
**Egrep** is one of the variant of [**Grep**][3] command which is used to search text files with regular expressions. For the purpose of this guide, we are going to grep **/cpu/procinfo/** file to find out if the CPU supports VT or not.
To find out if your CPU supports VT using egrep command, run:
```
$ egrep "(svm|vmx)" /proc/cpuinfo
```
**Sample output:**
You will get either **“vmx”** (Intel-VT technology) or **“svm”** (AMD-V support) in the output.
```
flags : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe syscall nx rdtscp lm constant_tsc arch_perfmon pebs bts rep_good nopl xtopology nonstop_tsc cpuid aperfmperf pni pclmulqdq dtes64 monitor ds_cpl vmx est tm2 ssse3 cx16 xtpr pdcm pcid sse4_1 sse4_2 x2apic popcnt tsc_deadline_timer xsave avx lahf_lm epb pti tpr_shadow vnmi flexpriority ept vpid xsaveopt dtherm arat pln pts
[...]
```
Since the output is very long, you may find it hard to find the words “vmx” or “svm” in the output. No worries! You can distinguish those terms with colors like below.
```
$ egrep --color -i "svm|vmx" /proc/cpuinfo
```
![][5]
If you dont get any output, it means that your system doesnt support virtualization.
Please note that these CPU flags (vmx or svm) in the cpuinfo means that your system will support VT. In some CPU models, the VT support might be disabled in the BIOS, by default. In such cases, you should check your BIOS settings to enable VT support.
For more details about grep/egrep command, refer the man pages.
```
$ man grep
```
#### Method 2 Using “lscpu” command
The “lscpu” command is used to display the information about your CPU architecture. It gathers information from sysfs, /proc/cpuinfo file and displays the number of CPUs, threads, cores, sockets, and Non-Uniform Memory Access (NUMA) nodes of your host system.
To find out if the VT support is enabled or not, simply run:
```
$ lscpu
```
![][6]
For more details, check the man pages.
```
$ man lscpu
```
#### Method 3 Using “Cpu-checker” utility
**Cpu-checker** is yet another useful utility to test your CPU for virtualization support. As far as I searched on the web, this utility is available for only Ubuntu-based systems. To install it, run:
```
$ sudo apt-get install cpu-checker
```
Once cpu-checker package is installed, run the following command to check whether VT support is enable or not:
```
$ sudo kvm-ok
```
If your CPU supports VT, you will get the following output:
```
INFO: /dev/kvm exists
KVM acceleration can be used
```
If your CPU doesnt support VT, you will see an output something like below.
```
INFO: Your CPU does not support KVM extensions
KVM acceleration can NOT be used
```
#### Method 4 Using “virt-host-validate ” tool
This tool is specifically for RHEL based distros like CentOS and Scientific Linux. The **libvirt-client** package provides **virt-host-validate** binary. So you need to install “libvert-client” package to use this tool.
```
$ sudo yum install libvirt-client
```
Now, run “virt-host-validate” command to find if VT is enabled or not in your RHEL-based systems.
```
$ sudo virt-host-validate
```
If you get **pass** for all results, your system supports VT.
```
QEMU: Checking for hardware virtualization : PASS
QEMU: Checking if device /dev/vhost-net exists : PASS
QEMU: Checking if device /dev/net/tun exists : PASS
QEMU: Checking for cgroup 'memory' controller support : PASS
QEMU: Checking for cgroup 'memory' controller mount-point : PASS
QEMU: Checking for cgroup 'cpu' controller support : PASS
QEMU: Checking for cgroup 'cpu' controller mount-point : PASS
QEMU: Checking for cgroup 'cpuacct' controller support : PASS
QEMU: Checking for cgroup 'cpuacct' controller mount-point : PASS
QEMU: Checking for cgroup 'cpuset' controller support : PASS
QEMU: Checking for cgroup 'cpuset' controller mount-point : PASS
QEMU: Checking for cgroup 'devices' controller support : PASS
QEMU: Checking for cgroup 'devices' controller mount-point : PASS
QEMU: Checking for cgroup 'blkio' controller support : PASS
QEMU: Checking for cgroup 'blkio' controller mount-point : PASS
QEMU: Checking for device assignment IOMMU support : PASS
LXC: Checking for Linux >= 2.6.26 : PASS
LXC: Checking for namespace ipc : PASS
LXC: Checking for namespace mnt : PASS
LXC: Checking for namespace pid : PASS
LXC: Checking for namespace uts : PASS
LXC: Checking for namespace net : PASS
LXC: Checking for namespace user : PASS
LXC: Checking for cgroup 'memory' controller support : PASS
LXC: Checking for cgroup 'memory' controller mount-point : PASS
LXC: Checking for cgroup 'cpu' controller support : PASS
LXC: Checking for cgroup 'cpu' controller mount-point : PASS
LXC: Checking for cgroup 'cpuacct' controller support : PASS
LXC: Checking for cgroup 'cpuacct' controller mount-point : PASS
LXC: Checking for cgroup 'cpuset' controller support : PASS
LXC: Checking for cgroup 'cpuset' controller mount-point : PASS
LXC: Checking for cgroup 'devices' controller support : PASS
LXC: Checking for cgroup 'devices' controller mount-point : PASS
LXC: Checking for cgroup 'blkio' controller support : PASS
LXC: Checking for cgroup 'blkio' controller mount-point : PASS
```
If your system doesnt support VT, you will see an output like below.
```
QEMU: Checking for hardware virtualization : FAIL (Only emulated CPUs are available, performance will be significantly limited)
[...]
```
And, thats all for now folks. In this guide, we have discussed various methods to find if a CPU supports VT or not. As you can see, it was very easy. Hope this was useful. More good stuffs to come. Stay tuned!
Cheers!
--------------------------------------------------------------------------------
via: https://www.ostechnix.com/how-to-find-if-a-cpu-supports-virtualization-technology-vt/
作者:[SK][a]
译者:[译者ID](https://github.com/译者ID)
校对:[校对者ID](https://github.com/校对者ID)
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
[a]:https://www.ostechnix.com/author/sk/
[1]:https://www.ostechnix.com/check-linux-system-32-bit-64-bit/
[2]:https://www.ostechnix.com/check-linux-system-physical-virtual-machine/
[3]:https://www.ostechnix.com/the-grep-command-tutorial-with-examples-for-beginners/
[4]:
[5]:http://www.ostechnix.com/wp-content/uploads/2018/03/cpuinfo.png
[6]:http://www.ostechnix.com/wp-content/uploads/2018/03/cpuinfo-1-2.png