Projet

Général

Profil

SSD » Historique » Version 6

Mehdi Abaakouk, 06/02/2012 16:28
Utilisation du iscsi-target kernelland au lieu de userland

1 3 Mehdi Abaakouk
h1. Le SSD
2 2 Mehdi Abaakouk
3 5 iku jam
{{>toc}}
4 5 iku jam
5 4 Laurent GUERBY
Afin de mettre à disposition des volumes provenant du SSD sans pour autant perdre 128 MB par volume en utilisant ganeti voici la solution adoptée.
6 3 Mehdi Abaakouk
7 4 Laurent GUERBY
Elle permet d'avoir le SSD en raid 1 réseau (drbd de ganeti) et d'utiliser les fonctionnalités de redondance sans gaspiller de l'espace SSD
8 3 Mehdi Abaakouk
9 3 Mehdi Abaakouk
Une vm ganeti en drbd qui utilise tout l'espace de 2 SSD (ie: 24G sur h5 et h6)
10 3 Mehdi Abaakouk
11 4 Laurent GUERBY
La vm créé un lvm sur son disque virtuel, puis ensuite on partage des logical volume de ce lvm via NBD, ISCSI ou AoE
12 3 Mehdi Abaakouk
13 3 Mehdi Abaakouk
Ci-dessous les éléments de configuration de ceci.
14 1 Laurent GUERBY
15 6 Mehdi Abaakouk
h1. ISCSI (Internet Small Computer Systems Interface), *recommandé*
16 6 Mehdi Abaakouk
17 6 Mehdi Abaakouk
http://en.wikipedia.org/wiki/ISCSI
18 6 Mehdi Abaakouk
19 6 Mehdi Abaakouk
h2. Installation de iscsi côté server
20 6 Mehdi Abaakouk
21 6 Mehdi Abaakouk
<pre>
22 6 Mehdi Abaakouk
apt-get install iscsitarget-dkms iscsitarget
23 6 Mehdi Abaakouk
</pre>
24 6 Mehdi Abaakouk
25 6 Mehdi Abaakouk
Dans "/etc/iet/initiators.allow" et dans "/etc/iet/targets.allow" commenter la ligne "ALL ALL"
26 6 Mehdi Abaakouk
27 6 Mehdi Abaakouk
<pre>
28 6 Mehdi Abaakouk
/etc/init.d/iscsitarget start
29 6 Mehdi Abaakouk
</pre>
30 6 Mehdi Abaakouk
31 6 Mehdi Abaakouk
h2. Configuration d'un nouveau volume réseau
32 6 Mehdi Abaakouk
33 6 Mehdi Abaakouk
h3. Configuration sur le serveur
34 6 Mehdi Abaakouk
35 6 Mehdi Abaakouk
<pre>
36 6 Mehdi Abaakouk
lvcreate -n debug-gnt-2 -L 2G vgssd
37 6 Mehdi Abaakouk
mkfs.ext4 /dev/vgssd/debug-gnt-2
38 6 Mehdi Abaakouk
# tune2fs -o discard /dev/vgssd/debug-gnt-2 # ne marche pas sur squeeze
39 6 Mehdi Abaakouk
</pre>
40 6 Mehdi Abaakouk
41 6 Mehdi Abaakouk
Dans le fichier /etc/iet/ietd.conf ajouter un "target iscsi":
42 6 Mehdi Abaakouk
43 6 Mehdi Abaakouk
<pre>
44 6 Mehdi Abaakouk
Target iqn.2012-02.net.tetaneutral:debug-gnt.disk1
45 6 Mehdi Abaakouk
        IncomingUser
46 6 Mehdi Abaakouk
        OutgoingUser
47 6 Mehdi Abaakouk
        Lun 0 Path=/dev/vgssd/debug-gnt,Type=fileio
48 6 Mehdi Abaakouk
        Alias disk1
