03--KVM虚拟化

前言:这里开始涉及到云计算内容,虚拟化使云计算发展,云计算推动虚拟化进步,两者相辅相成,这一章总结一下kvm虚拟化的解决方案。

1、基础概念

1.1、云计算

以前要完成信息处理, 是需要在一个客观存在的计算机上完成的, 它看得见摸得到。后来随着计算机硬件、网络技术、存储技术的飞速发展, 计算机硬件性能过剩, 因为足够高的性能在大部分时间是被浪费掉的, 并没有参与客观运算; 那如果将资源集中起来, 计算任务去共享、复用集中起来的资源, 将是对资源的极大节省和效率的极大提升; 这就是云计算产生的背景, 它就是将庞大的计算资源集中在某个地方或是某些地方, 而不再是放在身边的计算机了, 用户的每一次计算, 都发生在远端的云计算机房内。

云计算的服务类型:

  • SaaS(软件即服务):通过云端提供完整的应用程序,用户通过网页浏览器等方式访问,如微信客户端。
  • PaaS(平台即服务):云服务提供商提供给客户开发、运维应用程序的运行环境, 用户负责维护自己的应用程序, 但并不掌控操作系统、硬件以及运作的网络基础架构。如aliyun的RDS-MySQL、RDS-Redis等。
  • IaaS(基础设施即服务):提供基础的计算资源,如虚拟机、存储空间等,用户可以自由配置和管理,如aliyun的ECS、腾讯的CMS。

1.2、虚拟化

虚拟化是一种资源管理技术, 它将计算机的各种实体资源予以抽象和转化, 并提供分割、重新组合, 以达到最大化利用物理资源的目的; 广义上来说, 我们一直以来对物理硬盘所做的逻辑分区、以及后来的LVM, 都可以纳入虚拟化的范畴; 在没有虚拟化之前, 一个物理主机上面只能运行一个操作系统及其之上的一系列运行环境和应用程序, 有了虚拟化技术, 一个物理主机可以被抽象、分割成多个虚拟的逻辑意义上的主机, 向上支撑多个操作系统及其之上的运行环境和应用程序, 则其资源就可以被最大化的利用

半虚拟化:
  纯软件的虚拟化可以做到第一个目标, 但性能不是很好, 而且软件设计的复杂度大大增加。
  那么如果放弃第一个目标呢?让客户机意识到自己是运行在虚拟化环境里, 并做相应修改以配合VMM, 这就是半虚拟化(Para-Virtualization)。一方面, 可以提升性能和简化VMM软件复杂度;另一方面, 也不需要太依赖硬件虚拟化的支持, 从而使得其软件设计(至少是VMM这一侧)可以跨平台且是优雅的。“本质上, 准虚拟化弱化了对虚拟机特殊指令的被动截获要求, 将其转化成客户机操作系统的主动通知。但是, 准虚拟化需要修改客户机操作系统的源代码来实现主动通知。”典型的半虚拟化技术就是virtio, 使用virtio需要在宿主机/VMM和客户机里都相应地装上驱动。
全虚拟化:
  与半虚拟化相反的, 全虚拟化(Full Virtualization)坚持第一个理想化目标:客户机的操作系统完全不需要改动。敏感指令在操作系统和硬件之间被VMM捕捉处理, 客户操作系统无须修改, 所有软件都能在虚拟机中运行。因此, 全虚拟化需要模拟出完整的、和物理平台一模一样的平台给客户机, 这在达到了第一个目标的同时也增加了虚拟化层(VMM)的复杂度。
  性能上, 2005年硬件虚拟化兴起之前, 软件实现的全虚拟化完败于VMM和客户机操作系统协同运作的半虚拟化, 这种情况一直延续到2006年。之后以Intel VT-x、VT-d为代表的硬件虚拟化技术的兴起, 让由硬件虚拟化辅助的全虚拟化全面超过了半虚拟化。但是, 以virtio为代表的半虚拟化技术也一直在演进发展, 性能上只是略逊于全虚拟化, 加之其较少的平台依赖性, 依然受到广泛的欢迎。

1.3、kvm

KVM全称为Kernel-based Virtual Machine,是一种基于内核的虚拟机解决方案,利用硬件虚拟化技术实现全虚拟化。

每个KVM客户机对应于宿主机上的一个Linux进程,其中每个虚拟CPU(vCPU)是该进程的一个线程,并有一个专门处理IO的线程,它们组成一个线程组。因此,宿主机像调度普通进程一样调度这些客户机,可以通过Linux的进程调度机制实现不同客户机的权限限制和优先级设置。

