mirror of
https://github.com/LCTT/TranslateProject.git
synced 2025-01-10 22:21:11 +08:00
333 lines
10 KiB
Markdown
333 lines
10 KiB
Markdown
Setup Headless Virtualization Server Using KVM In Ubuntu 18.04 LTS
|
||
======
|
||
|
||
![](https://www.ostechnix.com/wp-content/uploads/2016/11/kvm-720x340.jpg)
|
||
|
||
We already have covered [**setting up Oracle VirtualBox on Ubuntu 18.04**][1] headless server. In this tutorial, we will be discussing how to setup headless virtualization server using **KVM** and how to manage the guest machines from a remote client. As you may know already, KVM ( **K** ernel-based **v** irtual **m** achine) is an open source, full virtualization for Linux. Using KVM, we can easily turn any Linux server in to a complete virtualization environment in minutes and deploy different kind of VMs such as GNU/Linux, *BSD, Windows etc.
|
||
|
||
### Setup Headless Virtualization Server Using KVM
|
||
|
||
I tested this guide on Ubuntu 18.04 LTS server, however this tutorial will work on other Linux distributions such as Debian, CentOS, RHEL and Scientific Linux. This method will be perfectly suitable for those who wants to setup a simple virtualization environment in a Linux server that doesn’t have any graphical environment.
|
||
|
||
For the purpose of this guide, I will be using two systems.
|
||
|
||
**KVM virtualization server:**
|
||
|
||
* **Host OS** – Ubuntu 18.04 LTS minimal server (No GUI)
|
||
* **IP Address of Host OS** : 192.168.225.22/24
|
||
* **Guest OS** (Which we are going to host on Ubuntu 18.04) : Ubuntu 16.04 LTS server
|
||
|
||
|
||
|
||
**Remote desktop client :**
|
||
|
||
* **OS** – Arch Linux
|
||
|
||
|
||
|
||
### Install KVM
|
||
|
||
First, let us check if our system supports hardware virtualization. To do so, run the following command from the Terminal:
|
||
```
|
||
$ egrep -c '(vmx|svm)' /proc/cpuinfo
|
||
|
||
```
|
||
|
||
If the result is **zero (0)** , the system doesn’t support hardware virtualization or the virtualization is disabled in the Bios. Go to your bios and check for the virtualization option and enable it.
|
||
|
||
if the result is **1** or **more** , the system will support hardware virtualization. However, you still need to enable the virtualization option in Bios before running the above commands.
|
||
|
||
Alternatively, you can use the following command to verify it. You need to install kvm first as described below, in order to use this command.
|
||
```
|
||
$ kvm-ok
|
||
|
||
```
|
||
|
||
**Sample output:**
|
||
```
|
||
INFO: /dev/kvm exists
|
||
KVM acceleration can be used
|
||
|
||
```
|
||
|
||
If you got the following error instead, you still can run guest machines in KVM, but the performance will be very poor.
|
||
```
|
||
INFO: Your CPU does not support KVM extensions
|
||
INFO: For more detailed results, you should run this as root
|
||
HINT: sudo /usr/sbin/kvm-ok
|
||
|
||
```
|
||
|
||
Also, there are other ways to find out if your CPU supports Virtualization or not. Refer the following guide for more details.
|
||
|
||
Next, Install KVM and other required packages to setup a virtualization environment in Linux.
|
||
|
||
On Ubuntu and other DEB based systems, run:
|
||
```
|
||
$ sudo apt-get install qemu-kvm libvirt-bin virtinst bridge-utils cpu-checker
|
||
|
||
```
|
||
|
||
Once KVM installed, start libvertd service (If it is not started already):
|
||
```
|
||
$ sudo systemctl enable libvirtd
|
||
|
||
$ sudo systemctl start libvirtd
|
||
|
||
```
|
||
|
||
### Create Virtual machines
|
||
|
||
All virtual machine files and other related files will be stored under **/var/lib/libvirt/**. The default path of ISO images is **/var/lib/libvirt/boot/**.
|
||
|
||
First, let us see if there is any virtual machines. To view the list of available virtual machines, run:
|
||
```
|
||
$ sudo virsh list --all
|
||
|
||
```
|
||
|
||
**Sample output:**
|
||
```
|
||
Id Name State
|
||
----------------------------------------------------
|
||
|
||
```
|
||
|
||
![][3]
|
||
|
||
As you see above, there is no virtual machine available right now.
|
||
|
||
Now, let us crate one.
|
||
|
||
For example, let us create Ubuntu 16.04 Virtual machine with 512 MB RAM, 1 CPU core, 8 GB Hdd.
|
||
```
|
||
$ sudo virt-install --name Ubuntu-16.04 --ram=512 --vcpus=1 --cpu host --hvm --disk path=/var/lib/libvirt/images/ubuntu-16.04-vm1,size=8 --cdrom /var/lib/libvirt/boot/ubuntu-16.04-server-amd64.iso --graphics vnc
|
||
|
||
```
|
||
|
||
Please make sure you have Ubuntu 16.04 ISO image in path **/var/lib/libvirt/boot/** or any other path you have given in the above command.
|
||
|
||
**Sample output:**
|
||
```
|
||
WARNING Graphics requested but DISPLAY is not set. Not running virt-viewer.
|
||
WARNING No console to launch for the guest, defaulting to --wait -1
|
||
|
||
Starting install...
|
||
Creating domain... | 0 B 00:00:01
|
||
Domain installation still in progress. Waiting for installation to complete.
|
||
Domain has shutdown. Continuing.
|
||
Domain creation completed.
|
||
Restarting guest.
|
||
|
||
```
|
||
|
||
![][4]
|
||
|
||
Let us break down the above command and see what each option do.
|
||
|
||
* **–name** : This option defines the name of the virtual name. In our case, the name of VM is **Ubuntu-16.04**.
|
||
* **–ram=512** : Allocates 512MB RAM to the VM.
|
||
* **–vcpus=1** : Indicates the number of CPU cores in the VM.
|
||
* **–cpu host** : Optimizes the CPU properties for the VM by exposing the host’s CPU’s configuration to the guest.
|
||
* **–hvm** : Request the full hardware virtualization.
|
||
* **–disk path** : The location to save VM’s hdd and it’s size. In our example, I have allocated 8GB hdd size.
|
||
* **–cdrom** : The location of installer ISO image. Please note that you must have the actual ISO image in this location.
|
||
* **–graphics vnc** : Allows VNC access to the VM from a remote client.
|
||
|
||
|
||
|
||
### Access Virtual machines using VNC client
|
||
|
||
Now, go to the remote Desktop system. SSH to the Ubuntu server(Virtualization server) as shown below.
|
||
|
||
Here, **sk** is my Ubuntu server’s user name and **192.168.225.22** is its IP address.
|
||
|
||
Run the following command to find out the VNC port number. We need this to access the Vm from a remote system.
|
||
```
|
||
$ sudo virsh dumpxml Ubuntu-16.04 | grep vnc
|
||
|
||
```
|
||
|
||
**Sample output:**
|
||
```
|
||
<graphics type='vnc' port='5900' autoport='yes' listen='127.0.0.1'>
|
||
|
||
```
|
||
|
||
![][5]
|
||
|
||
Note down the port number **5900**. Install any VNC client application. For this guide, I will be using TigerVnc. TigerVNC is available in the Arch Linux default repositories. To install it on Arch based systems, run:
|
||
```
|
||
$ sudo pacman -S tigervnc
|
||
|
||
```
|
||
|
||
Type the following SSH port forwarding command from your remote client system that has VNC client application installed.
|
||
|
||
Again, **192.168.225.22** is my Ubuntu server’s (virtualization server) IP address.
|
||
|
||
Then, open the VNC client from your Arch Linux (client).
|
||
|
||
Type **localhost:5900** in the VNC server field and click **Connect** button.
|
||
|
||
![][6]
|
||
|
||
Then start installing the Ubuntu VM as the way you do in the physical system.
|
||
|
||
![][7]
|
||
|
||
![][8]
|
||
|
||
Similarly, you can setup as many as virtual machines depending upon server hardware specifications.
|
||
|
||
Alternatively, you can use **virt-viewer** utility in order to install operating system in the guest machines. virt-viewer is available in the most Linux distribution’s default repositories. After installing virt-viewer, run the following command to establish VNC access to the VM.
|
||
```
|
||
$ sudo virt-viewer --connect=qemu+ssh://192.168.225.22/system --name Ubuntu-16.04
|
||
|
||
```
|
||
|
||
### Manage virtual machines
|
||
|
||
Managing VMs from the command-line using virsh management user interface is very interesting and fun. The commands are very easy to remember. Let us see some examples.
|
||
|
||
To view the list of running VMs, run:
|
||
```
|
||
$ sudo virsh list
|
||
|
||
```
|
||
|
||
Or,
|
||
```
|
||
$ sudo virsh list --all
|
||
|
||
```
|
||
|
||
**Sample output:**
|
||
```
|
||
Id Name State
|
||
----------------------------------------------------
|
||
2 Ubuntu-16.04 running
|
||
|
||
```
|
||
|
||
![][9]
|
||
|
||
To start a VM, run:
|
||
```
|
||
$ sudo virsh start Ubuntu-16.04
|
||
|
||
```
|
||
|
||
Alternatively, you can use the VM id to start it.
|
||
|
||
![][10]
|
||
|
||
As you see in the above output, Ubuntu 16.04 virtual machine’s Id is 2. So, in order to start it, just specify its Id like below.
|
||
```
|
||
$ sudo virsh start 2
|
||
|
||
```
|
||
|
||
To restart a VM, run:
|
||
```
|
||
$ sudo virsh reboot Ubuntu-16.04
|
||
|
||
```
|
||
|
||
**Sample output:**
|
||
```
|
||
Domain Ubuntu-16.04 is being rebooted
|
||
|
||
```
|
||
|
||
![][11]
|
||
|
||
To pause a running VM, run:
|
||
```
|
||
$ sudo virsh suspend Ubuntu-16.04
|
||
|
||
```
|
||
|
||
**Sample output:**
|
||
```
|
||
Domain Ubuntu-16.04 suspended
|
||
|
||
```
|
||
|
||
To resume the suspended VM, run:
|
||
```
|
||
$ sudo virsh resume Ubuntu-16.04
|
||
|
||
```
|
||
|
||
**Sample output:**
|
||
```
|
||
Domain Ubuntu-16.04 resumed
|
||
|
||
```
|
||
|
||
To shutdown a VM, run:
|
||
```
|
||
$ sudo virsh shutdown Ubuntu-16.04
|
||
|
||
```
|
||
|
||
**Sample output:**
|
||
```
|
||
Domain Ubuntu-16.04 is being shutdown
|
||
|
||
```
|
||
|
||
To completely remove a VM, run:
|
||
```
|
||
$ sudo virsh undefine Ubuntu-16.04
|
||
|
||
$ sudo virsh destroy Ubuntu-16.04
|
||
|
||
```
|
||
|
||
**Sample output:**
|
||
```
|
||
Domain Ubuntu-16.04 destroyed
|
||
|
||
```
|
||
|
||
![][12]
|
||
|
||
For more options, I recommend you to look into the man pages.
|
||
```
|
||
$ man virsh
|
||
|
||
```
|
||
|
||
That’s all for now folks. Start playing with your new virtualization environment. KVM virtualization will be opt for research & development and testing purposes, but not limited to. If you have sufficient hardware, you can use it for large production environments. Have fun and don’t forget to leave your valuable comments in the comment section below.
|
||
|
||
Cheers!
|
||
|
||
|
||
|
||
--------------------------------------------------------------------------------
|
||
|
||
via: https://www.ostechnix.com/setup-headless-virtualization-server-using-kvm-ubuntu/
|
||
|
||
作者:[SK][a]
|
||
选题:[lujun9972](https://github.com/lujun9972)
|
||
译者:[译者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/install-oracle-virtualbox-ubuntu-16-04-headless-server/
|
||
[2]:
|
||
[3]:http://www.ostechnix.com/wp-content/uploads/2016/11/sk@ubuntuserver-_001.png
|
||
[4]:http://www.ostechnix.com/wp-content/uploads/2016/11/sk@ubuntuserver-_008-1.png
|
||
[5]:http://www.ostechnix.com/wp-content/uploads/2016/11/sk@ubuntuserver-_002.png
|
||
[6]:http://www.ostechnix.com/wp-content/uploads/2016/11/VNC-Viewer-Connection-Details_005.png
|
||
[7]:http://www.ostechnix.com/wp-content/uploads/2016/11/QEMU-Ubuntu-16.04-TigerVNC_006.png
|
||
[8]:http://www.ostechnix.com/wp-content/uploads/2016/11/QEMU-Ubuntu-16.04-TigerVNC_007.png
|
||
[9]:http://www.ostechnix.com/wp-content/uploads/2016/11/sk@ubuntuserver-_010-1.png
|
||
[10]:http://www.ostechnix.com/wp-content/uploads/2016/11/sk@ubuntuserver-_010-2.png
|
||
[11]:http://www.ostechnix.com/wp-content/uploads/2016/11/sk@ubuntuserver-_011-1.png
|
||
[12]:http://www.ostechnix.com/wp-content/uploads/2016/11/sk@ubuntuserver-_012.png
|