Este tutorial muestra cómo configurar un servidor de almacenamiento independiente en Debian Wheezy. En lugar de NFS, usaré GlusterFS aquí. El sistema cliente podrá acceder al almacenamiento como si fuera un sistema de archivos local. GlusterFS es un sistema de archivos en clúster capaz de escalar a varios peta-bytes. Agrega varios bloques de almacenamiento sobre la interconexión Infiniband RDMA o TCP/IP en un gran sistema de archivos de red paralelo. Los bloques de almacenamiento se pueden fabricar con cualquier hardware básico, como servidores x86_64 con SATA-II RAID e Infiniband HBA.
Ambos sistemas deberían poder resolver el nombre de host del otro sistema. Si esto no se puede hacer a través de DNS, debe editar el archivo /etc/hosts para que tenga el siguiente aspecto en ambos sistemas:
127.0.0.1 localhost.localdomain localhost
192.168.0.100 server1.example.com server1
192.168.0.101 client1.example.com client1
# The following lines are desirable for IPv6 capable hosts
::1 localhost ip6-localhost ip6-loopback
fe00::0 ip6-localnet
ff00::0 ip6-mcastprefix
ff02::1 ip6-allnodes
ff02::2 ip6-allrouters |
(También es posible usar direcciones IP en lugar de nombres de host en la siguiente configuración. Si prefiere usar direcciones IP, no tiene que preocuparse por si los nombres de host se pueden resolver o no).
2 Configuración del servidor GlusterFS
servidor1.ejemplo.com:
GlusterFS está disponible como paquete para Debian Wheezy, por lo que podemos instalarlo de la siguiente manera:
apt-get install glusterfs-server
El comando
glusterfsd --version
ahora debería mostrar la versión de GlusterFS que acaba de instalar (3.2.7 en este caso):
[email protected]:~# glusterfsd --version
glusterfs 3.2.7 compilado el 12 de noviembre de 2012 19:30:08
Revisión del repositorio:git://git.gluster.com/glusterfs.git
Copyright (c) 2006-2011 Gluster Inc.
GlusterFS viene SIN NINGUNA GARANTÍA EN ABSOLUTO.
Usted puede redistribuir copias de GlusterFS bajo los términos del Licencia pública general de GNU.
[email protected]:~#
Si usa un firewall, asegúrese de que los puertos TCP 111, 24007, 24008, 24009-(24009 + número de ladrillos en todos los volúmenes) estén abiertos en server1.example.com.
A continuación, creamos el recurso compartido denominado testvol en localhost (=server1) en el directorio /data (se creará si no existe):
gluster volume create testvol server1.example.com:/data
[email protected]:~# gluster volume create testvol server1.example.com:/data
La creación del volumen testvol se ha realizado correctamente. Inicie el volumen para acceder a los datos.
[email protected]:~#
Iniciar el volumen:
gluster volume start testvol
Es posible que el comando anterior le indique que la acción no tuvo éxito:
[email protected]:~# gluster volume start testvol
La prueba de volumen inicial no ha tenido éxito
[email protected]:~#
Puede verificar el estado del volumen con el comando
gluster volume info
[email protected]:~# gluster volume info
Nombre del volumen:testvol
Tipo:Distribuir
Estado:Iniciado
Número de ladrillos:1
Tipo de transporte:tcp
Bricks:
Brick1:servidor1. ejemplo.com:/datos
[correo electrónico protegido]:~#
Si te dice que el volumen se inició, todo está bien, de lo contrario, vuelve a iniciarlo.
De forma predeterminada, todos los clientes pueden conectarse al volumen. Si desea otorgar acceso únicamente a client1.example.com (=192.168.0.101), ejecute:
gluster volume set testvol auth.allow 192.168.0.101
Tenga en cuenta que es posible utilizar comodines para las direcciones IP (como 192.168.*) y que puede especificar varias direcciones IP separadas por comas (por ejemplo, 192.168.0.101,192.168.0.102).
La información del volumen ahora debería mostrar el estado actualizado:
gluster volume info
[email protected]:~# gluster volume info
Nombre del volumen:testvol
Tipo:Distribuir
Estado:Iniciado
Número de ladrillos:1
Tipo de transporte:tcp
Bricks:
Brick1:servidor1. ejemplo.com:/datos
Opciones reconfiguradas:
auth.allow:192.168.0.101
[email protected]:~#
3 Configuración del cliente GlusterFS
cliente1.ejemplo.com:
En el cliente, podemos instalar el cliente GlusterFS de la siguiente manera:
apt-get install glusterfs-client
Luego creamos el siguiente directorio:
mkdir /mnt/glusterfs
¡Eso es todo! Ahora podemos montar el sistema de archivos GlusterFS en /mnt/glusterfs con el siguiente comando:
mount.glusterfs server1.example.com:/testvol /mnt/glusterfs
Ahora debería ver el nuevo recurso compartido en los resultados de...
mount
[email protected]:~# mount
sysfs en /sys tipo sysfs (rw,nosuid,nodev,noexec,relatime)
proc en /proc tipo proc (rw,nosuid,nodev,noexec,relatime)
udev en /dev escriba devtmpfs (rw,relatime,size=10240k,nr_inodes=126813,mode=755)
devpts en /dev/pts escriba devpts (rw,nosuid,noexec,relatime,gid=5,mode=620,ptmxmode=000)
tmpfs activado /ejecutar tipo tmpfs (rw,nosuid,noexec,relatime,size=102704k,mode=755)
/dev/mapper/server1-root activado / escriba ext4 (rw,relatime,errors=remount-ro,user_xattr,barrier=1,data=ordered)
tmpfs en /ejecutar/bloquear escriba tmpfs (rw,nosuid,nodev,noexec,relatime,size=5120k )
tmpfs en /run/shm escriba tmpfs (rw,nosuid,nodev,noexec,relatime,size=205400k)
/dev/sda1 en /boot escriba ext2 (rw,relatime,errors=continue)
rpc_pipefs en /var/lib/nfs/rpc_pipefs escriba rpc_pipefs (rw,relatime)
server1.example.com:/testvol en /mnt/glusterfs escriba fuse.glusterfs (rw,relatime,user_id=0 ,group_id=0,default_permissions,allow_other,max_read=131072)
fusible en /sys/fs/fu se/conexiones tipo fusectl (rw,relatime)
[email protected]:~#
... y...
df -h
[Correo electrónico protegido]:~#df -h
Tamaño del sistema de archivos utilizado Avance Use%montado en
rootfs 29g 1.2g 26g 5% /
udev 10m 0 10m 0% /dev
TMPFS 101M 240K 101M 1%/ejecución
/dev/mapper/server1-raot 29g 1.2g 26g 5%/
tmpfs 5.0m 0 5.0m 0%/run/bloquear
TMPFS 201M 0 201M 0% /run/shm
/dev/sda1 228M 18M 199M 9% /boot
server1.example.com:/testvol 29G 1.2G 26G 5% /mnt/glusterfs
[correo electrónico protegido]:~#
En lugar de montar el recurso compartido GlusterFS manualmente en el cliente, puede modificar /etc/fstab para que el recurso compartido se monte automáticamente cuando se inicie el cliente.
Abra /etc/fstab y agregue la siguiente línea:
vi /etc/fstab
[...]
server1.example.com:/testvol /mnt/glusterfs glusterfs defaults,_netdev 0 0 |
Para probar si su /etc/fstab modificado está funcionando, reinicie el cliente:
reboot
Después del reinicio, debería encontrar el recurso compartido en las salidas de...
df -h
... y...
mount
4 Enlaces
- GlusterFS:http://www.gluster.org/
- Documentación de GlusterFS 3.2:http://download.gluster.com/pub/gluster/glusterfs/3.2/Documentation/AG/html/index.html
- Debian:http://www.debian.org/