客户机看到的硬件设备是由QEMU模拟的(不包括透传的VT-d设备)。当客户机操作模拟设备时,QEMU会截获并将其转换为对实际物理设备(即使这些设备可能不存在或者只是虚拟化的实体)的驱动操作。

2、KVM虚拟机创建

由于KVM已经是kernel源代码的一部分, 所以不需要另外安装, 主要是安装QEMU 虚拟化工具,基础环境配置如下

将安装所需要的库克隆到安装主机
$ git clone https://gitee.com/mirschao/kvmvirtual.git
$ bash kvmvirtual/installer/deploy.sh

KVM中支持三种网络模式, 分别为NAT模式、bridge桥接模式、host-only仅主机模式; NAT模式通常用来在个人虚拟化桌面中应用广泛, 桥接模式在服务器端虚拟化使用广泛, host-only一般在超级大的服务厂商内部网络使用

2.1、NAT模式

查看主机中是否有虚拟机

[root@localhost ~]# virsh list --allId    名称                         状态
----------------------------------------------------[root@localhost ~]# 

创建虚拟磁盘

虚拟磁盘格式有raw(类似ssd,一次性占用设定大小,速度较快数据库服务应用较多)和qcow2(类似机械硬盘,根据需要逐渐扩大,支持虚拟机克隆,虚拟机磁盘快照。扩容)

[root@localhost ~]# qemu-img create -f raw /kvm/vdisks/test-nat-network.raw 20G
Formatting '/kvm/vdisks/test-nat-network.raw', fmt=raw size=21474836480

创建虚拟机

提前将iso文件上传到文件夹/kvm/isos下

[root@localhost ~]# virt-install --name=test-nat-network \
> --vcpus=2 --memory=2048 --disk=/kvm/vdisks/test-nat-network.raw \
> --cdrom=/kvm/isos/CentOS-7.6-x86_64-DVD-1810.iso --os-variant=rhel7 \
> --noautoconsole --autostart \
> --graphics vnc,listen=0.0.0.0,port=5901开始安装......
域安装仍在进行。您可以重新连接
到控制台以便完成安装进程。
[root@localhost ~]# ###以下为注释virt-install:这是用于创建和安装虚拟机的命令行工具。--name=test-nat-network:指定虚拟机的名称为 test-nat-network。--vcpus=2:指定虚拟机的虚拟CPU数量为 2 个。--memory=2048:指定虚拟机的内存大小为 2048 MB(即 2 GB)。--disk=/kvm/vdisks/test-nat-network.raw:指定虚拟机的磁盘配置,/kvm/vdisks/test-nat-network.raw 表示虚拟机的磁盘镜像文件路径和名称。--cdrom=/kvm/isos/CentOS-7.6-x86_64-DVD-1810.iso:指定虚拟机的光盘镜像(ISO文件),用于安装操作系统。在这里使用的是 CentOS 7.6 的 ISO 文件路径。--os-variant=rhel7:指定操作系统类型--noautoconsole:不自动连接到虚拟机的控制台。这意味着虚拟机创建后,不会自动打开控制台窗口。--autostart:设置虚拟机在宿主机启动时自动启动。--graphics vnc,listen=0.0.0.0,port=5901:配置虚拟机的图形显示方式为 VNC,并指定以下参数:listen=0.0.0.0: 允许从任意地址连接 VNC。port=5901: VNC 监听的端口号为 5901。这意味着你可以通过 VNC 客户端连接到宿主机的 5901 端口来访问虚拟机的图形界面。

此时使用vnc连接宿主机5901端口

正常安装系统,根据实际情况需求(是否订阅redhat)把kdump关掉或者开启,这个设置很占内存。然后进入网络设置,开启网卡,查看自动获取的ip与宿主机的nat网卡virbr0是否符合

 后续开始正常安装系统

2.2、桥接模式

首先需要在宿主机创建一个桥接网卡

[root@localhost ~]# vim /etc/sysconfig/network-scripts/ifcfg-br0
[root@localhost ~]# cat /etc/sysconfig/network-scripts/ifcfg-br0
DEVICE="br0"
NAME="br0"
BOOTPROTO="static"
ONBOOT="yes"
TYPE="Bridge"
IPADDR="192.168.188.188"
GATEWAY="192.168.188.2"
NETMASK="255.255.255.0"
DNS1="114.114.114.114"
DEFROUTE="yes"

将宿主机原先网卡ens33也桥接到br0上,br0透过ens33上网

