每天5分钟复习OpenStack(三)
每天5分钟复习OpenStack(三)
为什么要拉起kvm 虚拟机要熟悉这些操作? 作为一个运维工程师,将来有大量的时间是在制作镜像,镜像的制作就是在kvm虚拟化环境拉起kvm 管理的虚拟机的过程,安装一些必要的agent,如 QGA,cloud-init 等,完成之后shutdown 关机,其qcow2的磁盘文件就是镜像。
拉起第一台KVM 虚拟机
1、环境说明
• 安装vmware软件
• 安装系统,系统版本 Centos7.6 版本 1810
• vmware 网络配置 NAT 模式 网段192.168.48.0/24 虚拟机IP 192.168.48.11
• 虚拟机默认最小化安装,对分区没有要求 下面提供一个初始化脚本用来系统优化新安装的系统


2、环境初始化
主要功能是:
修改主机名为自己的IP 、
关闭selinux firewalld
加载netfilter 模块是为了在linux Bridge 上增加NAT 功能。
修改网卡名为ethX
关闭SSH登录的反向解析。
#!/bin/bash
#1. 设置用户名
name=`ip -o -4 addr |awk -F '/| +' '/eth0/{print $4}' |tr '.' '-'`
hostnamectl set-hostname $name
# 2. 关闭selinux
sed -i 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/selinux/config
setenforce 0
# 3. 关闭防火墙,开启转发
systemctl stop firewalld
systemctl disable firewalld
echo "net.ipv4.ip_forward=1" >> /etc/sysctl.conf
modprobe br_netfilter
echo "net.bridge.bridge-nf-call-arptables = 0 " >> /etc/sysctl.conf
echo "net.bridge.bridge-nf-call-iptables = 0" >> /etc/sysctl.conf
echo br_netfilter >> /etc/modules-load.d/modules.conf
sysctl -p
#4. 关闭NetworkManager
systemctl stop NetworkManager
systemctl disable NetworkManager
#5. 修改网卡名字
grep biosdevname=0 /etc/default/grub || sed -ie 's/rhgb quiet/net.ifnames=0 #biosdevname=0 rhgb quiet/' /etc/default/grub
grub2-mkconfig -o /boot/grub2/grub.cfg
#ssh 优化
sed -i 's/#UseDNS yes/UseDNS no/' /etc/ssh/sshd_config
systemctl restart sshd
#8. 重启reboot
#########重启服务器###########
read -p "是否重启服务器 y/n" sure
if [ $sure == "y" ];then
reboot
fi
3、安装KVM 基础环境安装包
yum install qemu-kvm virt-manager virt-install vim libvirt bc wget -y
4、启动libvirtd 服务 下载安装镜像文件
systemctl start libvirtd
systemctl enable libvirtd
mkdir -pv /data/{iso,images}
5、 下载阿里云7.6的镜像iso文件
wget https://mirrors.aliyun.com/centos-vault/7.6.1810/isos/x86_64/CentOS-7-x86_64-Minimal-1810.iso?spm=a2c6h.25603864.0.0.39ec12cfDiobIj \
-O /data/iso/CentOS-7-x86_64-Minimal-1810.iso
6、拉起kvm 虚拟机test
kvm001.raw 文件系统会自动生成
vnc的方式登录,因此需要找到vnc对应的端口
启动文件为ISO,因此需要手动安装系统,将来熟悉后可以采用ks文件来实现自动化的安装。
vnc 登录的方式
virt-install \
--name=test --ram 1024 --vcpus=1 \
--disk path=/data/images/kvm001.raw,size=50,format=raw,bus=virtio \
--cdrom=/data/iso/CentOS-7-x86_64-Minimal-1810.iso --network bridge=virbr0,model=virtio \
--graphics vnc,listen=0.0.0.0 --noautoconsole
自动安装系统的方式
需要提前准备ks文件,ks文件制作网上例子很多,这里暂时不表。
也可以去掉ks.cfg 的部分,直接使用默认的console=tty0 来手动安装。
(注意有些特殊的操作系统如欧拉系统,默认其没有开启VNC服务,则vnc的方式无法系统安装,默认进入系统安装页面后VNC登陆就显示断开,此时只能使用console的方式)
virt-install \
--name test \
--memory=1024 \
--vcpus=2 \
--os-type linux \
--location /data/iso/CentOS-7-x86_64-Minimal-1810.iso \
--disk path=/data/images/test.qcow2,size=30,format=qcow2 \
--network bridge=virbr0 \
--graphics=none \
--console pty,target_type=serial \
--initrd-inject ks.cfg \
--extra-args 'inst.ks=file:/ks.cfg console=tty0 console=ttyS0,115200n8'
根据虚拟机名字test 查看进程号,通过进程查看监听端口号为5900+本地IP=192.168.48.11 则登录地址192.168.48.11:5900


VNC 安装登录操作系统



等待系统安装完成后,重启系统后,通过virsh list --all状态为shutdown

5、virsh常用管理命令
1 启动虚拟机
virsh start test
virsh autostart test
6、给虚拟机加上管理地址,方便ssh登录,重启网卡,使默认路由生效。


7、配置宿主机使虚拟机能访问公网
iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE

默认情况下虚拟机的流量都直接传送到网关192.168.122.1 ,而网关IP就在宿主机上,因此加上对应iptables 规则后,虚拟机就能访问公网了。
思考:
192.168.122.0/24 网段是系统自定义的,如何改变改网段
在实际生产环境会配置各种网桥,这些网桥都是只在本地物理机上生效,怎么跨主机让相同网络的虚拟机能相互访问呢?
各个网桥的流量怎么隔离了
每个虚拟机都使用光盘安装太麻烦,有没有简单方法使用kvm虚拟机能直接复制?
下面章节将一一揭晓上述答案

