mirror of
https://github.com/LCTT/TranslateProject.git
synced 2025-01-13 22:30:37 +08:00
d4d5cf4556
sources/tech/20210119 Set up a Linux cloud on bare metal.md
129 lines
5.0 KiB
Markdown
129 lines
5.0 KiB
Markdown
[#]: collector: (lujun9972)
|
||
[#]: translator: ( )
|
||
[#]: reviewer: ( )
|
||
[#]: publisher: ( )
|
||
[#]: url: ( )
|
||
[#]: subject: (Set up a Linux cloud on bare metal)
|
||
[#]: via: (https://opensource.com/article/21/1/cloud-image-virt-install)
|
||
[#]: author: (Sumantro Mukherjee https://opensource.com/users/sumantro)
|
||
|
||
Set up a Linux cloud on bare metal
|
||
======
|
||
Create cloud images with virt-install on Fedora.
|
||
![Sky with clouds and grass][1]
|
||
|
||
Virtualization is one of the most used technologies. Fedora Linux uses [Cloud Base images][2] to create general-purpose virtual machines (VM), but there are many ways to set up Cloud Base images. Recently, the virt-install command-line tool for provisioning VMs added support for **cloud-init**, so it can now be used to configure and run a cloud image locally.
|
||
|
||
This article walks through how to set up a base Fedora cloud instance on bare metal. The same steps can be used with any raw or Qcow2 Cloud Base image.
|
||
|
||
### What is --cloud-init?
|
||
|
||
The **virt-install** command creates a KVM, Xen, or [LXC][3] guest using **libvirt**. The `--cloud-init` option uses a local file (called a **nocloud datasource**) so you don't need a network connection to create an image. The **nocloud** method derives user data and metadata for the guest from an iso9660 filesystem (an `.iso` file) during the first boot. When you use this option, **virt-install** generates a random (and temporary) password for the root user account, provides a serial console so you can log in and change your password, and then disables the `--cloud-init` option for subsequent boots.
|
||
|
||
### Set up a Fedora Cloud Base image
|
||
|
||
First, [download a Fedora Cloud Base (for OpenStack) image][2].
|
||
|
||
![Fedora Cloud website screenshot][4]
|
||
|
||
(Sumantro Mukherjee, [CC BY-SA 4.0][5])
|
||
|
||
Then install the **virt-install** command:
|
||
|
||
|
||
```
|
||
`$ sudo dnf install virt-install`
|
||
```
|
||
|
||
Once **virt-install** is installed and the Fedora Cloud Base image is downloaded, create a small YAML file named `cloudinit-user-data.yaml` to contain a few configuration lines that virt-install will use.
|
||
|
||
|
||
```
|
||
#cloud-config
|
||
password: 'r00t'
|
||
chpasswd: { expire: false }
|
||
```
|
||
|
||
This simple cloud-config sets the password for the default **fedora** user. If you want to use a password that expires, you can set it to expire after logging in.
|
||
|
||
Create and boot the VM:
|
||
|
||
|
||
```
|
||
$ virt-install --name local-cloud18012709 \
|
||
\--memory 2000 --noreboot \
|
||
\--os-variant detect=on,name=fedora-unknown \
|
||
\--cloud-init user-data="/home/r3zr/cloudinit-user-data.yaml" \
|
||
\--disk=size=10,backing_store="/home/r3zr/Downloads/Fedora-Cloud-Base-33-1.2.x86_64.qcow2"
|
||
```
|
||
|
||
In this example, `local-cloud18012709` is the name of the virtual machine, RAM is set to 2000MiB, disk size (the virtual hard drive) is set to 10GB, and `--cloud-init` and `backing_store` contain the absolute path to the YAML config file you created and the Qcow2 image you downloaded.
|
||
|
||
### Log in
|
||
|
||
After the image is created, you can log in with the username **fedora** and the password set in the YAML file (in my example, this is **r00t**, but you may have used something different). Change your password once you've logged in for the first time.
|
||
|
||
To power off your virtual machine, execute the `sudo poweroff` command, or press **Ctrl**+**]** on your keyboard.
|
||
|
||
### Start, stop, and kill VMs
|
||
|
||
The `virsh` command is used to start, stop, and kill VMs.
|
||
|
||
To start any VM that is running:
|
||
|
||
|
||
```
|
||
`$ virsh start <vm-name>`
|
||
```
|
||
|
||
To stop any running VM:
|
||
|
||
|
||
```
|
||
`$ virsh shutdown <vm-name>`
|
||
```
|
||
|
||
To list all VMs that are in a running state:
|
||
|
||
|
||
```
|
||
`$ virsh list`
|
||
```
|
||
|
||
To destroy the VMs:
|
||
|
||
|
||
```
|
||
`$ virsh destroy <vm-name>`
|
||
```
|
||
|
||
![Destroying a VM][6]
|
||
|
||
(Sumantro Mukherjee, [CC BY-SA 4.0][5])
|
||
|
||
### Fast and easy
|
||
|
||
The **virt-install** command combined with the `--cloud-init` option makes it fast and easy to create cloud-ready images without worrying about whether you have a cloud to run them on yet. Whether you're preparing for a a major deployment or just learning about containers, give `virt-install --cloud-init` a try.
|
||
|
||
Do you have a favourite tool for your work in the cloud? Tell us about them in the comments.
|
||
|
||
--------------------------------------------------------------------------------
|
||
|
||
via: https://opensource.com/article/21/1/cloud-image-virt-install
|
||
|
||
作者:[Sumantro Mukherjee][a]
|
||
选题:[lujun9972][b]
|
||
译者:[译者ID](https://github.com/译者ID)
|
||
校对:[校对者ID](https://github.com/校对者ID)
|
||
|
||
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
|
||
|
||
[a]: https://opensource.com/users/sumantro
|
||
[b]: https://github.com/lujun9972
|
||
[1]: https://opensource.com/sites/default/files/styles/image-full-size/public/lead-images/bus-cloud.png?itok=vz0PIDDS (Sky with clouds and grass)
|
||
[2]: https://alt.fedoraproject.org/cloud/
|
||
[3]: https://www.redhat.com/sysadmin/exploring-containers-lxc
|
||
[4]: https://opensource.com/sites/default/files/uploads/fedoracloud.png (Fedora Cloud website)
|
||
[5]: https://creativecommons.org/licenses/by-sa/4.0/
|
||
[6]: https://opensource.com/sites/default/files/uploads/destroyvm.png (Destroying a VM)
|