[root@localhost ~]# cp /etc/sysconfig/network-scripts/{ifcfg-ens33,ifcfg-ens33.bak}
[root@localhost ~]# vim /etc/sysconfig/network-scripts/ifcfg-ens33
[root@localhost ~]# cat /etc/sysconfig/network-scripts/ifcfg-ens33
DEVICE="ens33"
NAME="ens33"
BOOTPROTO="none"
NM_CONTROLLED="no"
ONBOOT="yes"
TYPE="Ethernet"
BRIDGE="br0"
DEFROUTE="yes"
IPV4_FAILURE_FATAL="yes"

重启网络

[root@localhost ~]# systemctl restart network

创建虚拟机

[root@localhost ~]#  qemu-img create -f raw /kvm/vdisks/template.raw 20G
Formatting '/kvm/vdisks/template.raw', fmt=raw size=21474836480 
[root@localhost ~]# virt-install --name=template \
> --vcpus=2 --memory=2048 --disk=/kvm/vdisks/template.raw \
> --cdrom=/kvm/isos/CentOS-7.6-x86_64-DVD-1810.iso --os-variant=rhel7 \
> --noautoconsole --autostart \
> --network bridge=br0 \
> --graphics vnc,listen=0.0.0.0,port=5900开始安装......
域安装仍在进行。您可以重新连接
到控制台以便完成安装进程。

这里配置一下静态ip(方便后续实验)

 后续操作同上

2.3、KVM虚拟机快速创建

#    查看虚拟机状态
[root@localhost ~]# virsh list --allId    名称                         状态
----------------------------------------------------1     test-nat-network               running2     template                       running#查看虚拟磁盘文件
[root@localhost ~]# ll /kvm/vdisks/
总用量 2784244
-rw-r--r-- 1 qemu qemu 21474836480 7月  23 14:11 template.qcow2
-rw-r--r-- 1 qemu qemu 21474836480 7月  23 14:11 test-nat-network.raw#查看虚拟机硬件配置文件
[root@localhost ~]# ll /etc/libvirt/qemu
总用量 16
drwxr-xr-x 2 root root   54 7月  23 00:07 autostart
drwx------ 3 root root   42 7月  22 22:11 networks
-rw------- 1 root root 4228 7月  23 00:07 template.xml
-rw------- 1 root root 4258 7月  22 22:57 test-nat-network.xml

根据下面步骤将演示nat虚拟机删除,删除方式如下

[root@localhost ~]# virsh list --allId    名称                         状态
----------------------------------------------------1     test-nat-network               running2     template                       running[root@localhost ~]# virsh shutdown test-nat-network
域 test-nat-network 被关闭
[root@localhost ~]# virsh undefine test-nat-network
域 test-nat-network 已经被取消定义
[root@localhost ~]# rm -rf /kvm/vdisks/test-nat-network.raw [root@localhost ~]# virsh list --allId    名称                         状态
----------------------------------------------------2     template                       running[root@localhost ~]# ll /kvm/vdisks/
总用量 1394064
-rw-r--r-- 1 qemu qemu 21474836480 7月  23 14:32 template.raw
[root@localhost ~]# ll /etc/libvirt/qemu
总用量 8
drwxr-xr-x 2 root root   26 7月  23 14:29 autostart
drwx------ 3 root root   42 7月  22 22:11 networks
-rw------- 1 root root 4228 7月  23 00:07 template.xml

一台主机对应虚拟硬件配置和虚拟磁盘两个文件,想要快速创建一台虚拟机就是拷贝这两个文件到对应主机位置实现,但是由于系统内唯一标识符存在无法直接使用常规手段拷贝,需要借助qemu实现,具体操作如下

[root@localhost ~]# qemu-img create -f qcow2 -b /kvm/vdisks/template.raw /kvm/vdisks/test-quickly.qcow2
Formatting '/kvm/vdisks/test-quickly.qcow2', fmt=qcow2 size=21474836480 backing_file='/kvm/vdisks/template.raw' encryption=off cluster_size=65536 lazy_refcounts=off

磁盘创建成功后如何修改虚拟磁盘文件,以ip举例把虚拟磁盘挂载到中间目录上,然后进入中间目录修改(这里修改前面配置的静态ip作为示例,uuid具有唯一性且会自动生成,直接删除即可),操作如下