49 6 Mehdi Abaakouk
</pre>
50 6 Mehdi Abaakouk
51 6 Mehdi Abaakouk
Dans le fichier /etc/iet/initiators.allow, autorisé la machine:
52 6 Mehdi Abaakouk
53 6 Mehdi Abaakouk
<pre>
54 6 Mehdi Abaakouk
iqn.2012-02.net.tetaneutral:nagios.disk1 91.224.149.236
55 6 Mehdi Abaakouk
</pre>
56 6 Mehdi Abaakouk
Puis on reload
57 6 Mehdi Abaakouk
<pre>
58 6 Mehdi Abaakouk
/etc/init.d/iscsitarget restart
59 6 Mehdi Abaakouk
</pre>
60 6 Mehdi Abaakouk
61 6 Mehdi Abaakouk
En iscsi, on peut aussi utiliser des login/password en plus des ip pour les ACL
62 6 Mehdi Abaakouk
63 6 Mehdi Abaakouk
h3. Configuration sur le client
64 6 Mehdi Abaakouk
65 6 Mehdi Abaakouk
66 6 Mehdi Abaakouk
<pre>
67 6 Mehdi Abaakouk
apt-get install open-iscsi
68 6 Mehdi Abaakouk
sed -i -e '/node.startup/s/manual/automatic/g' /etc/iscsi/iscsid.conf
69 6 Mehdi Abaakouk
/etc/init.d/open-iscsi start
70 6 Mehdi Abaakouk
iscsi_discovery  91.224.149.251
71 6 Mehdi Abaakouk
72 6 Mehdi Abaakouk
73 6 Mehdi Abaakouk
cat >> /etc/fstab <<EOF
74 6 Mehdi Abaakouk
/dev/sda    /myssd2     ext4    discard,noatime,_netdev     0       0
75 6 Mehdi Abaakouk
EOF
76 6 Mehdi Abaakouk
mkdir /myssd2
77 6 Mehdi Abaakouk
/etc/init.d/open-iscsi restart
78 6 Mehdi Abaakouk
</pre>
79 6 Mehdi Abaakouk
80 6 Mehdi Abaakouk
h3. Supprimer un disk iscsi
81 6 Mehdi Abaakouk
82 6 Mehdi Abaakouk
Sur le client, arrêter open-iscsi:
83 6 Mehdi Abaakouk
<pre>
84 6 Mehdi Abaakouk
/etc/init.d/open-iscsi stop
85 6 Mehdi Abaakouk
</pre>
86 6 Mehdi Abaakouk
87 6 Mehdi Abaakouk
Sur le serveur, nettoyer le fichier /etc/rc.local:
88 6 Mehdi Abaakouk
... A SUIVRE
89 6 Mehdi Abaakouk
90 2 Mehdi Abaakouk
h1. NBD (Network Block Device)
91 2 Mehdi Abaakouk
92 2 Mehdi Abaakouk
http://en.wikipedia.org/wiki/Network_block_device
93 2 Mehdi Abaakouk
94 2 Mehdi Abaakouk
h2. Installation de nbd côté serveur
95 2 Mehdi Abaakouk
96 2 Mehdi Abaakouk
<pre>
97 2 Mehdi Abaakouk
apt-get install nbd-server
98 2 Mehdi Abaakouk
echo '[general]' > /etc/nbd-server/conf
99 2 Mehdi Abaakouk
/etc/init.d/nbd-server restart
100 2 Mehdi Abaakouk
</pre>
101 1 Laurent GUERBY
102 1 Laurent GUERBY
h2. Configuration d'un nouveau volume réseau
103 2 Mehdi Abaakouk
104 4 Laurent GUERBY
h3. Configuration sur le serveur
105 4 Laurent GUERBY
106 2 Mehdi Abaakouk
<pre>
107 2 Mehdi Abaakouk
lvcreate -n debug-gnt -L 2G vgssd
108 2 Mehdi Abaakouk
mkfs.ext4 /dev/vgssd/debug-gnt
109 2 Mehdi Abaakouk
# tune2fs -o discard /dev/vgssd/debug-gnt # ne marche pas sur squeeze
110 2 Mehdi Abaakouk
</pre>
111 2 Mehdi Abaakouk
112 2 Mehdi Abaakouk
Le port est par convention pour tetaneutral :
113 2 Mehdi Abaakouk
1 + 3 last ip digit (ie: 1231 pour 91.224.149.231)
114 2 Mehdi Abaakouk
115 2 Mehdi Abaakouk
<pre>
116 2 Mehdi Abaakouk
cat >> /etc/nbd-server/conf <<EOF
117 2 Mehdi Abaakouk
[debug-gnt]
118 2 Mehdi Abaakouk
    exportname = /dev/vgssd/debug-gnt
