kvm命令行安装

qemu-img创建磁盘文件

通过文件管理可以直接查看、修改、复制虚拟机的内部文件。例如,当系统因为配置文件无法启动 时,可以直接修改虚拟机的文件。虚拟机磁盘文件主要有raw和qcow2格式。raw格式性能最好,速度最 快,它的缺点就是不支持一些新的功能,如支持镜像,zlib磁盘压缩,AES加密等。要使用镜像功能,磁 盘格式必须为qcow2。

raw格式的话,速度稍微快点,在高版本的qemu-kvm中,几乎不比qcow2的格式快,而qcow2格式节 省空间,可动态增长,在公有云中广泛使用,建议使用qcow2。所有有时候,我们需要将raw格式的磁盘 转换成qcow2格式。

创建一个raw格式的磁盘文件

[root@localhost kvm-vm]# qemu-img create/kvm-vm/vmtest01.img 8G Formatting '/kvm-vm/vmtest01.img', fmt=rawsize=8589934592

查看一下

[root@localhost kvm-vm]# ls -lh

虽然通过ls命令看到磁盘为8G,但是实际空间大小为0,所以通过qemu-img创建的磁盘为稀疏模式磁盘。

通过virt-manager或者virt-install命令创建新虚拟机并安装好

转换磁盘格式为qcow2

virt-install命令参数:

通用选项:

-n NAME, --name=NAME 虚拟机名称

-r MEMORY, --ram=MEMORY 以MB为单位为客户端事件分配的内存

--vcpus=VCPUS 配置虚拟机的虚拟CPU(vcpu)数量,如:

--vcpus 5

--vcpus 5, maxcpus=10

--vcpus socket=2,cores=4,threads=2

--cpuset=CPUSET Set whichphysical CPUs domain can use.

--cpu=CPU CPU型号及功能,如:--cpu coreduo,+x2apic

--description=DESCRIPTION 在生成的XML中保存的可读VM描述。

--security=SECURITY 设定域安全驱动器配置。

--numatune=NUMATUNE 为域进程调整NUMA策略。

安装方法选项:

-c CDROM, --cdrom=CDROM 光驱安装介质

-l LOCATION, --location=LOCATION

