Openstack创建镜像

时间:2021-11-04 20:53:48

如何创建生产用的Openstack镜像

参考官方文档https://docs.openstack.org/image-guide/centos-image.html

  1,创建虚拟机硬盘

qemu-img create -f qcow2 /tmp/centos.qcow2 10G

  2,创建虚拟机(没有virt-install命令使用yum -y install virt-install安装)

virt-install --virt-type kvm --name centos --ram 1024 \
--disk /tmp/centos.qcow2,format=qcow2 \
--network network=default \
--graphics vnc,listen=0.0.0.0 --noautoconsole \
--os-type=linux --os-variant=rhel7 \
--location=/tmp/CentOS-7-x86_64-Minimal-1708.iso

  PS:使用物理机作为控制节点安装的时候报 network default参数错误,把这个参数取消即可,不影响安装

  VNC客户端先准备好

  使用TightVNC连接

Openstack创建镜像

  选择支持中文,时区为亚洲上海

  分区只分一个/分区即可(设置为标准分区)

  PS:虚拟机不分swap分区因为虚拟机本来就是用硬盘创建出来的,没必要在用硬盘来做虚拟内存

Openstack创建镜像

  设置密码(以后创建的虚拟机密码均为这个)

Openstack创建镜像

  等待安装完成

Openstack创建镜像

  安装完毕点击重启,但是在该页面无法启动,需要在宿主机上面来启动

Openstack创建镜像

virsh start centos

  使用VNC登陆

  修改网卡硬配置 /etc/sysconfig/network-scripts/ifcfg-eth0

  删除不需要的配置

Openstack创建镜像

  关闭网络管理(记得首字母大写)

systemctl stop NetworkManager
systemctl disable NetworkManager

  重启网络

systemctl restart network

  PS:虚拟机没有通公网

  关闭selinux

  关闭防火墙postfix

systemctl disable firewalld
systemctl diaable postfix

  

  安装acpi或者其他需要在组件(比如生产需要配置yum源,安装一些常用的软件等)演示不安装了

  假设都安装完毕,写mate-data

  在虚拟机的/tmp/init.sh

#!/bin/bash

set_key(){
if [ ! -d /root/.ssh ]; then
mkdir -p /root/.ssh
chmod 700 /root/.ssh
fi
for ((i=1;i<=5;i++));do
if [ ! -f /root/.ssh/authorized_keys ];then
curl -f http://169.254.169.254/latest/meta-data/public-keys/0/openssh-key > /tmp/metadata-key 2>/dev/null
if [ $? -eq 0 ];then
cat /tmp/metadata-key >> /root/.ssh/authorized_keys
chmod 0600 /root/.ssh/authorized_keys
restorecon /root/.ssh/authorized_keys
rm -f /tmp/metadata-key
echo "Successfully retrieved public key from instance metadata"
echo "*****************"
echo "AUTHORIZED KEYS"
echo "*****************"
cat /root/.ssh/authorized_keys
echo "*****************"
fi
fi
done
} set_hostname(){
PRE_HOSTNAME=$(curl -s http://169.254.169.254/latest/meta-data/hostname)
DOMAIN_NAME=$(echo $PRE_HOSTNAME | awk -F '.' '{print $1}')
hostnamectl set-hostname `echo ${DOMAIN_NAME}.example.com`
} set_static_ip(){
PRE_IP=$(curl -s http://169.254.169.254/latest/meta-data/local-ipv4)
NET_FILE="/etc/sysconfig/network-scripts/ifcfg-eth0"
echo "TYPE=Ethernet" > $NET_FILE
echo "BOOTPROTO=static" >> $NET_FILE
echo "NAME=eth0" >> $NET_FILE
echo "DEVICE=eth0" >> $NET_FILE
echo "ONBOOT=yes" >> $NET_FILE
echo "IPADDR=${PRE_IP}" >> $NET_FILE
echo "NETMASK=255.255.255.0" >> $NET_FILE
echo "GATEWAY=192.168.0.1" >> $NET_FILE
} main(){
set_key;
set_hostname;
set_static_ip;
/bin/cp /tmp/rc.local /etc/rc.d/rc.local
reboot
} main

  PS:把获取key,hostname,静态ip写成3个函数,然后在main里面执行,在/tmp文件夹备份一份rc.local 设置完毕覆盖,以防虚拟机重启再次执行

  在/etc/rc.local添加

/bin/bash /tmp/init.sh

  给rc.local加执行权限(必须是/etc/rc.d/rc.local不能给/etc/rc.local加执行权限否则会不执行初始化文件需要手动执行初始化文件才能生效)

chmod +x /etc/rc.d/rc.local

  关闭镜像

shutdown -h now

  

  在控制节点操作,上传镜像

openstack image create "CentOS-7-x86_64" \
--file /tmp/centos.qcow2 \
--disk-format qcow2 --container-format bare \
--public

  删除镜像使用命令

openstack image delete CentOS-7-x86_64

  上传较慢

Openstack创建镜像

  镜像路径在/var/lib/glance/images

  使用命令查看

openstack image list

Openstack创建镜像

  使用admin登陆web界面也能看到

Openstack创建镜像

  使用新镜像创建虚拟机

  使用admin登陆web界面

  创建云主机类型

Openstack创建镜像

Openstack创建镜像

  谁能使用demo

Openstack创建镜像

  退出admin使用demo登陆

  创建云主机

Openstack创建镜像

  使用刚刚建立的源

Openstack创建镜像

  云主机类型web-node

  创建可以在node2的目录/var/lib/nova/instances/_base看到拷贝镜像

  PS:我试验中没有动静 可能和报错 构建已中止:分配网络失败,不重新调度有关

  

  重启主机可以正常创建了 但是该目录还是没有文件增加

  原来是创建在控制节点上面去了,因为控制节点也设置成了计算节点调度到上面了

  

  创建快照

Openstack创建镜像

  是一个私有快照

Openstack创建镜像