119 2 Mehdi Abaakouk
    port = 1231
120 2 Mehdi Abaakouk
    authfile = /etc/nbd-server/allow-231
121 2 Mehdi Abaakouk
EOF
122 2 Mehdi Abaakouk
123 2 Mehdi Abaakouk
cat > /etc/nbd-server/allow-231 <<EOF
124 2 Mehdi Abaakouk
91.224.149.231
125 2 Mehdi Abaakouk
EOF
126 2 Mehdi Abaakouk
</pre>
127 2 Mehdi Abaakouk
128 2 Mehdi Abaakouk
h3. Configuration sur le client
129 2 Mehdi Abaakouk
130 2 Mehdi Abaakouk
<pre>
131 2 Mehdi Abaakouk
apt-get install nbd-client
132 2 Mehdi Abaakouk
133 2 Mehdi Abaakouk
cat > /etc/nbd-client <<EOF
134 2 Mehdi Abaakouk
KILLALL="true"
135 2 Mehdi Abaakouk
NBD_DEVICE[0]=/dev/nbd0
136 2 Mehdi Abaakouk
NBD_TYPE[0]=f
137 2 Mehdi Abaakouk
NBD_HOST[0]=ssd1
138 2 Mehdi Abaakouk
NBD_PORT[0]=1231 # < 1 + 3 last ip digit
139 2 Mehdi Abaakouk
NBD_EXTRA[0]=
140 2 Mehdi Abaakouk
EOF
141 2 Mehdi Abaakouk
142 2 Mehdi Abaakouk
mkdir /myssd1
143 2 Mehdi Abaakouk
144 2 Mehdi Abaakouk
cat >> /etc/fstab <<EOF
145 2 Mehdi Abaakouk
/dev/nbd0           /myssd      ext4    defaults,discard,noauto        0       2
146 2 Mehdi Abaakouk
EOF
147 2 Mehdi Abaakouk
148 2 Mehdi Abaakouk
/etc/init.d/nbd-client restart
149 2 Mehdi Abaakouk
mount -a
150 2 Mehdi Abaakouk
</pre>
151 2 Mehdi Abaakouk
152 1 Laurent GUERBY
153 1 Laurent GUERBY
h1. AoE (ATA over Ethernet)
154 2 Mehdi Abaakouk
155 4 Laurent GUERBY
http://en.wikipedia.org/wiki/ATA_over_Ethernet
156 4 Laurent GUERBY
157 2 Mehdi Abaakouk
h2. Installation de AoE côté serveur
158 2 Mehdi Abaakouk
159 2 Mehdi Abaakouk
<pre>
160 2 Mehdi Abaakouk
apt-get install vblade vblade-persist
161 2 Mehdi Abaakouk
</pre>
162 2 Mehdi Abaakouk
163 2 Mehdi Abaakouk
h2. Configuration d'un nouveau volume réseau
164 2 Mehdi Abaakouk
165 2 Mehdi Abaakouk
h3. Configuration sur le serveur
166 2 Mehdi Abaakouk
167 2 Mehdi Abaakouk
<pre>
168 2 Mehdi Abaakouk
lvcreate -n debug-gnt-3 -L 2G vgssd
169 2 Mehdi Abaakouk
mkfs.ext4 /dev/vgssd/debug-gnt-3
170 2 Mehdi Abaakouk
# tune2fs -o discard /dev/vgssd/debug-gnt-3 # ne marche pas sur squeeze
171 2 Mehdi Abaakouk
</pre>
172 2 Mehdi Abaakouk
173 2 Mehdi Abaakouk
<pre>
174 2 Mehdi Abaakouk
vblade-persist setup 0 0 eth0 /dev/vgssd/debug-gnt-3
175 2 Mehdi Abaakouk
vblade-persist mac 0 0 add aa:00:00:be:8f:d0 
176 2 Mehdi Abaakouk
vblade-persist auto 0 0 
177 2 Mehdi Abaakouk
vblade-persist restart 0 0
178 2 Mehdi Abaakouk
</pre> 
179 2 Mehdi Abaakouk
180 2 Mehdi Abaakouk
Le 0 0 est un identifiant unique du disque
181 2 Mehdi Abaakouk
Dans AoE les acl s'applique sur les adresses MAC
182 2 Mehdi Abaakouk
183 2 Mehdi Abaakouk
AoE communique sur la couche ethernet comme son nom l'indique
184 2 Mehdi Abaakouk
Il n'est donc pas routable
185 2 Mehdi Abaakouk
186 2 Mehdi Abaakouk
187 2 Mehdi Abaakouk
188 2 Mehdi Abaakouk
h3. Configuration sur le client
189 2 Mehdi Abaakouk
190 2 Mehdi Abaakouk
<pre>
191 2 Mehdi Abaakouk
apt-get install aoe-tools
192 2 Mehdi Abaakouk
</pre>
193 2 Mehdi Abaakouk
194 2 Mehdi Abaakouk
dans /etc/default/aoetools changer INTERFACES comme ceci:
195 2 Mehdi Abaakouk
196 2 Mehdi Abaakouk
<pre>
197 2 Mehdi Abaakouk
INTERFACES="eth0"
198 2 Mehdi Abaakouk
</pre>
199 2 Mehdi Abaakouk
200 2 Mehdi Abaakouk
<pre>
201 2 Mehdi Abaakouk
/etc/init.d/aoetools start
202 2 Mehdi Abaakouk
aoe-discover
203 2 Mehdi Abaakouk
204 2 Mehdi Abaakouk
cat >> /etc/fstab <<EOF
205 2 Mehdi Abaakouk
/dev/etherd/e0.0    /myssd2     ext4    discard,noatime,_netdev     0       0
206 2 Mehdi Abaakouk
EOF
207 2 Mehdi Abaakouk
208 2 Mehdi Abaakouk
mkdir /myssd2
209 2 Mehdi Abaakouk
210 2 Mehdi Abaakouk
/etc/init.d/aoetools restart
211 2 Mehdi Abaakouk
mount -a
212 2 Mehdi Abaakouk
</pre>
213 2 Mehdi Abaakouk
214 2 Mehdi Abaakouk
215 2 Mehdi Abaakouk
h1. Installation d'une machine SSDx
216 2 Mehdi Abaakouk
217 2 Mehdi Abaakouk
h2. Préparation du disque sur h5 et h6
218 2 Mehdi Abaakouk
219 2 Mehdi Abaakouk
<pre>
220 2 Mehdi Abaakouk
root@h5:~# fdisk /dev/sda
221 2 Mehdi Abaakouk
222 2 Mehdi Abaakouk
WARNING: DOS-compatible mode is deprecated. It's strongly recommended to
223 2 Mehdi Abaakouk
         switch off the mode (command 'c') and change display units to