[root@localhost ~]# guestmount -a /kvm/vdisks/test-quickly.qcow2 -m /dev/centos/root /kvm/modify/
[root@localhost ~]# cd /kvm/modify/
[root@localhost modify]# ll
总用量 12
lrwxrwxrwx.  1 root root    7 7月  24 12:40 bin -> usr/bin
drwxr-xr-x.  2 root root    6 7月  24 12:39 boot
drwxr-xr-x.  2 root root    6 7月  24 12:39 dev
drwxr-xr-x. 75 root root 8192 7月  24 12:42 etc
drwxr-xr-x.  2 root root    6 4月  11 2018 home
lrwxrwxrwx.  1 root root    7 7月  24 12:40 lib -> usr/lib
lrwxrwxrwx.  1 root root    9 7月  24 12:40 lib64 -> usr/lib64
drwxr-xr-x.  2 root root    6 4月  11 2018 media
drwxr-xr-x.  2 root root    6 4月  11 2018 mnt
drwxr-xr-x.  2 root root    6 4月  11 2018 opt
drwxr-xr-x.  2 root root    6 7月  24 12:39 proc
dr-xr-x---.  2 root root  114 7月  24 12:43 root
drwxr-xr-x.  2 root root    6 7月  24 12:39 run
lrwxrwxrwx.  1 root root    8 7月  24 12:40 sbin -> usr/sbin
drwxr-xr-x.  2 root root    6 4月  11 2018 srv
drwxr-xr-x.  2 root root    6 7月  24 12:39 sys
drwxrwxrwt.  7 root root  132 7月  24 12:43 tmp
drwxr-xr-x. 13 root root  155 7月  24 12:40 usr
drwxr-xr-x. 19 root root  251 7月  24 12:41 var
[root@localhost modify]# vim ./etc/sysconfig/network-scripts/ifcfg-eth0 
[root@localhost modify]# cat ./etc/sysconfig/network-scripts/ifcfg-eth0 
TYPE="Ethernet"
PROXY_METHOD="none"
BROWSER_ONLY="no"
BOOTPROTO="none"
DEFROUTE="yes"
IPV4_FAILURE_FATAL="no"
IPV6INIT="yes"
IPV6_AUTOCONF="yes"
IPV6_DEFROUTE="yes"
IPV6_FAILURE_FATAL="no"
IPV6_ADDR_GEN_MODE="stable-privacy"
NAME="eth0"
DEVICE="eth0"
ONBOOT="yes"
IPADDR="192.168.188.138"
PREFIX="24"
GATEWAY="192.168.188.2"
DNS1="8.8.8.8"
IPV6_PRIVACY="no"
[root@localhost modify]# cd
[root@localhost ~]# guestunmount /kvm/modify/
[root@localhost ~]# ll /kvm/modify/
总用量 0

修改对应的配置文件方便kvm识别并为之对应

root@localhost ~]# cp /etc/libvirt/qemu/{template.xml,test-quickly.xml}
[root@localhost ~]# vim /etc/libvirt/qemu/test-quickly.xml
改主机名:<name>test-quickly</name>
删除uuid
改磁盘:<disk type='file' device='disk'><driver name='qemu' type='qcow2'/><source file='/kvm/vdisks/test-quickly.qcow2'/><target dev='vda' bus='virtio'/><address type='pci' domain='0x0000' bus='0x00' slot='0x06' function='0x0'/></disk>
改vnc端口(避免端口冲突):<graphics type='vnc' port='6901' autoport='no' listen='0.0.0.0'><listen type='address' address='0.0.0.0'/></graphics>
删除网卡mac地址(删除后如下):<interface type='bridge'><source bridge='br0'/><model type='virtio'/><address type='pci' domain='0x0000' bus='0x00' slot='0x03' function='0x0'/></interface>

开始定义虚拟机

[root@localhost ~]# virsh list --allId    名称                         状态
-----------------------------------------------------     template                       关闭[root@localhost ~]# virsh define /etc/libvirt/qemu/test-quickly.xml 
定义域 test-quickly(从 /etc/libvirt/qemu/test-quickly.xml)[root@localhost ~]# virsh list --allId    名称                         状态
-----------------------------------------------------     template                       关闭-     test-quickly                   关闭[root@localhost ~]# virsh start test-quickly
域 test-quickly 已开始[root@localhost ~]# virsh list --allId    名称                         状态
----------------------------------------------------3     test-quickly                   running-     template                       关闭[root@localhost ~]# 

使用vnc访问查看虚拟机状态(查看ip是否被修改)

快速创建完成

2.3.1、快速创建脚本和模板 

上述这个过程中很多内容可以通过修改模板文件后使用脚本代替我们完成,我们只需要提供一些基础参数(ip,主机名,虚拟机名)使用脚本调用对应参数实现脚本位于最开始clone下的项目中,操作如下

[root@localhost ~]# cp kvmvirtual/virtual_create/createvm.sh /usr/local/bin/createvm
[root@localhost ~]# chmod a+x /usr/local/bin/createvm 
[root@localhost ~]# createvm --help
用法: createvm [hapn]... Create a virtual machine and create a fixed IP address, vnc port, virtual machine name -h, --help 获取帮助信息-a, --address 设置IP地址-p, --port 设置vnc端口-n, --name 设置虚拟机名称退出状态:0 正常1404 一般问题 (例如:没有对应的选项)x403 严重问题 (例如:设置参数不正确)

