跨平台(I版到K版)迁移实践总结
rm -f /etc/udev/rules.d/-persistent-net.rules
nova stop uuid
[root@node-63~]# scp -r /var/lib/nova/instances/5e8d5d06-e3ed-4f56-b28b-7d57309e9fbb node-76:/tmp/
qemu-img convert -f raw disk -O qcow2 disk
[root@node-63~]# qemu-img info /var/lib/nova/instances/5e8d5d06-e3ed-4f56-b28b-7d57309e9fbb/disk
image:/var/lib/nova/instances/5e8d5d06-e3ed-4f56-b28b-7d57309e9fbb/disk
file format: qcow2
virtual size:50G(53687091200 bytes)
disk size:734M
cluster_size:65536
backing file:/var/lib/nova/instances/_base/c631b3cc0e8ed9b5fa4d9020995b108d50ba085f
Format specific information:
compat:1.1
lazy refcounts:false
[root@node-~]# scp /var/lib/nova/instances/_base/c631b3cc0e8ed9b5fa4d9020995b108d50ba085f node-:/tmp/5e8d5d06-e3ed-4f56-b28b-7d57309e9fbb/
source /root/openrc-xxx
nova boot <instance-name>--image <image-uuid>--flavor <flavor-id>--nic net-id=<net-uuid>,v4-fixed-ip=<fixed-ip>--security-groups
<security-groups_id> --available-zone nova:hostname
注意:
1)instance-name 需要很原来的虚拟机名称保持一致
2)image-uuid,已经在K版环境上传了I版镜像,可以直接使用:
有些镜像无法使用,创建这些镜像的虚拟机时,请用任意其他镜像代替
3)flavor,选择和以前的flavor内容一致的模板
4)net-uuid,请选择正确的网络
5)v4-fixed-ip,填写正确的ip地址,和老系统保持ip一致
6)--security-groups,填写正确的安全组
7)--available-zone ,事先规划好的目标计算节点
再次注意:
创建虚拟机时,需要使用特定租户创建,而不是用admin创建。
nova stop 41c0cc46-8afd--877b-45310f2a80b2
mv /var/lib/nova/instances/5e8d5d06-e3ed-4f56-b28b-7d57309e9fbb/disk /var/lib/nova/instances/<new-vm-uuid>/
mv /var/lib/nova/instances/5e8d5d06-e3ed-4f56-b28b-7d57309e9fbb/c631b3cc0e8ed9b5fa4d9020995b108d50ba085f /var/lib/nova/instances/_base/
nova start xxxx
1. 是否能够正常启动,重启,读写数据。
2.虚机所有信息保持与原虚机一致,包括登录密码。
3.网络可达东西南北流量正常,浮动ip可以访问。
#!/bin/bash
#:vm uuid
#:dest host
#copy instance file to remote host
set-e
if[ $# -ne ];then
echo "please inpute two parment 1:uuid and 2:dest hostip"
exit
fi
source openrc-zmg.sh
echo vm-uuid:$
echo remotehostip: $
status=`nova show $|grep "^| status"|cut -f -d "|"|sed 's/ //g'`
if["$status"="ACTIVE"];then
echo "please use [nova stop uuid] to shutoff the vm"
exit
fi
nova show $
sourcehost=`nova show $|grep "OS-EXT-SRV-ATTR:host"|cut -f -d "|"`
echo sourcehost:$sourcehost
diskfile=/var/lib/nova/instances/$
echo $diskfile
#ssh $sourcehost "sshpass -p qwe123 scp -r /var/lib/nova/instances/$1 $2:/tmp"
#echo diskfile copy complete
#sleep
#ls
#ssh $sourcehost qemu-img info /var/lib/nova/instances/"$1"/disk|grep backing|cut -d : -f |tr -d '\r'|xargs -i cp -r {} /tmp
#sleep
expect <<!
set timeout -
spawn ssh $sourcehost
expect "root@node"
send "sshpass -p qwe123 rsync -arv --progress /var/lib/nova/instances/$1 $2:/var/lib/nova/instances/tmp\r"
expect "~]#"
send "qemu-img info /var/lib/nova/instances/$1/disk|grep back|cut -d : -f 2|xargs -i sshpass -p qwe123 scp {} $2:/var/lib/nova/instances/tmp/$1\r"
expect "~]#"
send "echo copy competed!\r"
expect eof
!
xargs -n7 ./create-vm.sh <test
#!/bin/bash
set-e
if[ $# -ne ];then
echo -e "please input parament\n1:<instance-name>\n2:<image-uuid>\n3:<flavor-id>\n4:<net-uuid>\n5:<fixed-ip>\n6:<security-groups_id>\n7:hostname"
exit
fi
nova boot "$1"--image $ --flavor $ --nic net-id=$,v4-fixed-ip=$ --security-groups $ --availability-zone nova:$
sleep
uuid=`nova show "$1"|grep "^| id"|cut -f -d "|"`
nova show "$1"
#!/bin/bash
set-e
if[ $# -ne ];then
echo "please inpute two parment 1:new vm uuid and 2:old vm uuid"
exit
fi
status=`nova show $|grep "^| status"|cut -f -d "|"|sed 's/ //g'`
echo $status
if["$status"="ACTIVE"];then
echo "please use [nova stop uuid] to shutoff the vm"
exit
fi
source admin-tenant.sh
nova show $
host=`nova show $|grep "OS-EXT-SRV-ATTR:host"|cut -f -d "|"`
echo "=====VM is at:$host=============="
ssh $host mv /var/lib/nova/instances/tmp/$/disk /var/lib/nova/instances/$/
echo "========mv disk compelted===="
sleep
echo "=====check the disk time for change======== "
ssh $host ls -al /var/lib/nova/instances/$/disk
echo "disk change ok!"
sleep
nova start $
echo "========start vm==wait 30s======"
nova show $
sleep
echo "=======create 0M disk.config======="
ssh $host qemu-img create /var/lib/nova/instances/$/disk.config 0M;
ssh $host chown nova:nova /var/lib/nova/instances/$/disk.config;
echo "======check disk.config owner====== "
ssh $host ls -al /var/lib/nova/instances/$/disk.config
跨平台(I版到K版)迁移实践总结的更多相关文章
- VPGAME 的 Kubernetes 迁移实践
作者 | 伍冲斌 VPGAME 运维开发工程师 导读:VPGAME 是集赛事运营.媒体资讯.大数据分析.玩家社群.游戏周边等为一体的综合电竞服务平台.总部位于中国杭州,在上海和美国西雅图分别设立了电 ...
- VPGAME的Kubernetes迁移实践
VPGAME 是集赛事运营.媒体资讯.大数据分析.玩家社群.游戏周边等为一体的综合电竞服务平台.总部位于中国杭州,在上海和美国西雅图分别设立了电竞大数据研发中心和 AI 研发中心.本文将讲述 VPGA ...
- HTML5与CSS3基础教程(第8版) PDF扫描版
<HTML5与CSS3基础教程(第8版)>自第1版至今,一直是讲解HTML和CSS入门知识的经典畅销书,全面系统地阐述HTML5和CSS3基础知识以及实际运用技术,通过大量实例深入浅出地分 ...
- c++学习书籍推荐《清华大学计算机系列教材:数据结构(C++语言版)(第3版)》下载
百度云及其他网盘下载地址:点我 编辑推荐 <清华大学计算机系列教材:数据结构(C++语言版)(第3版)>习题解析涵盖验证型.拓展型.反思型.实践型和研究型习题,总计290余道大题.525道 ...
- Windows Server 2008 R2 官方简体中文免费企业版/标准版/数据中心版
Windows Server 2008 R2是一款微软发布的Windows服务器操作系统,和之前发布的Windows Server 2008相比功能更为完善运行更为稳定,提升了系统管理弹性.虚拟化.网 ...
- 如何做系列(4)-微博URL短网址生成算法原理(java版、php版实现实例)
短网址(Short URL),顾名思义就是在形式上比较短的网址.通常用的是asp或者php转向,在Web 2.0的今天,不得不说,这是一个潮流.目前已经有许多类似服务,借助短网址您可以用简短的网址替代 ...
- camunda开源版与商业版的差异
Camunda流程引擎分社区版和企业版,社区版实际上是开源版,是Apache2.0协议,企业版实际上是商业收费版本,需要购买授权才能使用,那么社区版和企业版的差异有哪些呢,社区版本是否能满足我们日常的 ...
- 微软发布 Windows Server 2016 预览版第三版,开发者要重点关注Nano Server
微软已经发布 Windows Server 2016 和 System Center 2016 第三个技术预览版,已经提供下载.Windows Server 2016 技术预览版第三版也是首个包括了容 ...
- 使用VNET-to-VNET连接Microsoft Azure国际版和中国版
Microsoft Azure的VNET-to-VNET功能可以实现跨虚拟网络的VPN连接,通过VNET-to-VNET互联的两个虚拟网络可以在同一个订阅下或者隶属不同的订阅,而且可以跨数据中心.这实 ...
随机推荐
- mongoDB 高级查询语法
http://www.cnblogs.com/ITAres/articles/2084794.html本文参考自官方的手册:http://www.mongodb.org/display/DOCS/Ad ...
- JDBC技术总结(二)
上一节主要讲了JDBC的基本操作,这一节主要总结一下JDBC如何处理大文本.如何处理图片以及进行批处理. 1.JDBC处理大文本 在MySQL中,大文本是text类型,使用Java操作数据库中的大文本 ...
- Ubuntu Server 命令行下显示中文乱码(菱形)解决办法
如果Ubuntu Server在安装过程中,选择的是中文(很多新手都会在安装时选择中文,便于上手),这样在完成安装后,系统默认的语言将会是中文zh_CN.UTF- 8.但问题是我们安装的是服务器,只需 ...
- Android NDK开发篇(四):Java与原生代码通信(原生方法声明与定义与数据类型)
Java与原生代码通信涉及到原生方法声明与定义.数据类型.引用数据类型操作.NIO操作.訪问域.异常处理.原生线程 1.原生方法声明与定义 关于原生方法的声明与定义在上一篇已经讲一点了,这次具体分析一 ...
- SpringCloud系列四:实现Eureka Server的高可用并将应用注册到Eureka Sever集群上
1. 回顾 上一篇博客中,实现了单节点的Eureka Server.Eureka Client会定时连接Eureka Server,获取注册表中的信息并缓存到本地.微服务在消费远程API时总是使用本地 ...
- Linux中的一个命令行计算器bc简介
假如你在一个图形桌面环境中需要一个计算器时,你可能只需要一路进行点击便可以找到一个计算器.例如,Fedora 工作站中就已经包含了一个名为 Calculator 的工具.它有着几种不同的操作模式,例如 ...
- 【HBase基础教程】1、HBase之单机模式与伪分布式模式安装(转)
在这篇blog中,我们将介绍Hbase的单机模式安装与伪分布式的安装方式,以及通过浏览器查看Hbase的用户界面.搭建hbase伪分布式环境的前提是我们已经搭建好了hadoop完全分布式环境,搭建ha ...
- ASP.NET MVC自定义视图引擎ViewEngine 创建Model的专属视图
MVC内置的视图引擎有WebForm view engine和Razor view engine,当然也可以自定义视图引擎ViewEngine. 本文想针对某个Model,自定义该Model的专属视图 ...
- 第八章 委托,lamdbda 表达式和事件
第八章 委托,lamdbda 表达式和事件 委托是寻址方式的.net版本. 委托是类型安全的类,它定义了返回类型和参数的类型.委托类不仅包含方法的应用,也可以包含对多个方法的引用. 在 C++中,函数 ...
- springboot 中使用AOP
网上关于AOP的例子好多,各种名词解释也一大堆,反正名词各种晦涩,自己写个最最最简单的例子入门mark一下,以后再深入学习. maven依赖 <dependency> <groupI ...