224 2 Mehdi Abaakouk
         sectors (command 'u').
225 2 Mehdi Abaakouk
226 2 Mehdi Abaakouk
Command (m for help): c
227 2 Mehdi Abaakouk
DOS Compatibility flag is not set
228 2 Mehdi Abaakouk
229 2 Mehdi Abaakouk
Command (m for help): p
230 2 Mehdi Abaakouk
231 2 Mehdi Abaakouk
Disk /dev/sda: 40.0 GB, 40020664320 bytes
232 2 Mehdi Abaakouk
255 heads, 63 sectors/track, 4865 cylinders
233 2 Mehdi Abaakouk
Units = cylinders of 16065 * 512 = 8225280 bytes
234 2 Mehdi Abaakouk
Sector size (logical/physical): 512 bytes / 512 bytes
235 2 Mehdi Abaakouk
I/O size (minimum/optimal): 512 bytes / 512 bytes
236 2 Mehdi Abaakouk
Disk identifier: 0x0001def5
237 2 Mehdi Abaakouk
238 2 Mehdi Abaakouk
   Device Boot      Start         End      Blocks   Id  System
239 2 Mehdi Abaakouk
/dev/sda1   *           1        1216     9764864   83  Linux
240 2 Mehdi Abaakouk
/dev/sda2            1216        1703     3906560   82  Linux swap / Solaris
241 2 Mehdi Abaakouk
242 2 Mehdi Abaakouk
Command (m for help): n
243 2 Mehdi Abaakouk
Command action
244 2 Mehdi Abaakouk
   e   extended
245 2 Mehdi Abaakouk
   p   primary partition (1-4)