制作模板文件

[root@localhost ~]# vim /etc/libvirt/qemu/template.xml
修改虚拟机名和删除uuid<domain type='kvm'><name>NAME</name><memory unit='KiB'>2097152</memory>修改磁盘配置<disk type='file' device='disk'><driver name='qemu' type='qcow2'/><source file='/kvm/vdisks/NAME.qcow2'/><target dev='vda' bus='virtio'/><address type='pci' domain='0x0000' bus='0x00' slot='0x06' function='0x0'/></disk>
删除网卡mac
修改vnc端口<graphics type='vnc' port='VNCPORT' autoport='no' listen='0.0.0.0'><listen type='address' address='0.0.0.0'/></graphics>

使用脚本制作虚拟机

[root@localhost ~]# createvm -a 192.168.188.139 -p 6902 -n test-createvm-commands-01

 使用vnc登录查看

实际操作中通常会通过将jumpserver的认证脚本,zabbix-agent自启动配置在模板中,快速创建后第一次开机即可自动进行认证。

3、KVM虚拟机生命周期管理

[root@localhost ~]# virsh list
#查看运行中的虚拟机[root@localhost ~]# virsh list --all
#查看所有虚拟机[root@localhost ~]# virsh start test-quickly
#启动虚拟机test-quickly[root@localhost ~]# virsh reboot test-quickly
#重启虚拟机test-quickly[root@localhost ~]# virsh reboot test-quickly
#重启虚拟机test-quickly[root@localhost ~]# virsh destroy test-quickly
#虚拟机test-quickly断电[root@localhost ~]# virsh shutdown test-quickly
#虚拟机test-quickl关机[root@localhost ~]# virsh console test-quickly
#连接到虚拟机test-quickly

使用 virsh console连接时候可能会遇到如下错误导致无法退出

 这时使用ctrl+](ctrl和右中括号)退出当前连接

如果console连接卡住不动, 则通过vnc进入到对应的虚拟机中在以下文件中添加内容

# cat /etc/securetty | tail -n 1
ttyS0
# cat /etc/grub2.cfg | grep ttyS0
linux16 /vmlinuz-3.10.0-1160.el7.x86_64 root=/dev/mapper/centos-root ro rd.lvm.lv=centos/root rd.lvm.lv=centos/swap rhgb quiet console=ttyS0#此处如果有两个linux16开头的行则需要都添加console=ttyS0

4、虚拟机资源管理

 虚拟机cpu,内存,磁盘调整

#> cpu及memory的调整(须关机调整)
$ virsh edit VIRTUAL_MACHINES_NAME
<domain type='kvm'><name>VIRTUAL_MACHINES_NAME</name><uuid>752b7fc7-3446-40d3-9868-d46acf9a8b78</uuid><memory unit='KiB'>16777216</memory><currentMemory unit='KiB'>16777216</currentMemory><vcpu placement='static'>4</vcpu><os><type arch='x86_64' machine='pc-i440fx-rhel7.0.0'>hvm</type><boot dev='hd'/></os>..................
#> disk磁盘增加
$ qemu-img create -f [raw/qcow2] /kvm/vdisks/VMACHINE_NAME_DATA_NUMBER.[raw/qcow2] size
$ virsh attach-disk VMACHINE_NAME /kvm/vdisks/VMACHINE_NAME_DATA_NUMBER.[raw/qcow2] vdx#    挂载位置
$ virsh edit VMACHINE_NAME
......<devices><emulator>/usr/libexec/qemu-kvm</emulator><disk type='file' device='disk'><driver name='qemu' type='qcow2'/><source file='/ROOT/kvm/images/k8s-master-01.qcow2'/><target dev='vda' bus='virtio'/><address type='pci' domain='0x0000' bus='0x00' slot='0x06' function='0x0'/></disk><disk type='file' device='disk'><driver name='qemu' type='raw/qcow2'/><source file='/kvm/vdisks/VMACHINE_NAME.raw/qcow2'/><target dev='vdx' bus='virtio'/></disk>
......
#> disk磁盘移除
$ virsh detach-disk VMACHINE_NAME vdx

生产中对虚拟机进行配置以及相关重大变更的时候, 通常需要对虚拟机进行快照的创建; 以及在业务扩容的过程中, 将已存在的且符合生产要求的虚拟机进行克隆, 可以最快速的增加服务负载;

