- 积分
- 16843
在线时间 小时
最后登录1970-1-1
|

楼主 |
发表于 2021-9-10 16:49:47
|
显示全部楼层
热迁移
) S/ k+ @. _& L2 c% T# N- K& u/ `* `3 e( K
热迁移(Live Migration,又叫动态迁移、实时迁移),即虚拟机保存/恢复(Save/Restore):将整个虚拟机的运行状态完整保存下来,同时可以快速的恢复到原有硬件平台甚至是不同硬件平台上。恢复以后,虚拟机仍旧平滑运行,用户不会察觉到任何差异。 Q9 [1 Q7 O: A( ^4 ?0 a. y" A# [# I+ w
% n9 f. R. u/ C1 ropenstack热迁移
. q* N5 |1 }3 k# ^' W {4 \. P% |2 Z
OpenStack有两种在线迁移类型:live migration和block migration。Livemigration需要实例保存在NFS共享存储中,这种迁移主要是实例的内存状态的迁移,速度应该会很快。Block migration除了实例内存状态要迁移外,还得迁移磁盘文件,速度会慢些,但是它不要求实例存储在共享文件系统中。# F* I$ `4 T; I/ V V
* NFS允许一个系统在网络上与他人共享目录和文件。通过使用NFS,用户和程序可以像访问本地文件一样访问远端系统上的文件。, [" v" K4 `% S7 t0 \* H4 p6 i
$ r5 f% ?0 d+ z2 e/ l. P. v( J0 M& Z! I! Z* ` g6 ?$ P
Live Migration 的实现) o) K& {0 O1 V1 g; C/ P1 ]
9 W! y- B' T2 B6 ]' v1.机器:) Y. U' x! `6 ]( N9 p
jovi-controller 是控制节点 192.168.3.108 g4 C2 x) w9 l' E/ j; J2 U! _
jovi-compute1 是计算节点 192.168.3.12
! z1 m+ W6 K2 w( ]$ B# w$ `/ ~! f' jjovi-compute3 是计算节点 192.168.3.14
) [) b, X. g$ d2 `实验阶段,为了避免不必要的麻烦,请用命令service ufw stop关闭各个节点的防火墙,同时修改/etc/hosts文件,确定节点之间能互相ping通主机名。利用id nova命令查看下控制节点nova的uid和gid,并记录,在两个计算节点同样利用id nova查看uid和gid是否和控制节点保持一致,如果不一致则利用usermod -u 控制节点的uid nova和gropumod -g 控制节点的gid nova 两条命令进行修改,同时在所有计算节点运行如下命令,保证所有nova相关文件使用新的uid和gid
5 r7 U* x4 h( M; D+ o+ u[root@vmcom1-mn ~]#service nova-api stop! c5 K8 ~: F, h0 I# k
[root@vmcom1-mn ~]#service libvirt-bin stop
# N7 z7 x( y+ ^9 ]" j[root@vmcom1-mn ~]#find / -uid 106 -exec chown nova {} \; # note the 106 here is the old nova uid before the change
1 ^. K& M1 P/ Y5 ]- N+ C' M$ ~[root@vmcom1-mn ~]# find / -gid 107 -exec chgrp nova {} \; #note the 107 here is the old nova uid before the change
, S9 ]* r* \3 I/ r1 k" y[root@vmcom1-mn ~]#service nova-api restart% k* M$ G/ D) I$ m) X
[root@vmcom1-mn ~]#service libvirt-bin restart
4 h* b4 M: u7 x. e6 }) W, [" j4 N( V- \6 R7 n
2.修改各个节点的nova.conf
( z9 W( X$ M% ^( d: wvncserver_proxyclient_address=本机ip
4 ?; ~" y" Y) g2 c8 U3 vvncserver_listen=0.0.0.0
! ^+ M. ~ Y9 ^3 s: Z& R
) T4 P" S6 c) ]# U+ `3.控制节点,配置nfs$ W/ ?+ ~* x) E% u- q3 m0 N
- {- Y+ a- D& x7 ]' sapt-get install nfs-kernel-server portmap/ @- V, e* [9 D' M$ ^. G
在/etc/exports中加入/var/lib/nova/instances *(rw,sync,fsid=0,no_root_squash)
" L: D9 _% Q( \$ s( V3 U& n2 F重新启动nfs服务,portmap服务
! ]8 \+ x0 ~& V: L5 G
$ k' ?: C$ [( c' i* D! l! h4.计算节点,配置nfs和挂载
% [% w! k9 b y6 E9 r; [6 l& N u% A/ q
apt-get install nfs-common portmap2 s6 f& X0 w8 ^2 Z% \
chmod o+x /var/lib/nova/instances,确保节点有执行和查找目录的权限1 ~# q" u' v; t: q8 o
在计算节点的/etc/fstab的目录中加入! W' ?8 X/ G" H* x
控制节点ip:/var/lib/nova/instances /var/lib/nova/instances nfs defaults 0 07 s5 P) @" l5 ^0 p' x4 [) d
挂载目录,执行
' R8 r0 g/ q9 b( mmount -a -v
3 B9 H& @& w' ~4 F7 Z Mdf -k 查看已挂在目录,可以在最后看到远程控制节点的目录已被挂在
; k; P" [ _* M/ x# i4 u( q! U4 j
% ?4 d) h# O B6 }; h( G5.修改计算节点的相关的四个配置文件,可以手工如下修改; w8 [4 _' E6 \! a: M2 N* N% [
; i3 \9 _% Y8 Z% g, ~, ^
附修改脚本:4 D8 p6 e- K' l5 f+ W
sed -i '/vncserver_proxyclient_address/d' /etc/nova/nova.conf
F# x. G5 ?4 s9 U+ R) e. {sed -i '/vncserver_listen/d' /etc/nova/nova.conf
5 z/ h0 `# G9 Y3 \. i' V3 zsed -i '$a\vncserver_listen=0.0.0.0' /etc/nova/nova.conf, I$ ~1 F# d- t* N8 N" D" [
sed -i 's/#listen_tls = 0/listen_tls = 0/g' /etc/libvirt/libvirtd.conf
$ L- @( q% K* m; D/ M$ Q" Gsed -i 's/#listen_tcp = 1/listen_tcp = 1/g' /etc/libvirt/libvirtd.conf: F4 L4 M% k! V3 W" m4 L1 f% ?
sed -i '$a\auth_tcp="none"' /etc/libvirt/libvirtd.conf1 J p2 O; I5 P. u [3 Y/ N" G) E
sed -i 's/env libvirtd_opts="-d "/env libvirtd_opts="-d -l"/g' /etc/init/libvirt-bin.conf7 P4 `: L! Z5 `1 S7 J# |
sed -i 's/libvirtd_opts=" -d"/libvirtd_opts=" -d -l"/g' /etc/default/libvirt-bin6 P* k9 V1 F4 F' z
sed -i 's/#vnc_listen = “0.0.0.0″/vnc_listen = “0.0.0.0″/g' /etc/libvirt/qemu.conf
1 k& q0 @) ~7 K% psed -i 's/#user = "root"/user = "root"/g' /etc/libvirt/qemu.conf% p( o2 X+ N0 j5 ]! i8 S& _! Q
sed -i 's/#group = "root"/group = "root"/g' /etc/libvirt/qemu.conf
* s( K# w1 _4 D4 f2 c! Z: S# |5 h
+ p6 w; b! Q+ {
3 k' \$ e/ x6 @4 m$ x6.重新启动libvirt-bin
: F3 d# |' F( H6 C
: D* O) {) U' y$ dservice libvirt-bin restart% f- S* n* L Y
确定进程已启动。( ], ^9 \2 G; `' g
ps -ef | grep libvirt
7 a" U: s/ [& Z7 s' D: p确定有libvirtd -d -l进程存在
6 t0 V! w1 B" |* r; Aroot 5277 1 004:06 ? 00:00:01/usr/sbin/libvirtd -d -l, z; C/ i# M$ J* ?" Q/ \( E2 g
1 o9 R; Q9 @$ X' h* v% f8 Y7.重新启动nova-compute服务,portmap服务
) F% X( y$ i9 ?* m6 d" _
2 z/ k8 o. C' ~service nova-compute restart
& p+ u$ \) N+ C) |; I$ r+ b2 f8 Iservice portmap restart
5 @3 W4 z5 G4 D; D; T; R0 n+ y' Q( @# l8 K4 F3 S" w
8.测试
7 a7 m! t2 I1 O4 e$ Y
$ g- Z% d1 h8 ^ Y1 ?9 b9 Qroot@jovi-controller:~# nova list 查看实例$ p& z) M4 }* N- p" T& y
root@jovi-controller:~# nova show 11fd9622-a948-4cdb-94d0-d8f2558cf179 查看需要迁移的实例0 J# h4 P. n* p2 q9 ]1 Y% L
root@jovi-controller:~# nova-manage service list查看可用的计算节点* V- ^. |' x2 S- G |1 \- X- A3 g8 o
root@jovi-controller:~# nova-manage service describe_resource compute-node2查看目标节点资源
k) r+ e% }8 w3 x% Z3 \+ Kroot@jovi-controller:~#nova live-migration 11fd9622-a948-4cdb-94d0-d8f2558cf179 jovi-compute3 迁移成功,应该没有输出。3 t8 g: R9 d/ U8 S& E2 Q
9 ~% c9 Z L. }+ C0 E相关问题的总结:
3 D/ X' m! I3 q" j! C# J" @
2 u# |) M5 I- v; h: Z部署过程中曾遇到两个导致无法迁移成功的错误,一个是在日志文件中发现cpu info incapable,另外一个问题是在日志文件中发现failed to connect remote host uri,经过与最后实验成功的环境相对照,发现实际上导致这两个问题的最终原因是计算节点的计算资源不匹配,例如之前失败的情况是compute1节点 cpu 4核心,8g内存,compute3节点 cpu 2核心,内存4g,所以提示出现上述错误。
, h9 u) w' d% U) `. p
4 p1 z0 a) G; Q5 _" N% O4 U8 i2 I本质是因为在openstack源码中,有一段针对热迁移时节点计算资源检测的函数,该函数的作用检测迁移的源节点和目的节点的计算资源是否匹配,从而判断能否承载实例的运行。% j* m: v) @2 l8 S4 D5 q
# b0 y5 U8 y( a. o" _9 s! @8 P N8 L因此后来将两个计算节点都调整为双核,4g内存,按之前方案配置后,即可成功实现迁移。
& q& ]+ r6 w4 y( N+ A9 x! C1 `- W$ k0 s6 n% m
另外网上的部署方案都提到了要修改nova.conf中vncserver_proxyclient_address=127.0.0.1,笔者经过测试,这这种方法只适用于单网卡的计算节点,多网卡情况下应该注意填写的是与控制节点以及其他计算节点互联网口的ip,这样dashboard中的vnc才可以成功运行,否则会提示faild to connect to server错误。 |
|