#!/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,如需轉載請自行聯系原作者