#> 快照的创建 -> 恢复 -> 删除
$ virsh snapshot-create-as VMACHINE_NAME VMACHINE_NAME-snapshot-$(date +%Y%m%d%H%M%S)
$ vrish snapshot-revert VMACHINE_NAME VMACHINE_NAME-snapshot-xxxxxxxxxxxxxx
$ virsh snapshot-delete VMACHINE_NAME VMACHINE_NAME-snapshot-xxxxxxxxxxxxxx
#> 克隆(需要对OLD_VMACHINE_NAME机器关机)
$ virt-clone -o OLD_VMACHINE_NAME -n NEW_VMACHINE_NAME -f /kvm/vdisks/NEW_VMACHINE_NAME.qcow2

通常情况下, 当宿主机需要生产维护or宕机灾难时, 需要我们快速的对其上的虚拟机进行迁移, 考虑到这种情况, 就需要在KVM环境实施之前将虚拟磁盘存储目录变更为NFS/GFS的集群文件系统, 让多台KVM宿主机均可访问同一个地方的虚拟磁盘, 这也方便了我们进行迁移操作; 当然宿主机与宿主机之间也要保证网络等基础环境资源的一致性, 相互之间也一定要做好免密认证;

$ virsh migrate --live hiops_test_migrate qemu+ssh://root@192.168.121.12/system --verbose --unsafe

5、图形化界面操作

以上环境均为无图形化操作手册,用于理解配置文件位置及操作原理,实际工作中,大部分操作均可使用webvirtualcloud和virt-manager两种虚拟机管理工具进行操作,操作方式与vmware十分相似,网上也有很多类似教程,这里展示一下webvirtualcloud的手动部署( 如果工作环境可以使用外国网络环境可以直接使用github上提供的一键安装)

