openstack制作镜像

centos命令行制作镜像:(常用命令 glance index;glance image-delete id)

安装qemu-kvm,yum install -y kvm

1.qemu-img create -f qcow2 centos32.img 10G 

2.virt-install -n centos -f centos32.img -s 10 -r 1024 -v --vcpus=2 --vnc --cdrom=CentOS-6.3-i386-minimal.iso

3.glance -v add name='centos32' is_public=true container_format=ovf disk_format=qcow2<centos32.img

centos图像界面制作镜像:

目前网上有许多为OpenStack制作镜像的方法,但大部分是通过命令行来创建的,其实在CentOS下有很方便的窗口程序Virual Machine Manager来为OpenStack创建镜像。接下来我以创建一个CentOS6.3镜像为例简单说明一下这个创建过程。

启动管理程序

管理程序需要以root用户登录桌面才能启动,因此首先我们需要以root用户直接或者通过vnc方式登录以图形界面方式登录到服务器,然后在终端输入virt-manager或者依次点击应用》系统工具》Virtual Machine Manager启动管理程序。当然前提是你已经安装好了管理程序,如果没有安装请通过以下命令安装

yum install virt-manager virt-viewer创建虚拟机
问题1:
        warning: KVM is noit available. This may mean the KVM package is not installed, or the KVM kernel modules are not loaded. Your virtual machines may perform poorly
解决:服务器不支持虚拟化,查看egrep 'svm|vmx' /proc/cpuinfo,进BIOS开启处理器的虚拟化支持
问题2:
dnsmasq: failed to open pidfile /var/run/libvirt/network/default.pid: Permission denied
解决:yum updata selinux-policy.noarch
          service libvirtd restart

点击创建虚拟机按钮打开创建虚拟机对话框,如下图所示:

openstack制作镜像

1.给要创建的虚拟机取一个名字如centos63,选择安装方式;
2.选择安装文件及操作系统类型、版本;
3.配置内存、CPU;
4.创建磁盘,这里我选择了第二项,单击Browse,然后选择New Volume创建一个7G大小的qcow2格式的磁盘,最后选择创建的磁盘文件。如下所示:
openstack制作镜像

继续前进,直到完成弹出虚拟机界面,然后完成系统安装。PS:在对磁盘进行分区时,我只创建了一个root分区,没有创建boot及swap分区。后期处理

安装完系统并重启后,安装所需要的软件,最后还需要对系统进行一些后期处理。

修改grub参数

如果不修改grub,镜像上传后启动实例后,实例无法启动,报“kernel panic - not syncing: Attempted to kill init!”错误,方法一:从网上查到修改/boot/grub/grub.conf文件,在kernel项参数quiet的后面添加一个参数enforcing=0即可网址。方法二:参考文档https://github.com/rackerjoe/oz-image-build/blob/master/templates/centos60_x86_64.tdl运行以下命令:

sed -i 's/ rhgb//g' /boot/grub/grub.confsed -i 's/ quiet//g' /boot/grub/grub.conf

 

修改网卡配置文件

实例的MAC地址是在实例创建时由OpenStack分配的,因此我们要删除/etc/sysconfig/network-scripts/ifcfg-eth0中的MAC信息。另外OpenStack通过dhcp方式给CentOS注入ip地址,请不要给镜像配置静态ip,可通过以下命令完成这一步操作

cat > /etc/sysconfig/network-scripts/ifcfg-eth0 <<EOFDEVICE="eth0"BOOTPROTO="dhcp"NM_CONTROLLED="yes"ONBOOT="yes"TYPE="Ethernet"EOF修改rc.local文件

 

要使实例能接受OpenStack注入的密钥文件等信息,还要修改rc.local文件,命令如下:

cat >> /etc/rc.d/rc.local <<EOFif [ ! -d /root/.ssh ]; then mkdir -p /root/.ssh chmod 700 /root/.sshfi # Fetch public key using HTTPATTEMPTS=30FAILED=0while [ ! -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 fidoneEOF

 

到这里镜像就做好了,关闭虚拟机,通过glance命令上传就是了

glance add name="centos63" is_public=true container_format=ovf disk_format=qcow2 < /var/lib/libvirt/images/centos63.img

转载于:https://my.oschina.net/OQKuDOtsbYT2/blog/119979

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值