每天5分钟复习OpenStack(三)的更多相关文章
- 理解 OpenStack Swift (1):OpenStack + 三节点Swift 集群+ HAProxy + UCARP 安装和配置
本系列文章着重学习和研究OpenStack Swift,包括环境搭建.原理.架构.监控和性能等. (1)OpenStack + 三节点Swift 集群+ HAProxy + UCARP 安装和配置 ( ...
- OpenStack三个节点icehouse-gre模式部署
一.环境准备 1.架构 创建3台虚拟机,分别作为controll节点.network节点和compute1节点. Controller节点:1processor,2G memory,5G storag ...
- OpenStack三个节点icehouse
一.环境准备 1.架构 创建3台虚拟机,分别作为controll节点.network节点和compute1节点. Controller节点:1processor,2G memory,5G storag ...
- 十分钟复习CSS盒模型与BFC
css盒模型与BFC 本文为收集整理总结网上资源 旨在系统复习css盒模型与bfc 节省复习时间 阅读10分钟 什么是盒模型 每一个文档中,每个元素都被表示为一个矩形的盒子,它都会具有内容区.padd ...
- EF6 在原有数据库中使用 CodeFirst 总复习(三、重建迁移)
本来原来学的时候,挺顺利的,没想到再次使用,还是遇到很多问题,导致更新失败,所以,只能重建迁移,免得看着乱乱的. 一.删除迁移,将数据恢复到(一)结束状态 1.删除文件夹 2.删除表 3.删除列 4. ...
- 五分钟学习React(三):纯HTML代码搭建React应用
上一期我们使用了React官方的脚手架运行React应用.大家可能会觉得这种方法很繁琐,需要配置各种第三方插件.JQuery时代的前端真是让人怀念.这一期,我就带领大家创建一个"怀旧版&qu ...
- 10分钟安装OpenStack
1 OpenStack初学者的苦恼 2 OpenStack最低配置要求 3 配置UOS环境 3.1 设置网络 3.1.1 创建路由器 3.1.2 创建网络 3.1.3 创建两个子网 3.2 创建UOS ...
- OpenStack三种类型的NAT转换
SNAT SNAT即源网络地址转换,这个NAT路由修改IP包包头中的源IP地址.SNAT功能通常用于让只具有私有IP地址的主机能够访问外网,比如,多个PC使用路由器共享上网,每个PC都配置了内网IP, ...
- [NOIP 2014复习]第三章:动态规划——NOIP历届真题回想
背包型动态规划 1.Wikioi 1047 邮票面值设计 题目描写叙述 Description 给定一个信封,最多仅仅同意粘贴N张邮票,计算在给定K(N+K≤40)种邮票的情况下(假定全部的邮票数量都 ...
- [NOIP复习]第三章:动态规划
一.背包问题 最基础的一类动规问题.相似之处在于给n个物品或无穷多物品或不同种类的物品,每种物品仅仅有一个或若干个,给一个背包装入这些物品,要求在不超出背包容量的范围内,使得获得的价值或占用体积尽可能 ...
随机推荐
- VSCode设置第三方字体
最近需要写C,所以下了一个VSCode IDE嘛 当然是美观最重要了(不是 个人比较喜欢JetBrains家的字体 在IDEA中主要使用的是 JetBrains Mono 想着把VSCode的字体也设 ...
- 帮老娘导入SF信息
转自自己的QQ空间 2023/1/3 老娘公司要统计Excel 简单说就是把顺丰上面寄的85个快递填到表里去 再把没有寄的从那两张表加起来130多个人里面揪出来单独填表 有些企业的Excel就是个灾难 ...
- Redis的设计与实现(1)-SDS简单动态字符串
现在在高铁上, 赶着春节回家过年, 无座站票, 电脑只能放行李架上, 面对着行李架撸键盘--看过<Redis的设计与实现>这本书, 突然想起, 便整理下SDS的内容, 相对后面的章节, 算 ...
- K8S | Deployment应用编排
目录 一.背景 二.Deployment组件 1.简介 2.语法说明 三.基础用例 1.创建操作 2.查看信息 3.更新操作 4.删除操作 四.进阶用例 1.回滚操作 2.伸缩操作 3.暂停与恢复 五 ...
- Linux shell:根据盘符定位硬盘在服务器上的位置
disk-light.sh #!/bin/bash t_dev=$1 [ -b "$t_dev" ] || { echo "-b failed: $t_dev" ...
- Redis从入门到放弃(5):事务
1.事务的定义 Redis的事务提供了一种"将多个命令打包, 然后一次性.按顺序地执行"的机制. redis事务的主要作用就是串联多个命令防止别的命令插队. 但是,事务并不具有传统 ...
- 记一次 HTTPS 抓包分析和 SNI 的思考
日常听说 HTTPS 是加密协议,那现实中的 HTTPS 流量,是真的完全加密吗? --答案是,不一定.原因嘛,抓个包就知道了. 我们用 curl 命令触发一下: curl -v 'https://s ...
- 从零开始实现放置游戏(十七)——完结篇(附DEMO地址)
大家好,时隔2年多,我来填坑啦! 之前用的技术.设计思路都不成熟,所以直接干掉重做了. 由于从头教学实在太啰嗦,精力也有限,咱们还是直接上源码吧. DEMO地址: http://212.129.154 ...
- 带你读论文丨S&P21 Survivalism: Living-Off-The-Land 经典离地攻击
本文分享自华为云社区<[论文阅读] (21)S&P21 Survivalism: Living-Off-The-Land经典离地攻击>,作者: eastmount . 摘要 随着恶 ...
- Callback Function Essence
Include Example Input: I am a. route execute finish. I am b. route execute finish. What is Callback ...