246 2 Mehdi Abaakouk
p
247 2 Mehdi Abaakouk
Partition number (1-4): 3
248 2 Mehdi Abaakouk
First cylinder (1703-4865, default 1703):
249 2 Mehdi Abaakouk
Using default value 1703
250 2 Mehdi Abaakouk
Last cylinder, +cylinders or +size{K,M,G} (1703-4865, default 4865):
251 2 Mehdi Abaakouk
Using default value 4865
252 2 Mehdi Abaakouk
253 2 Mehdi Abaakouk
Command (m for help): t
254 2 Mehdi Abaakouk
Partition number (1-4): 3
255 2 Mehdi Abaakouk
Hex code (type L to list codes): 8e
256 2 Mehdi Abaakouk
Changed system type of partition 3 to 8e (Linux LVM)
257 2 Mehdi Abaakouk
258 2 Mehdi Abaakouk
Command (m for help): w
259 2 Mehdi Abaakouk
The partition table has been altered!
260 2 Mehdi Abaakouk
</pre>
261 2 Mehdi Abaakouk
262 2 Mehdi Abaakouk
Création du lvm
263 2 Mehdi Abaakouk
264 2 Mehdi Abaakouk
<pre>
265 2 Mehdi Abaakouk
pvcreate /dev/sda3
266 2 Mehdi Abaakouk
vgcreate kvmvgssd /dev/sda3
267 2 Mehdi Abaakouk
</pre>
268 2 Mehdi Abaakouk
269 2 Mehdi Abaakouk
270 2 Mehdi Abaakouk
*Création de la vm, sur le master node (ie: h1):*
271 2 Mehdi Abaakouk
272 2 Mehdi Abaakouk
La taille du disque sera de 24680M: 24680M + 128M (drbd) = 24808M dispo sur le SSD
273 2 Mehdi Abaakouk
274 1 Laurent GUERBY
275 1 Laurent GUERBY
<pre>
276 1 Laurent GUERBY
gnt-instance add -t drbd -B memory=512,vcpus=2 --disk 0:size=24680M,vg=kvmvgssd -n h5:h6 -o debootstrap+default --no-wait-for-sync -H kvm:boot_order=cdrom,cdrom_image_path=/root/debian-6.0.3-amd64-netinst.iso ssd1
277 2 Mehdi Abaakouk
</pre>
278 2 Mehdi Abaakouk
279 4 Laurent GUERBY
Ensuite se connecter en vnc pour faire l'installation classique, uniquement SSH server est installé
280 4 Laurent GUERBY
Le FS c'est un VG appelé vgssd, puis un lv 'root' de 4G en ext4 avec l'option discard et noatime
281 1 Laurent GUERBY
282 4 Laurent GUERBY
Pour le vnc, il faut redigirer de la machine ou tourne la vm (ie: h5 pour ssd1) sur le port retourné par la commande suivante :
283 2 Mehdi Abaakouk
<pre>
284 2 Mehdi Abaakouk
gnt-instance list -o network_port ssd1
285 2 Mehdi Abaakouk
</pre>
286 2 Mehdi Abaakouk
287 2 Mehdi Abaakouk
288 4 Laurent GUERBY
*Une fois la vm installé voici la configuration à effectuer:*
289 2 Mehdi Abaakouk
Via un terminal sur la vm (en vnc toujours)
290 2 Mehdi Abaakouk
291 2 Mehdi Abaakouk
<pre>
292 2 Mehdi Abaakouk
cat >> /etc/apt/sources.list <<EOF
293 2 Mehdi Abaakouk
deb http://backports.debian.org/debian-backports squeeze-backports main
294 2 Mehdi Abaakouk
deb-src http://backports.debian.org/debian-backports squeeze-backports main
295 2 Mehdi Abaakouk
EOF
296 2 Mehdi Abaakouk
297 2 Mehdi Abaakouk
sed -i -e 's/^.*Port.*$/Port 2222/' -e 's/^[# ]*PasswordAuthentication.*$/PasswordAuthentication no/' $TARGET/etc/ssh/sshd_configentication.*$/PasswordAuthentication no/' /etc/ssh/sshd_config
298 2 Mehdi Abaakouk
299 2 Mehdi Abaakouk
cat > /etc/resolv.conf <<EOF
300 2 Mehdi Abaakouk
domain tetaneutral.net
301 2 Mehdi Abaakouk
search tetaneutral.net
302 2 Mehdi Abaakouk
nameserver 91.224.149.254
303 2 Mehdi Abaakouk
nameserver 8.8.8.8
304 2 Mehdi Abaakouk
EOF
305 2 Mehdi Abaakouk
306 2 Mehdi Abaakouk
cat >/etc/hosts <<EOF
307 2 Mehdi Abaakouk
127.0.0.1       localhost
308 2 Mehdi Abaakouk
309 2 Mehdi Abaakouk
# The following lines are desirable for IPv6 capable hosts
310 2 Mehdi Abaakouk
::1     ip6-localhost ip6-loopback
311 2 Mehdi Abaakouk
fe00::0 ip6-localnet
312 2 Mehdi Abaakouk
ff00::0 ip6-mcastprefix
313 2 Mehdi Abaakouk
ff02::1 ip6-allnodes
314 2 Mehdi Abaakouk
ff02::2 ip6-allrouters
315 2 Mehdi Abaakouk
316 2 Mehdi Abaakouk
91.224.149.251      ssd1.tetaneutral.net ssd1
317 2 Mehdi Abaakouk
2a01:6600:8081:fb00::1     ssd1.tetaneutral.net ssd1
318 2 Mehdi Abaakouk
EOF
319 2 Mehdi Abaakouk
320 2 Mehdi Abaakouk
321 2 Mehdi Abaakouk
cat > /etc/network/interfaces <<EOF
322 2 Mehdi Abaakouk
# This file describes the network interfaces available on your system
323 2 Mehdi Abaakouk
# and how to activate them. For more information, see interfaces(5).
324 2 Mehdi Abaakouk
325 2 Mehdi Abaakouk
# The loopback network interface
326 2 Mehdi Abaakouk
auto lo
327 2 Mehdi Abaakouk
iface lo inet loopback
328 2 Mehdi Abaakouk
329 2 Mehdi Abaakouk
# The primary network interface
330 2 Mehdi Abaakouk
auto eth0
331 2 Mehdi Abaakouk
iface eth0 inet static
332 2 Mehdi Abaakouk
        address 91.224.149.251
