このエントリーをはてなブックマークに追加

2.1.1.4.4.3.10. Ubuntu11.10

2.1.1.4.4.3.10.1. テンプレート作成

インストールするOSのテンプレートを作成します。
パッケージのインストールやrootのパスワードは適宜変更して下さい。
AMIなどにするつもりがなければpublic keyの部分も必要ないでしょう。
$ mkdir /etc/oz
$ cat << 'TEMPLATE' | sudo tee /etc/oz/ubuntu11.10.tdl > /dev/null
   <template>
 <name>ubuntu-oneiric_x86_64</name>
 <description>Ubuntu 11.10</description>
 <disksize>10</disksize>
 <os>
  <name>Ubuntu</name>
  <version>11.10</version>
  <arch>x86_64</arch>
  <install type='iso'>
    <iso>http://releases.ubuntu.com/11.10/ubuntu-11.10-server-amd64.iso</iso>
  </install>
 </os>
 <commands>
   <command name='console'>
sed -i 's/splash//g' /etc/default/grub
sed -i 's/quiet/console=ttyS0/g' /etc/default/grub
/usr/sbin/update-grub
   </command>
   <command name='update'>
apt-get update
apt-get -y upgrade
apt-get -y install openssh-client
ln -s /etc/init/ssh.conf /etc/init.d/ssh
echo "cloud-init cloud-init/datasources string NoCloud, ConfigDrive, OVF, MAAS, Ec2" > /tmp/debconf-selections
/usr/bin/debconf-set-selections /tmp/debconf-selections
rm -f /tmp/debconf-selections
apt-get -y install cloud-init
apt-get clean
/usr/sbin/useradd -m stack -s /bin/bash
echo "stack ALL=(ALL) NOPASSWD: ALL" >> /etc/sudoers
sed -i 's/^user: ubuntu/user: stack/g' /etc/cloud/cloud.cfg
echo -n > /etc/udev/rules.d/70-persistent-net.rules
echo -n > /lib/udev/rules.d/75-persistent-net-generator.rules
   </command>
   <command name='setup-rc-local'>
cat >> /etc/rc.local &lt;&lt; EOF
if [ ! -d /stack/.ssh ]; then
  mkdir -p /stack/.ssh
  chmod 700 /stack/.ssh
fi
# Fetch public key using HTTP
ATTEMPTS=10
while [ ! -f /stack/.ssh/authorized_keys ]; do
    curl -f http://169.254.169.254/latest/meta-data/public-keys/0/openssh-key > /tmp/aws-key 2>/dev/null
    if [ \$? -eq 0 ]; then
        cat /tmp/aws-key >> /stack/.ssh/authorized_keys
        chmod 0600 /stack/.ssh/authorized_keys
        restorecon /stack/.ssh/authorized_keys
        rm -f /tmp/aws-key
        echo "Successfully retrieved AWS public key from instance metadata"
    else
        FAILED=\$((\$FAILED + 1))
        if [ \$FAILED -ge \$ATTEMPTS ]; then
            echo "Failed to retrieve AWS public key after \$FAILED attempts, quitting"
            break
        fi
        echo "Could not retrieve AWS public key (attempt #\$FAILED/\$ATTEMPTS), retrying in 5 seconds..."
        sleep 5
    fi
done
EOF
   </command>
 </commands>
</template>
TEMPLATE

2.1.1.4.4.3.10.2. 仮想イメージの作成

OSの仮想イメージを作成します。

$ oz-install -d4 -u -t 3000 /etc/oz/ubuntu11.10.tdl

2.1.1.4.4.3.10.3. OpenStackへの登録

OpenStackに登録とかしなくてもKVMなどでちゃんと利用可能です。

2.1.1.4.4.3.10.3.1. イメージの登録(無圧縮)

OpenStackへの登録はcontainer_formatをbare、disk_formatはrawを設定して行います。
$ glance image-create --name "name=ubuntu11.10" --disk-format=raw --container-format=bare --is-public=true < /var/lib/libvirt/images/ubuntu11.10_x86_64.dsk

ディスクフォーマットをqcow2にして更に圧縮する場合は以下のコマンドで行います。約30分の1のサイズになりました。

$ qemu-img convert -O qcow2 -c /var/lib/libvirt/images/ubuntu11.10_x86_64.dsk /var/lib/libvirt/images/ubuntu11.10_x86_64.qcow2

2.1.1.4.4.3.10.3.2. イメージの登録(圧縮)

圧縮した場合はcontainer_formatをovf、disk_formatはqcow2を設定して行います。

$ glance image-create --name "ubuntu11.10" --disk-format=qcow2 --container-format=ovf --is-public=true < /var/lib/libvirt/images/ubuntu11.10_x86_64.qcow2

2.1.1.4.4.3.10.3.3. イメージからインスタンスを起動

$ nova boot --flavor 1 --image ubuntu11.10 ubuntu1110_001 --key_name mykey

2.1.1.4.4.3.10.3.4. インスタンスへログイン

$ ssh -i /home/stack/mykey root@10.0.0.4