$ cat /etc/redhat-release
CentOS Stream release 8#    至少是centos8$ sed -ri 's/SELINUX=enforcing/SELINUX=disabled/' /etc/selinux/config
$ systemctl disable --now firewalld
$ yum -y install epel-release
$ yum -y install python3-virtualenv python3-devel libvirt-devel glibc gcc \nginx supervisor python3-lxml git python3-libguestfs iproute-tc \cyrus-sasl-md5 python3-libguestfs
$ cd /srv/
$ git clone https://github.com/retspen/webvirtcloud && cd webvirtcloud
Cloning into 'webvirtcloud'...
remote: Enumerating objects: 8955, done.
remote: Counting objects: 100% (927/927), done.
remote: Compressing objects: 100% (457/457), done.
remote: Total 8955 (delta 474), reused 864 (delta 451), pack-reused 8028
Receiving objects: 100% (8955/8955), 8.25 MiB | 649.00 KiB/s, done.
Resolving deltas: 100% (5965/5965), done.$ pip3 install -i https://mirrors.ustc.edu.cn/pypi/web/simple pip -U
$ pip config set global.index-url https://mirrors.ustc.edu.cn/pypi/web/simple
$ pip install -U setuptools virtualenv
$ cp webvirtcloud/settings.py.template webvirtcloud/settings.py
$ virtualenv -p $(which python3) /srv/envs/webvirtcloud#     这条命令的目的是在 /srv/envs/ 目录下创建一个使用 Python 3 解释器的虚拟环境,用于隔离和管理 webvirtcloud 应用程序所需的 Python 环境和依赖。$ source /srv/envs/webvirtcloud/bin/activate
(webvirtcloud) $ python /srv/webvirtcloud/conf/runit/secret_generator.py
X^*tIo&S|GhwygIp3}X)qs{wkcAy=vay~.%4^kU#,iKZs*\`&V
$ vim /srv/webvirtcloud/webvirtcloud/settings.py
SECRET_KEY = "X^*tIo&S|GhwygIp3}X)qs{wkcAy=vay~.%4^kU#,iKZs*\`&V"
$ cd /srv/webvirtcloud/
$ pip install -r conf/requirements.txt
$ python manage.py makemigrations
$ python manage.py migrate
$ vim /etc/supervisord.d/webvirtcloud.ini
[program:webvirtcloud]
command=/srv/envs/webvirtcloud/bin/gunicorn webvirtcloud.wsgi:application -c /srv/webvirtcloud/gunicorn.conf.py
directory=/srv/webvirtcloud
user=root
autostart=true
autorestart=true
redirect_stderr=true
[program:novncd]
command=/srv/envs/webvirtcloud/bin/python /srv/webvirtcloud/console/novncd
directory=/srv/webvirtcloud
user=root
autostart=true
autorestart=true
redirect_stderr=true
$ systemctl enable --now supervisord
$ supervisorctl reload
$ supervisorctl update
$ supervisorctl restart all
$ supervisorctl status
novncd                           RUNNING   pid 15774, uptime 0:00:06
webvirtcloud                     RUNNING   pid 15775, uptime 0:00:06
$ cp conf/nginx/webvirtcloud.conf /etc/nginx/conf.d/#    这里需要把nginx自带的虚拟主机注释掉$ systemctl enable --now nginx

遇到usb不支持的情况,解决办法如下

$ vim /srv/webvirtcloud/vrtManager/create.pyif "usb" in dom_caps["disk_bus"]:xml += """<input type='mouse' bus='{}'/>""".format("virtio" if virtio else "usb")xml += """<input type='keyboard' bus='{}'/>""".format("virtio" if virtio else "usb")xml += """<input type='tablet' bus='{}'/>""".format("virtio" if virtio else "usb")else:xml += """<input type='mouse'/>"""xml += """<input type='keyboard'/>"""xml += """<input type='tablet'/>"""#    修改为以下配置if "usb" in dom_caps["disk_bus"]:passelse:pass

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/51279.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Node.js版本管理工具之NVM

目录 一、NVM介绍二、NVM的下载安装1、NVM下载2、卸载旧版Node.js3、安装 三、NVM配置及使用1、设置nvm镜像源2、安装Node.js3、卸载Node.js4、使用或切换Node.js版本5、设置全局安装路径和缓存路径 四、常用命令技术交流 博主介绍&#xff1a; 计算机科班人&#xff0c;全栈工…

卷积神经网络(一)---原理和结构

在介绍卷积神经网络之前&#xff0c;先提出三个观点&#xff0c;正是这三个观点使得卷积神经网络能够真正起作用。 1. 局部性 对于一张图片而言&#xff0c;需要检测图片中的特征来决定图片的类别&#xff0c;通常情况下这些特征都不是由整张图片决定的&#xff0c;而是由一些…

vscode 环境

这张截图显示的是在VS Code&#xff08;Visual Studio Code&#xff09;中选择Python解释器的界面。不同的Python解释器及其虚拟环境列出了可选项&#xff0c;用户可以根据需要选择合适的解释器来运行Python代码。以下是对截图中信息的详细解释&#xff1a; 解释器选择界面 当…

Chrome浏览器设置暗黑模式 - 护眼模式 - 亮度调节 - DarkReader - 地址栏和书签栏设置为黑色背景

效果图 全黑 浅灰 &#xff08;DarkReader设置开启亮色亮度-25&#xff09; 全白 前言 主要分两部分需要操作&#xff0c; 1&#xff09;地址栏和书签栏 》 需要修改浏览器的外观模式 2&#xff09;页面主体 》 需要安装darkreader插件进行设置 步骤 1&#xff09;地址栏和…

AOP面向切面编程和log4j的使用(Java版)

什么是面向切面编程 在传统的面向对象编程中&#xff0c;程序的功能被模块化成各个类和方法&#xff0c;这些类和方法分别处理特定的功能。然而&#xff0c;有些功能可能涉及到多个类、多个方法&#xff0c;例如日志记录、事务管理、性能监控等&#xff0c;这些功能可能在不同…

橙单后端项目下载编译遇到的问题与解决

今天下载orange-admin项目&#xff0c;不过下载下来运行出现一些问题。 1、涉及到XMLStreamException的几个类都出现下面的错误 The package javax.xml.stream is accessible from more than one module: <unnamed>, java.xml ctrl-shift-t 可以找到这个引入是哪些包里…

AcWing803. 区间合并

#include<climits>的作用是方便我直接使用INT_MIN,下面这个代码是二刷写的 思路是先根据 [ L , R ] i [L,R]_i [L,R]i​的L先排序&#xff0c;然后遍历vector进行区间合并。 #include<iostream> #include<vector> #include<algorithm> #include<cl…

在window将Redis注册为服务

将redis注册为系统服务&#xff0c;开启自启动 安装服务 默认注册完之后会自动启动&#xff0c;在window中的服务看一下&#xff0c;如果启动类型为自动&#xff0c;状态是自动运行则启动完成。如果是手动&#xff0c;需要右键属性调整为自动&#xff0c;在点击启动&#xff0c…

【React】详解组件通信:从基础到进阶的全面指南

文章目录 一、父组件向子组件传递数据1. 基本概念2. 示例代码3. 详解定义子组件 Son定义父组件 App导出父组件 App数据流props 的内容 二、子组件向父组件传递数据1. 基本概念2. 示例代码3. 详解引入React库和useState钩子定义子组件 Son定义父组件 App导出父组件 App数据流 三…

C++11新特性——智能指针——参考bibi《 原子之音》的视频以及ChatGpt

智能指针 一、内存泄露1.1 内存泄露常见原因1.2 如何避免内存泄露 二、实例Demo2.1 文件结构2.2 Dog.h2.3 Dog.cpp2.3 mian.cpp 三、独占式智能指针:unique _ptr3.1 创建方式3.1.1 ⭐从原始(裸)指针转换&#xff1a;3.1.2 ⭐⭐使用 new 关键字直接创建&#xff1a;3.1.3 ⭐⭐⭐…

Idea中连接MS SQL Server报错:驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接

一、错误重现 报错如下&#xff1a; [08S01] 驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接。错误:“PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to request…

leetcode日记(59)简化路径

&#xff08;小杯文字描述…看了好一会才看懂题目要求&#xff09;题目是标准化路径&#xff0c;就是将多个‘/’优化为一个、将最后一个‘/’去掉、将‘/../’和‘/./’去掉&#xff0c;将原路径转化为实际想表达的最终路径。 有点像单纸带图灵机&#xff0c;需要依次遍历字母…

Windows系统安全加固方案:快速上手系统加固指南 (下)

这里写目录标题 一、概述二、IP协议安全配置启用SYN攻击保护 三、文件权限3.1 关闭默认共享3.2 查看共享文件夹权限3.3 删除默认共享 四、服务安全4.1禁用TCP/IP 上的NetBIOS4.2 ### 禁用不必要的服务 五、安全选项5.1启动安全选项5.2禁用未登录前关机 六、其他安全配置**6.1防…

《JavaEE》----2.<多线程的简介创建Thread类>

前言&#xff1a; 大家好&#xff0c;我目前在学习java。我准备利用这个暑假&#xff0c;来复习之前学过的内容&#xff0c;并整理好之前写过的博客进行发布。如果博客中有错误或者没有读懂的地方。热烈欢迎大家在评论区进行讨论&#xff01;&#xff01;&#xff01; 喜欢我文…

【深度学习】“复杂场景下基于深度学习的卷积神经网络在鸟类多类别识别中的模型设计与性能优化研究“(中)

【深度学习】“复杂场景下基于深度学习的卷积神经网络在鸟类多类别识别中的模型设计与性能优化研究”(中) 大家好 我是寸铁&#x1f44a; 【深度学习】“复杂场景下基于深度学习的卷积神经网络在鸟类多类别识别中的模型设计与性能优化研究”(中)✨ 喜欢的小伙伴可以点点关注 &a…

一个网站搞定Adobe系列软件下载安装,良心网站!

Adobe系列软件几乎是每个办公职场人都会用到的软件&#xff0c;比如PDF&#xff0c;PS&#xff0c;AI&#xff0c;PE&#xff0c;PR等&#xff0c;不管你是设计图片&#xff0c;制作编辑音频还是视频&#xff0c;Adobe都有对应的软件。但是对于大部分用户来说&#xff0c;Adobe…

Linux网络:传输层TCP协议(四)拥塞控制及延迟应答

目录 一、拥塞控制 二、延迟应答 一、拥塞控制 虽然 TCP 拥有滑动窗口这个大杀器机制来根据具体情况对发送的数据大小和速度进行实时控制, 能够高效并且可靠的发送大量的数据. 但是如果在双方建立好连接后的刚开始阶段就发送大量的数据。仍然可能引发一些问题. 因为同一个网…

怎么给PDF文件加密码?关于PDF文件加密的四种方法推荐

怎么给PDF文件加密码&#xff1f;给PDF文件加上密码是保护文件安全的一种重要方法&#xff0c;特别是当需要在不受授权的访问下保护敏感信息时。这个过程不仅仅是简单地设置密码&#xff0c;而是涉及到对文档内容和访问控制的深思熟虑。加密PDF文件可以有效防止未经授权的用户查…

杂谈(杂鱼谈论c语言)——2.大小端字节序

⼤⼩端字节序和字节序判断 当我们了解了整数在内存中存储后&#xff0c;我们调试看⼀个细节&#xff1a; #include <stdio.h> int main() {int a 0x11223344;return 0; } 调试的时候&#xff0c;我们可以看到在a中的 0x11223344 这个数字是按照字节为单位&#xff0c;…

creality ender2的3D打印经验教训

创想云-3D打印模型库-一体化3D打印平台 1.开机后要放一张白纸进行检查&#xff0c;看看打印头立平台的距离&#xff0c;如果太近&#xff0c;会灼烧平台&#xff0c;会造成下面的结果&#xff1a; 2.下载模型&#xff0c;可以在线切片&#xff0c;要看看是否要支撑 没有支撑可…