Monday, 31 May 2010

Migración IMAP

Tanto si vais a cambiar de servidor de correo, como si queréis migrar a gmail o a Google Apps, aquí va una receta de cómo migrar todo el correo de un lado al otro usando IMAP.

En Gmail o Google Apps, las etiquetas se tratan como carpetas desde una conexión IMAP. Lo primero es habilitar la conexión IMAP en la configuración de GMail.

Luego usamos un comando de este estilo:

imapsync --host1 imap.server.org \
--user1 user@server.org \
--passfile1 ./passfile1 \
--host2 imap.gmail.com \
--port2 993 --user2 user@gmail.com \
--passfile2 ./passfile2 --ssl2 \
--split1 100 --split2 100 \
--buffersize 18192000 --maxsize 18192000 \
--noauthmd5 \
--folderrec ElDirQueSea \
--syncinternaldates \
--authmech1 LOGIN --authmech2 LOGIN \
--useheader 'Message-Id' --skipsize

Explicación de la falla:
Los primeros parámetros son obvios, datos de configuración de la conexión IMAP, que para el caso de GMail es especial ya que requiere SSL (de ahí el --ssl2) y no soporta authmd5 (de ahí el --noauthmd5). En los passfiles se guardan en texto plano los passwords y listos. Tmb se puede meter el pass directamente en la línea de comandos pero es un poco más salvaje a nivel de seguridad ya que al fichero siempre le puedes meter un chmod 600.
Después --syncinternaldates se asegura de que los correos vayan con su fecha, y no con la fecha de la migración, que siempre es interesante.
Los --buffersize 18192000 y --maxsize 18192000 lo que hacen es ampliar la memoria de imapsync, y limitar el tamaño del mensaje máximo para evitar que pete por out-of-memory, muy típico de imapsync.
Imapsync sincronizará la etiqueta o carpeta que le pongas en el --folderrec de manera rec-ursiva, jeje.
La última línea es muy importante si estás usando GMail, ya que de lo contrario vuelve a copiar los correos ya existente, que si bien no es problema por los duplicados ya que GMail lo detecta y elimina duplicados, sí es un engorro pq estás ejecutando el comando 20.000 horas de más, así que --useheader 'Message-Id' --skipsize obligado! ;)
Y por último los splits ... la verdad no he notado diferencia de velocidad, pero según reza la ayuda es el número de peticiones simultaneas a servidor origen y servidor destino respectivamente ... o eso creo :P

Por si sirve de ayuda, yo primero he hecho un --justfolders para que cree la estructura de directorios/etiquetas, y luego he creado un fichero de texto con cada folder en una línea. Luego con lo siguiente he ido saltando de folder en folder para evitar que un fallo me pare el proceso entero:

while read i
do
imapsync bla bla bla ... --folder $i
done < folder.list.txt

Ale, felices migraciones ;)

Links de interés:
http://www.thamtech.com/blog/2008/03/29/gmail-to-google-apps-email-migration/
http://www.linux-france.org/prj/imapsync/FAQ
http://wiki.zimbra.com/wiki/Guide_to_imapsync

No comments: