Перенос виртуальной машины на другую vg » История » Версия 5
Владимир Ипатов, 03.03.2021 22:58
1 | 1 | Владимир Ипатов | h1. Перенос виртуальной машины на другую vg |
---|---|---|---|
2 | 1 | Владимир Ипатов | |
3 | 1 | Владимир Ипатов | h2. Виртуальная машина на одном узле |
4 | 1 | Владимир Ипатов | |
5 | 1 | Владимир Ипатов | Данная операция является потенциально опасной, следует выполнять ее только при полном понимании описываемых операций и последствий. |
6 | 1 | Владимир Ипатов | Данная операция требует остановки машины на все время копирования содержимого. |
7 | 1 | Владимир Ипатов | |
8 | 1 | Владимир Ипатов | h3. Подготовка |
9 | 1 | Владимир Ипатов | |
10 | 1 | Владимир Ипатов | Получить информацию о машине: |
11 | 1 | Владимир Ипатов | <pre> |
12 | 1 | Владимир Ипатов | gnt-instance info ИМЯ |
13 | 1 | Владимир Ипатов | </pre> |
14 | 1 | Владимир Ипатов | |
15 | 1 | Владимир Ипатов | Больше всего будет интересовать информация о диске: |
16 | 1 | Владимир Ипатов | |
17 | 1 | Владимир Ипатов | Например: |
18 | 1 | Владимир Ипатов | <pre> |
19 | 1 | Владимир Ипатов | Disks: |
20 | 1 | Владимир Ипатов | - disk/0: plain, size 10.0G |
21 | 1 | Владимир Ипатов | access mode: rw |
22 | 1 | Владимир Ипатов | logical_id: xenvg/8aea288f-37ad-4cd0-8a76-1e36f4da32cb.disk0 |
23 | 1 | Владимир Ипатов | on primary: /dev/xenvg/8aea288f-37ad-4cd0-8a76-1e36f4da32cb.disk0 (253:9) |
24 | 1 | Владимир Ипатов | name: None |
25 | 1 | Владимир Ипатов | UUID: 3c7fb626-21d2-4e99-9365-6639a13456b5 |
26 | 1 | Владимир Ипатов | </pre> |
27 | 1 | Владимир Ипатов | |
28 | 1 | Владимир Ипатов | Выключить машину |
29 | 1 | Владимир Ипатов | |
30 | 1 | Владимир Ипатов | <pre> |
31 | 1 | Владимир Ипатов | gnt-instance shutdown ИМЯ |
32 | 1 | Владимир Ипатов | </pre> |
33 | 1 | Владимир Ипатов | |
34 | 1 | Владимир Ипатов | На мастер узле остановить ganeti-watcher, ganeti: |
35 | 1 | Владимир Ипатов | <pre> |
36 | 1 | Владимир Ипатов | service ganeti-watcher stop |
37 | 1 | Владимир Ипатов | service ganeti stop |
38 | 1 | Владимир Ипатов | </pre> |
39 | 1 | Владимир Ипатов | Сделать резервную копию конфига ganeti. |
40 | 1 | Владимир Ипатов | <pre> |
41 | 1 | Владимир Ипатов | cp /var/lib/ganeti/config.data ~/ |
42 | 1 | Владимир Ипатов | </pre> |
43 | 1 | Владимир Ипатов | |
44 | 1 | Владимир Ипатов | берем имя тома из информации об инстансе, после / |
45 | 1 | Владимир Ипатов | <pre> |
46 | 1 | Владимир Ипатов | в нашем случае это 8aea288f-37ad-4cd0-8a76-1e36f4da32cb.disk0 |
47 | 1 | Владимир Ипатов | </pre> |
48 | 1 | Владимир Ипатов | |
49 | 1 | Владимир Ипатов | Копируем в буфер обмена |
50 | 1 | Владимир Ипатов | |
51 | 1 | Владимир Ипатов | Также из информации об инстансе берем точный размер тома |
52 | 1 | Владимир Ипатов | |
53 | 1 | Владимир Ипатов | создаем том с таким же именем на новой vg (здесь она будет называться ssd) |
54 | 1 | Владимир Ипатов | |
55 | 1 | Владимир Ипатов | <pre> |
56 | 1 | Владимир Ипатов | lvcreate -L10G -n 8aea288f-37ad-4cd0-8a76-1e36f4da32cb.disk0 ssd |
57 | 1 | Владимир Ипатов | </pre> |
58 | 1 | Владимир Ипатов | |
59 | 1 | Владимир Ипатов | открываем файл /var/lib/ganeti/config.data, ищем по данному имени, находим блок наподобие этого (json упакован без отступов и перевода строки, читать неудобно, так что нужно пользоваться поиском по подстроке): |
60 | 1 | Владимир Ипатов | |
61 | 1 | Владимир Ипатов | <pre> |
62 | 2 | Владимир Ипатов | "disks": [{"logical_id": ["xenvg", "8aea288f-37ad-4cd0-8a76-1e36f4da32cb.disk0"], "uuid": "3c7fb626-21d2-4e99-9365-6639a13456b5", "dev_type": "plain", "params": {}, "mode": "rw", "iv_name": "disk/0", "size": 10240}] |
63 | 1 | Владимир Ипатов | </pre> |
64 | 1 | Владимир Ипатов | |
65 | 1 | Владимир Ипатов | вот указание vg и имени тома: |
66 | 1 | Владимир Ипатов | |
67 | 1 | Владимир Ипатов | <pre> |
68 | 1 | Владимир Ипатов | {"logical_id": ["xenvg", "8aea288f-37ad-4cd0-8a76-1e36f4da32cb.disk0"], |
69 | 1 | Владимир Ипатов | </pre> |
70 | 1 | Владимир Ипатов | |
71 | 1 | Владимир Ипатов | В нем меняем vg "xenvg" на "ssd" |
72 | 1 | Владимир Ипатов | |
73 | 1 | Владимир Ипатов | Сохраняем файл. |
74 | 1 | Владимир Ипатов | |
75 | 1 | Владимир Ипатов | Запускаем ганети: |
76 | 1 | Владимир Ипатов | <pre> |
77 | 1 | Владимир Ипатов | service ganeti start |
78 | 1 | Владимир Ипатов | </pre> |
79 | 1 | Владимир Ипатов | |
80 | 1 | Владимир Ипатов | Если в кластере более одного узла, то запускаем копирование конфигурации: |
81 | 1 | Владимир Ипатов | <pre> |
82 | 1 | Владимир Ипатов | gnt-cluster redist-conf |
83 | 1 | Владимир Ипатов | </pre> |
84 | 1 | Владимир Ипатов | |
85 | 1 | Владимир Ипатов | проверяем, применились ли изменения, с помощью команды info: |
86 | 1 | Владимир Ипатов | |
87 | 1 | Владимир Ипатов | <pre> |
88 | 1 | Владимир Ипатов | gnt-instance info ИМЯ |
89 | 1 | Владимир Ипатов | </pre> |
90 | 1 | Владимир Ипатов | |
91 | 1 | Владимир Ипатов | Если все в порядке, то запускаем машину и ganeti-watcher |
92 | 1 | Владимир Ипатов | <pre> |
93 | 1 | Владимир Ипатов | gnt-instance startup ИМЯ |
94 | 1 | Владимир Ипатов | service ganeti-watcher start |
95 | 1 | Владимир Ипатов | </pre> |
96 | 1 | Владимир Ипатов | |
97 | 1 | Владимир Ипатов | |
98 | 3 | Владимир Ипатов | h2. Виртуальная машина на двух узлах |
99 | 3 | Владимир Ипатов | |
100 | 3 | Владимир Ипатов | Возможны два варианта производства этой операции: с остановкой и без. |
101 | 3 | Владимир Ипатов | Вариант без остановки более сложный и трудоемкий. |
102 | 3 | Владимир Ипатов | |
103 | 3 | Владимир Ипатов | h2. Перенос с остановкой |
104 | 3 | Владимир Ипатов | |
105 | 3 | Владимир Ипатов | машину следует перед переносом остановить и перевести в plain (сделать ее машиной на одном узле): |
106 | 3 | Владимир Ипатов | |
107 | 3 | Владимир Ипатов | <pre> |
108 | 3 | Владимир Ипатов | gnt-instance shutdown ИМЯ |
109 | 3 | Владимир Ипатов | gnt-instance modify -t plain ИМЯ |
110 | 3 | Владимир Ипатов | </pre> |
111 | 3 | Владимир Ипатов | |
112 | 3 | Владимир Ипатов | После этого машина останется только на primary узле, дальнейшие операции проводятся так же, как для машины на одном узле, см. выше. |
113 | 3 | Владимир Ипатов | |
114 | 3 | Владимир Ипатов | по завершении переноса машина переводится в drbd режим: |
115 | 3 | Владимир Ипатов | |
116 | 3 | Владимир Ипатов | <pre> |
117 | 3 | Владимир Ипатов | gnt-instance modify -t drbd -n gnt2 ИМЯ |
118 | 3 | Владимир Ипатов | </pre> |
119 | 3 | Владимир Ипатов | где gnt2 - имя нового secondary узла |
120 | 3 | Владимир Ипатов | |
121 | 3 | Владимир Ипатов | h2. Перенос без остановки |
122 | 4 | Владимир Ипатов | |
123 | 4 | Владимир Ипатов | Данная операция является потенциально опасной, следует выполнять ее только при полном понимании описываемых операций и последствий. |
124 | 4 | Владимир Ипатов | |
125 | 4 | Владимир Ипатов | h3. Подготовка |
126 | 4 | Владимир Ипатов | |
127 | 4 | Владимир Ипатов | получаем информацию об инстансе, интересует то, на каком узле он запущен и информация о дисках: |
128 | 4 | Владимир Ипатов | |
129 | 4 | Владимир Ипатов | <pre> |
130 | 4 | Владимир Ипатов | gnt-instance info ИМЯ |
131 | 4 | Владимир Ипатов | </pre> |
132 | 4 | Владимир Ипатов | |
133 | 4 | Владимир Ипатов | <pre> |
134 | 4 | Владимир Ипатов | Disks: |
135 | 4 | Владимир Ипатов | - disk/0: drbd, size 10.0G |
136 | 4 | Владимир Ипатов | access mode: rw |
137 | 5 | Владимир Ипатов | nodeA: gnt2, minor=1 |
138 | 5 | Владимир Ипатов | nodeB: gnt1, minor=1 |
139 | 4 | Владимир Ипатов | port: 11001 |
140 | 4 | Владимир Ипатов | on primary: /dev/drbd1 (147:1) in sync, status ok |
141 | 5 | Владимир Ипатов | on secondary: /dev/drbd1 (147:1) in sync, status ok |
142 | 4 | Владимир Ипатов | name: None |
143 | 4 | Владимир Ипатов | UUID: 4dd153b6-f975-4c3f-a2f7-9dddbd6a3dc2 |
144 | 4 | Владимир Ипатов | child devices: |
145 | 4 | Владимир Ипатов | - child 0: plain, size 10.0G |
146 | 5 | Владимир Ипатов | logical_id: ssd/590d122d-57bb-4a3d-a6d4-95542d42cf26.disk0_data |
147 | 4 | Владимир Ипатов | on primary: /dev/ssd/590d122d-57bb-4a3d-a6d4-95542d42cf26.disk0_data (253:4) |
148 | 4 | Владимир Ипатов | on secondary: /dev/ssd/590d122d-57bb-4a3d-a6d4-95542d42cf26.disk0_data (253:4) |
149 | 4 | Владимир Ипатов | name: None |
150 | 4 | Владимир Ипатов | UUID: 4a24c9fb-cd8e-4034-b908-18d3d83c246d |
151 | 4 | Владимир Ипатов | - child 1: plain, size 128M |
152 | 4 | Владимир Ипатов | logical_id: ssd/590d122d-57bb-4a3d-a6d4-95542d42cf26.disk0_meta |
153 | 4 | Владимир Ипатов | on primary: /dev/ssd/590d122d-57bb-4a3d-a6d4-95542d42cf26.disk0_meta (253:5) |
154 | 1 | Владимир Ипатов | on secondary: /dev/ssd/590d122d-57bb-4a3d-a6d4-95542d42cf26.disk0_meta (253:5) |
155 | 1 | Владимир Ипатов | name: None |
156 | 1 | Владимир Ипатов | UUID: 37dc4222-a29a-42d0-a1a5-3e2c9b0aec8a |
157 | 1 | Владимир Ипатов | |
158 | 5 | Владимир Ипатов | </pre> |
159 | 5 | Владимир Ипатов | |
160 | 5 | Владимир Ипатов | Итак, мы видим, что машина запущена на gnt2, устройство /dev/drbd1, lvm том /dev/ssd/590d122d-57bb-4a3d-a6d4-95542d42cf26.disk0_data |
161 | 5 | Владимир Ипатов | |
162 | 5 | Владимир Ипатов | Далее, нужно запустить мастер на узле, который является *SECONDARY* для виртуальной машины, заходим на него и gnt-cluster master-failover |
163 | 5 | Владимир Ипатов | |
164 | 5 | Владимир Ипатов | затем останавливаем ganeti-watcher НА ОБОИХ узлах: |
165 | 5 | Владимир Ипатов | <pre> |
166 | 5 | Владимир Ипатов | service ganeti-watcher stop |
167 | 5 | Владимир Ипатов | </pre> |
168 | 5 | Владимир Ипатов | |
169 | 5 | Владимир Ипатов | Далее, переходим на узел, где машина secondary (в нашем случае это мастер, gnt1) |
170 | 5 | Владимир Ипатов | |
171 | 5 | Владимир Ипатов | Далее, нужно отцепить drbd от текущего тома старой vg: |
172 | 5 | Владимир Ипатов | <pre> |
173 | 5 | Владимир Ипатов | drbdsetup resource1 down |
174 | 5 | Владимир Ипатов | </pre> |
175 | 5 | Владимир Ипатов | где resource1 - это аналог /dev/drbd1 |
176 | 5 | Владимир Ипатов | |
177 | 5 | Владимир Ипатов | Переименовываем том в старой vg, а также это будет наш бэкап: |
178 | 5 | Владимир Ипатов | <pre> |
179 | 5 | Владимир Ипатов | lvrename ssd 590d122d-57bb-4a3d-a6d4-95542d42cf26.disk0_data gate-disk0 |
180 | 5 | Владимир Ипатов | </pre> |
181 | 5 | Владимир Ипатов | |
182 | 5 | Владимир Ипатов | затем заново активируем drbd: |
183 | 5 | Владимир Ипатов | <pre> |
184 | 5 | Владимир Ипатов | gnt-instance activate-disks ИМЯ |
185 | 5 | Владимир Ипатов | </pre> |
186 | 5 | Владимир Ипатов | |
187 | 5 | Владимир Ипатов | после этого проверяем, что диск проиницализировался заново и он считается Diskless, запускаем команду drbd-overview: |
188 | 5 | Владимир Ипатов | <pre> |
189 | 5 | Владимир Ипатов | 1:??not-found?? Connected Secondary/Primary Diskless/UpToDate |
190 | 5 | Владимир Ипатов | </pre> |
191 | 5 | Владимир Ипатов | |
192 | 5 | Владимир Ипатов | затем останавливаем ganeti на мастере, делаем резервную копию конфига |
193 | 5 | Владимир Ипатов | <pre> |
194 | 5 | Владимир Ипатов | service ganeti stop |
195 | 5 | Владимир Ипатов | cp /var/lib/ganeti/config.data ~ |
196 | 5 | Владимир Ипатов | </pre> |
197 | 5 | Владимир Ипатов | |
198 | 5 | Владимир Ипатов | открываем конфиг, находим по имени тома секцию конфига, относящуюся к диску (там json без отступов и переводов строки, так что пользуемся поиском по подстроке): |
199 | 5 | Владимир Ипатов | <pre> |
200 | 5 | Владимир Ипатов | [{"logical_id": ["8db85567-d4d7-427d-916e-382ab6d9448b", "05ddeac2-8a00-42a5-bf8c-68a440d29d49", 11001, 1, 1, "6adc50aa8fda95beb7b1565c3eb2fd688a9e8a47"], "uuid": "4dd153b6-f975-4c3f-a2f7-9dddbd6a3dc2", "dev_type": "drbd", "params": {}, "mode": "rw", "children": [{"dev_type": "plain", "logical_id": ["ssd", "590d122d-57bb-4a3d-a6d4-95542d42cf26.disk0_data"], "params": {}, "uuid": "4a24c9fb-cd8e-4034-b908-18d3d83c246d", "size": 10240}, {"dev_type": "plain", "logical_id": ["ssd", "590d122d-57bb-4a3d-a6d4-95542d42cf26.disk0_meta"], |
201 | 5 | Владимир Ипатов | </pre> |
202 | 5 | Владимир Ипатов | нас интересует то, что относится к _data, не _meta: |
203 | 5 | Владимир Ипатов | <pre> |
204 | 5 | Владимир Ипатов | {"dev_type": "plain", "logical_id": ["ssd", "590d122d-57bb-4a3d-a6d4-95542d42cf26.disk0_data"], "params": {}, "uuid": "4a24c9fb-cd8e-4034-b908-18d3d83c246d", "size": 10240} |
205 | 5 | Владимир Ипатов | </pre> |
206 | 5 | Владимир Ипатов | меняем в конфиге имя vg на новую (вместо "ssd" - "xenvg"), только для _data, не для _meta |
207 | 5 | Владимир Ипатов | сохраняем конфиг |
208 | 5 | Владимир Ипатов | |
209 | 5 | Владимир Ипатов | затем, на узле, где машина сейчас запущена (т.е. не на том, который сейчас мастер и где мы сейчас редактировали конфиг), создаем том в новой vg. |
210 | 5 | Владимир Ипатов | В нашем примере это узел gnt2. |
211 | 5 | Владимир Ипатов | <pre> |
212 | 5 | Владимир Ипатов | lvcreate -L10G -n 590d122d-57bb-4a3d-a6d4-95542d42cf26.disk0_data xenvg |
213 | 4 | Владимир Ипатов | </pre> |