安装源(例如:nfs:host:/path、http://host/path、ftp://host/path)

--pxe 使用 PXE 协议从网络引导

--import 在磁盘映像中构建客户机

--livecd 将光驱介质视为 Live CD

-x EXTRA, extra-args=EXTRA

附加到使用--location引导的内核的参数--os-type=DISTRO_TYPE

操 作 系 统 类 型 ,'linux' 、'unix' 、 'windows'

--os-variant=DISTRO_VARIANT

操作系统版本,如: 'fedora6','rhel5', 'solaris10','win2k'

--boot=BOOTOPTS 自选配置后安装引导顺序、菜单、永久kernel引导,等等。

存储配置:

--disk=DISKOPTS 用各种选项指定存储。 Ex.

--disk path=/my/existing/disk

--disk path=/my/new/disk,size=5 (单位GB)

--disk vol=poolname:volname,device=cdrom,bus=scsi,...

--nodisks 不要为该客户端设置任何磁盘。

--filesystem=FILESYSTEMS

将主机目录传递给虚拟机。例如:

--filesystem /my/source/dir,/dir/in/guest

--filesystem template_name,/,type=template

联网配置:

-w NETWORK, network=NETWORK

配置客户网络接口。 Ex:

--network bridge=mybr0

--network network=my_libvirt_virtual_net

--network network=mynet,model=virtio,mac=00:11...

--nonetworks 不要为该客体创建网络接口。

图形配置:

--graphics=GRAPHICS

配置虚拟机显示设置。例如:

--graphics vnc

--graphics spice,port=5901,tlsport=5902

--graphics none

--graphics vnc,password=foobar,port=5910,keymap=ja

--noautoconsole 不要自动尝试连接到客户端控制台

设备选项:

--serial=SERIALS 配置虚拟机串口设备

--parallel=PARALLELS 配置虚拟机并口设备

--channel=CHANNELS 配置虚拟机沟通频道

--console=CONSOLES 配置虚拟机与主机之间的文本控制台连接

--host-device=HOSTDEVS 配置与客户相连的物理主机设备

--soundhw=SOUNDHW 配置客户声音设备仿真

--watchdog=WATCHDOG 配置虚拟机 watchdog 设备

--video=VIDEO 配置虚拟机视频硬件。

--smartcard=SMARTCARD 配置虚拟机智能卡设备。

例如:--smartcard mode=passthrough

--redirdev=REDIRDEV Configure a guest redirection device.

例如:--redirdevusb,type=tcp,server=192.168.1.1:4000

虚拟化平台选项:

-v, --hvm 客户端应该是一个全虚拟客户端

-p, --paravirt 这个客户端是一个半虚拟客户端

--container This guestshould be a container guest

--virt-type=HV_TYPE 要使用的管理程序名称(kvm、qemu、xen)

--arch=ARCH 模拟的 CPU 构架

--machine=MACHINE The machinetype to emulate

--noacpi 为全虚拟客户端禁用 ACPI(在 os-type/os-variant db 中覆盖数值)

-u UUID, --uuid=UUID 客户端 UUID。

其它选项:

--autostart 引导主机时自动启动域。

--print-xml 输出所生成域的XML,而不是定义虚拟机。

--print-step=XMLSTEP 输出具体安装步骤

--noreboot 完成安装后不要引导虚拟机。

--wait=WAIT 要等待的时间(以分钟为单位)

--dry-run 完成安装步骤,但不要创建设备或者定义虚拟机。

--force 对任意应用程序提示强制回答‘yes’,终止其它提示

-q, --quiet 禁止无错误输出

--prompt 要求用户为模糊情况或者需要的选项输入

-d, --debug 输入故障排除信息

实践:

使用qemu-img命令创建一个qcow2格式的虚拟机磁盘文件

qemu-img create -f qcow2/kvm-vm/centos7-vm002.qcow2 10G

使用virt-install命令创建虚拟机

# virt-install --name mycentosy -r 1024--vcpus 1 --network bridge=br0 --disk

/iso/mycentos7.qcow2,format=qcow2,size=10--location=/iso/centos7.iso

virt-install \

--name vm002 \ 指定虚拟机的名字

--vcpus 1 --ram 1024 \ 指定vcpu数量和内存大小

--disk/kvm-vm/centos7-vm002.qcow2,format=qcow2 \ 指定虚拟磁盘及格式

--network network=default \ 指定虚拟机采用的网络为默认,默认为NAT

--graphics vnc,listen=0.0.0.0--noautoconsole \ 指定虚拟机显示协议为VNC

--os-type=linux --os-variant=centos7.0\ 指定操作系统类型及版本

--location=/iso/CentOS-7-x86_64-DVD-1611.iso 指定安装介质

然后到桌面系统,打开virt-manager,完成后续的安装操作系统的工作即可。

如果不希望手动安装操作系统,也可以指定应答文件来自动完成安装过程,增加--extra-args参数

--extra-args=’ks=http://192.168.1.100/mini.txt’ (mini.txt为应答文件)

如果希望通过PXE安装虚拟机,可以使用以下命令参数:

--pxe 制定使用PXE协议从网络引导

纯命令行安装kvm的操作系统

qemu-img create -f qcow2/home/kvmos/centos6.9.qcow2 60G

virt-install --name centos6.9 -r 2048--vcpus=2 --location=/home/softs/iso/CentOS-6.9- x86_64-bin-DVD1.iso --networkbridge=br0 --disk path=/home/kvmos/centos6.9.qcow2,size=60,format=qcow2,sparse --nographics -x 'console=ttyS0'

vnc 安装

qemu-img create -f qcow2/opt/kvm/hardisk/disk.img 60G

virt-install \

--name user_1604 \

--ram 2048 \

--vcpus=2 \

--diskpath=/home/kvmos/user_1604.qcow2,size=60,format=qcow2,sparse \

--accelerate \

--cdrom/home/softs/iso/ubuntu-16.04.4-server-amd64.iso \

--graphics vnc,listen=0.0.0.0,port=5924, \

--noautoconsole \

--network bridge=br0 \

--autostart

这时可能通过远程设备,连接上vnc接口即可。

无法使用vrishconsole 登录虚拟机的解决方案

如果通过vrish console 无法连接到服务器,可以使用vnc或者 ssh连接到服务器。如果不支持virsh console 可以尝试以下方法

方法一:

修改grub配置文件,在内核行加入console=ttyS0,重启即可

linux16/vmlinuz-3.10.0-693.el7.x86_64 root=/dev/mapper/centos-root rord.lvm.lv=centos/root rd.lvm.lv=centos/swap console=ttyS0.UTF-8 或者使用如下命令,如果是CentOS7,需要在虚拟机里运行以下命令

[root@localhost ~]# grubby --update-kernel=ALL--args="console=ttyS0"

方法二:

如果是ubuntu系统可以使用如下方法:

$ sudo systemctlenable serial-getty@ttyS0.service

$ sudo systemctlstart serial-getty@ttyS0.service

#virsh edit VPS-Domain

<graphicstype='vnc' port='5901' autoport='no' listen='0.0.0.0' keymap='en-us'/> 在其中加入passwd的属性,更改为如下:

<graphics type='vnc' port='5901'autoport='no' listen='0.0.0.0' passwd='12345678' keymap='en-us'/>

其中passwd的位置可以随意。

原文发布于微信公众号 - L宝宝聊IT(gh_b0e552aa80db)

原文发表时间:2018-06-18

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏同步博客

我对RPC的理解

  这篇文章将会用最直白的方式介绍RPC,以及实现RPC客户端的Ajax跨域调用的例子。

1314
来自专栏微服务生态

缓存穿透、缓存并发、热点缓存之最佳招式

在之前的一篇缓存穿透、缓存并发、缓存失效之思路变迁文章中介绍了关于缓存穿透、并发的一些常用思路,但是个人感觉文章中没有明确一些思路的使用场景,本文继续将继续深化...

782
来自专栏菩提树下的杨过

spring cloud: 使用consul来替换config server

上一篇提到了,eureka 2.x官方停止更新后,可以用consul来替代,如果采用consul的话,其实config server也没必要继续使用了,cons...

1653
来自专栏Java架构沉思录

DNS是如何运行的

DNS 是互联网核心协议之一。不管是上网浏览,还是编程开发,都需要了解一点它的知识。

1251
来自专栏linux驱动个人学习

Linux启动流程

启动第一步--加载BIOS  当你打开计算机电源,计算机会首先加载BIOS信息,BIOS信息是如此的重要,以至于计算机必须在最开始就找到它。这是因为BIOS中包...

3105
来自专栏黑白安全

中间件漏洞与防护

中间件漏洞可以说是最容易被web管理员忽视的漏洞,原因很简单,因为这并不是应用程序代码上存在的漏洞,而是属于一种应用部署环境的配置不当或者使用不当造成的 我们...

1713
来自专栏趣谈编程

DNS原理入门

DNS 是互联网核心协议之一。不管是上网浏览,还是编程开发,都需要了解一点它的知识。

1700
来自专栏后端云

本地存储条件下的热迁移

每个读者都可能会问这样一个问题,虚拟机用的好好的,为啥要迁移呀?也就是迁移的价值和目的在哪里。在数据中心的日常运维中,常常要处理下面几种场景和需求,了解了这些需...

1584
来自专栏Samego开发资源

端口检测 | 命令行整理篇

2713
来自专栏Python数据科学

爬虫模拟登录—OAUTH的详解

前两篇分享了HTTP的基本概念和高级用法,以及京东模拟登录的实战内容。本篇博主将会继续与大家分享HTTP中的另一个有趣内容:OAUTH,它也是在爬虫的模拟登录中...

2012

扫码关注云+社区