Projet

Général

Profil

SSD » Historique » Version 3

Mehdi Abaakouk, 04/11/2011 17:41

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