Projet

Général

Profil

SSD » Historique » Version 4

Laurent GUERBY, 04/11/2011 23:17

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