天天看點

雲主機遷移腳本

#!/bin/sh

#1、此腳本需要新伺服器的的root可以直接登入,root的密碼是沒有特殊字元的密碼。允許老的伺服器用scp指令向新伺服器傳送檔案。

#由于root密碼被修改成簡單密碼,是以不要停止iptables,可以在iptables裡面加入允許老伺服器的ip的22端口可以通路。

#2、為了友善檢視那些雲主機已經遷移好了,需要連接配接到新伺服器上,運作tty,檢視到tty值,把tty的結果替換腳本中的”/dev/pts/ttynum“字元。

#同時不要關閉已經打開的新的伺服器的連接配接。

#3、腳本執行完以後,背景确認一下是否全部完成。然後删除/tmp/a.sh zcc.host zcc.hostbak

#4、删除新伺服器上的/tmp/newserver.sh okhost檔案。同時把root密碼修改成老的root密碼。

#4、sh -x a.sh 新伺服器的ip 新伺服器的密碼

newip=$1;

newpasswd=$2;

if [ ! -f /tmp/newserver.sh ];then

cat >> /tmp/newserver.sh << "EOF"

       #!/bin/sh

       sed -i 's#rhel6.2.0#pc#' /vm/vm/$1/$1.xml;

       [ $? != 0 ] && exit 1;

       sed -i 's#/usr/libexec/qemu-kvm#/usr/bin/kvm#' /vm/vm/$1/$1.xml;

       [ $? != 0 ] && exit 2;

       if [ -f /vm/vm/$1/snapshot/*.xml ];then

               sed -i 's#rhel6.2.0#pc#' /vm/vm/$1/snapshot/*.xml;

               [ $? != 0 ] && exit 3;

               sed -i 's#/usr/libexec/qemu-kvm#/usr/bin/kvm#' /vm/vm/$1/snapshot/*.xml;

               [ $? != 0 ] && exit 4;

               mkdir -p /var/lib/libvirt/qemu/snapshot/$1 && cp /vm/vm/$1/snapshot/*.xml /var/lib/libvirt/qemu/snapshot/$1;

               [ $? != 0 ] && exit 5;

       fi

       virsh define /vm/vm/$1/$1.xml;

       virsh start $1;

       hostip=$(less /vm/vm/$1/$1.xml| grep value |grep -o -P '(\d{1,3}\.){3}\d{1,3}')

       if [ -n $hostip ];then

               for pingnum in $(seq 1 10);

               do

                       ping -c 2 $hostip

                       if [ $? = 0 ] ; then

                               echo `date +%F` `date +%T` $1 done  >> /tmp/okhost

                               echo =================================== > /dev/pts/ttynum

                               echo ===========$1======done======= > /dev/pts/ttynum

                               break

                       fi

                       if (( $pingnum == 6 )) ; then

                               echo `date +%F` `date +%T` $1 done  but dead ping  >> /tmp/okhost

                               echo =================================== > /dev/pts/ttynum                

               done

EOF

fi

       chmod 700 /tmp/newserver.sh

       #scp newserver.sh to newserver

       expect -c "

               spawn scp -r /tmp/newserver.sh root@$newip:/tmp/

               expect {

                       \"*assword\" {set timeout 9000; send \"$newpasswd\r\";}

                       \"yes/no\" {send \"yes\r\"; exp_continue;}

               }

       expect eof"

[ $? != 0 ] && echo "create newserver or scp wang!" && exit;

echo "create and scp newserver ok"

       if [ ! -f /tmp/zcc.host ];then

               virsh list --all | sed '1,2d' | sed '$d' | awk '{print $2}'| sort > /tmp/zcc.host

               cp /tmp/zcc.host /tmp/zcc.hostbak

       while read host

       do

               virsh destroy $host 2>/dev/null

               sleep 3

               virsh snapshot-list $host > /tmp/$$.snapshot

               snapshotname=$(grep -o -P '\d{14}' /tmp/$$.snapshot)

               rm /tmp/$$.snapshot

               if [ -n "$snapshotname" ];then

                       virsh snapshot-delete $host $snapshotname;

               fi

               virsh undefine $host

               #scp -r /vm/vm/$host [email protected]:/vm/vm/

               expect -c "

               spawn scp -r /vm/vm/$host/ root@$newip:/vm/vm/

                       expect {

                       }

               expect eof"

               if [ $? = 0 ];then

                       echo =============================

                       echo ====$host=====scp======OK====

                       mv /vm/vm/$host /vm/vm/$host.$(date +%Y-%m-%d.%H:%M:%S).drop

                       sed -i "/^$host$/d" /tmp/zcc.host

                       spawn ssh root@$newip \"nohup /tmp/newserver.sh $host\" &

                               \"*assword\" {set timeout 9000; send \"$newpasswd\r\";}

                               \"yes/no\" {send \"yes\r\"; exp_continue;}

       done < /tmp/zcc.host

本文轉自 freeterman 51CTO部落格,原文連結:http://blog.51cto.com/myunix/1202228,如需轉載請自行聯系原作者