参考文档:
http://docs.openstack.org/essex/openstack-compute/admin/content/manually-creating-qcow2-images.html
https://github.com/rackerjoe/oz-image-build/blob/master/templates/CentOS60_x86_64.tdl
目前网上有许多为OpenStack制作镜像的方法,但大部分是通过命令行来创建的,其实在CentOS下有很方便的窗口程序Virual Machine Manager来为OpenStack创建镜像。接下来我以创建一个CentOS6.3镜像为例简单说明一下这个创建过程。
启动管理程序
管理程序需要以root用户登录桌面才能启动,因此首先我们需要以root用户直接或者通过vnc方式登录以图形界面方式登录到服务器,然后在终端输入virt-manager或者依次点击应用》系统工具》Virtual Machine Manager启动管理程序。当然前提是你已经安装好了管理程序,如果没有安装请通过以下命令安装
- yum install virt-manager virt-viewer
创建虚拟机
点击创建虚拟机按钮打开创建虚拟机对话框,如下图所示:
1.给要创建的虚拟机取一个名字如centos63,选择安装方式;
2.选择安装文件及操作系统类型、版本;
3.配置内存、CPU;
4.创建磁盘,这里我选择了第二项,单击Browse,然后选择New Volume创建一个7G大小的qcow2格式的磁盘,最后选择创建的磁盘文件。如下所示:
继续前进,直到完成弹出虚拟机界面,然后完成系统安装。PS:在对磁盘进行分区时,我只创建了一个root分区,没有创建boot及swap分区。
后期处理
安装完系统并重启后,安装所需要的软件,最后还需要对系统进行一些后期处理。
修改grub参数
可能是我没有创建boot或swap分区的原因,镜像上传后启动实例后,实例无法启动,报“kernel panic – not syncing: Attempted to kill init!”错误,从网上查到修改/boot/grub/grub.conf文件,在kernel项参数quiet的后面添加一个参数enforcing=0即可网址 http://www.linuxidc.com/Linux/2012-09/71176.htm 。
修改网卡配置文件
实例的MAC地址是在实例创建时由OpenStack分配的,因此我们要删除/etc/sysconfig/network-scripts/ifcfg-eth0中的MAC信息。另外OpenStack通过dhcp方式给CentOS注入ip地址,请不要给镜像配置静态ip,可通过以下命令完成这一步操作
- cat > /etc/sysconfig/network-scripts/ifcfg-eth0 <<EOF
- DEVICE=”eth0″
- BOOTPROTO=”dhcp”
- NM_CONTROLLED=”yes”
- ONBOOT=”yes”
- TYPE=”Ethernet”
- EOF
修改rc.local文件
要使实例能接受OpenStack注入的密钥文件等信息,还要修改rc.local文件,命令如下:
- cat >> /etc/rc.d/rc.local <<EOF
- if [ ! -d /root/.ssh ]; then
- mkdir -p /root/.ssh
- chmod 700 /root/.ssh
- fi
- # Fetch public key using HTTP
- ATTEMPTS=30
- FAILED=0
- while [ ! -f /root/.ssh/authorized_keys ]; do
- 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 “*****************”
- curl -f http://169.254.169.254/latest/meta-data/hostname > /tmp/metadata-hostname 2>/dev/null
- if [ $? -eq 0 ]; then
- TEMP_HOST=$(cat /tmp/metadata-hostname)
- sed -i “s/^HOSTNAME=.*$/HOSTNAME=$TEMP_HOST/g” /etc/sysconfig/network
- /bin/hostname $TEMP_HOST
- echo “Successfully retrieved hostname from instance metadata”
- echo “*****************”
- echo “HOSTNAME CONFIG”
- echo “*****************”
- cat /etc/sysconfig/network
- echo “*****************”
- else
- echo “Failed to retrieve hostname from instance metadata. This is a soft error so we’ll continue”
- fi
- rm -f /tmp/metadata-hostname
- else
- FAILED=$(($FAILED + 1))
- if [ $FAILED -ge $ATTEMPTS ]; then
- echo “Failed to retrieve public key from instance metadata after $FAILED attempts, quitting”
- break
- fi
- echo “Could not retrieve public key from instance metadata (attempt #$FAILED/$ATTEMPTS), retrying in 5 seconds…”
- sleep 5
- fi
- done
- EOF
上传镜像
到这里镜像就做好了,通过glance命令上传就是了
- glance add name=”centos63″ is_public=true container_format=ovf disk_format=qcow2 < /var/lib/libvirt/images/centos63.img