333 2 Mehdi Abaakouk
        netmask 255.255.255.0
334 2 Mehdi Abaakouk
        network 91.224.149.0
335 2 Mehdi Abaakouk
        broadcast 91.224.149.255
336 2 Mehdi Abaakouk
        gateway 91.224.149.254
337 2 Mehdi Abaakouk
338 2 Mehdi Abaakouk
iface eth0 inet6 static
339 2 Mehdi Abaakouk
   address 2a01:6600:8081:fb00::1
340 2 Mehdi Abaakouk
   netmask 56
341 2 Mehdi Abaakouk
   gateway fe80::31
342 2 Mehdi Abaakouk
EOF
343 2 Mehdi Abaakouk
344 2 Mehdi Abaakouk
cat >> /etc/default/grub <<EOF
345 2 Mehdi Abaakouk
GRUB_CMDLINE_LINUX="\$GRUB_CMDLINE_LINUX elevator=noop console=ttyS0,38400"
346 2 Mehdi Abaakouk
GRUB_TERMINAL=console
347 2 Mehdi Abaakouk
EOF
348 2 Mehdi Abaakouk
</pre>
349 2 Mehdi Abaakouk
350 2 Mehdi Abaakouk
# Décommenter cette ligne dans /etc/inittab
351 2 Mehdi Abaakouk
<pre>
352 2 Mehdi Abaakouk
T0:23:respawn:/sbin/getty -L ttyS0 9600 vt100
353 2 Mehdi Abaakouk
</pre>
354 2 Mehdi Abaakouk
355 2 Mehdi Abaakouk
<pre>
356 2 Mehdi Abaakouk
update-grub
357 2 Mehdi Abaakouk
apt-get install -t  squeeze-backports linux-image-2.6.39-bpo.2-amd64
358 2 Mehdi Abaakouk
</pre>
359 2 Mehdi Abaakouk
360 2 Mehdi Abaakouk
h1. Doc initial
361 1 Laurent GUERBY
362 1 Laurent GUERBY
http://dl.sileht.net/public/setupssdvm.txt