rsync (Español)
rsync es una utilidad de código abierto que proporciona una transferencia de archivos incremental rápida.
Instalación
rsync debe instalarse en la máquina tanto de origen como de destino.
Interfaces gráficas
- Grsync — Front-end GTK.
- gutback — Wrapper de rsync escrito en Shell.
- https://github.com/gutenye/gutbackup || gutbackupAUR[enlace roto: package not found]
- JotaSync — Interfaz Java Swing para rsync con planificador integrado.
- luckyBackup — Front-end Qt escrito en C++.
Otras herramientas que usan rsync son y .
Como alternativa de cp/mv
rsync se puede usar como una alternativa avanzada para la orden o , especialmente para copiar archivos más grandes:
$ rsync -P source destination
La opción -P
es la misma que --partial --progress
, que mantiene los archivos parcialmente transferidos y muestra una barra de progreso de la transferencia.
Es posible que desee utilizar la opción / para recoger recursivamente el contenido de los directorios.
Los archivos se pueden copiar localmente como con cp, pero el propósito motivador de rsync es copiar archivos de forma remota, es decir, entre dos servidores diferentes. Las ubicaciones remotas se pueden especificar con una sintaxis de dos puntos entre servidores:
$ rsync source host:destination
o
$ rsync host:source destination
Las transferencias de archivos en red utilizan el protocolo SSH de forma predeterminada y puede ser un nombre de equipo real o un perfil/alias predefinido desde .
Ya sea que transfiera archivos de forma local o remota, rsync primero crea una lista de archivos que contiene información (de manera predeterminada, el tamaño del archivo y la última marca de tiempo de modificación) que luego se utilizará para determinar si el archivo necesita ser construido. Para cada archivo que se construirá, se encuentra una suma de comprobación débil y fuerte para todos los bloques, de modo que cada bloque tenga una longitud de S bytes, que no se superponga y que tenga un desplazamiento que sea divisible por S. Con esta información, se puede construir un archivo grande usando rsync sin tener que transferir todo el archivo. Para obtener una explicación práctica y matemática detallada, remítase a how rsync works y the rsync algorithm, respectivamente.
Para pasar a rsync valores predeterminados rápidamente, puede usar algunos alias:
Lidiar con la barra diagonal
Arch por defecto usa «cp» de GNU (parte de de GNU). Sin embargo, rsync sigue la convención de BSD para «cp», que da un tratamiento especial a los directorios de origen con una bara diagonal «/». A pesar de que:
$ rsync -r source destination
crea un directorio «destination/source» con el contenido de «source»;
y la orden:
$ rsync -r source/ destination
copia todos los archivos presentes en «source/» directamente a «destination», sin subdirectorio intermedio, como si lo hubiera invocado así:
$ rsync -r source/. destination
Este comportamiento es diferente al de GNU para cp, que trata «source» y «source/» de forma idéntica (pero no «source/.»). Además, algunos intérpretes de órdenes añaden automáticamente la barra inclinada final cuando se completan los nombres de directorios con el tabulador. Debido a estos factores, puede haber cierta tendencia entre los usuarios de rsync nuevos u ocasionales a olvidarse del comportamiento diferente de rsync, y sin darse cuenta provoquen un desastre o incluso sobrescribir archivos importantes al dejar la barra diagonal en la línea de órdenes.
Por lo tanto, puede ser prudente usar un script para eliminar automáticamente las barras diagonales finales antes de invocar rsync:
#!/bin/zsh new_args=(); for i in "$@"; do case $i in /) i=/;; */) i=${i%/};; esac new_args+=$i; done exec rsync "${(@)new_args}"
Este script se puede colocar en algún lugar de la ruta y crear un alias a rsync en el archivo de inicio de shell.
Como herramienta para realizar copias de seguridad
El protocolo rsync puede usarse fácilmente para realizar copias de seguridad, transfiriendo solo los archivos que han cambiado desde la última copia de seguridad. Esta sección describe un script para realizar copias de seguridad programada muy simple que utiliza rsync, el cual generalmente se utiliza para realizar copias a medios extraíbles.
Realizar copia de seguridad automatizada
A modo de ejemplo, el script se creará en el directorio , y se ejecutará diariamente si un daemon cron está instalado y configurado correctamente. Configurar y usar cron no entra en el ámbito de este artículo.
Primero, cree un script que contenga las opciones de órdenes apropiadas:
/etc/cron.daily/backup
#!/bin/bash rsync -a --delete --quiet /folder/to/backup /location/of/backup
- indica que los archivos deben archivarse, lo que significa que la mayoría de sus características se conservan (no así las ACL, enlaces duros o atributos extendidos como capacidades)
--delete
- significa que los archivos eliminados en origen también serán eliminados en la copia de seguridad
Aquí, debe cambiarse por aquello que quiere respaldar (, por ejemplo) y es donde se quiere guardar la copia de seguridad (, pongamos por caso).
Por último, el script debe hacerse ejecutable:
# chmod +x /etc/cron.daily/backup
Realizar copia de seguridad automatizada con SSH
Si realiza una copia de seguridad en un servidor remoto utilizando SSH, utilice este script en su lugar:
- le dice a rsync que use SSH
- es el usuario en el servidor
remotehost
- agrupa todas estas opciones de (recursivo, enlaces, permisos, tiempos, grupo, propietario, dispositivos)
-a
), se necesita acceso de root a la máquina de destino. La forma preferida de lograr esto para la automatización es configurar el demonio SSH para permitir que root inicie sesión utilizando una clave pública sin contraseña y ejecutar la orden rsync como root.Realizar copia de seguridad automatizada con NetworkManager
Este script inicia una copia de seguridad cuando se establece la conexión de red.
Primero, cree un script que contenga las opciones de órdenes apropiadas:
- agrupa todas estas opciones de (recursivo, enlaces, permisos, tiempos, grupo, propietario, dispositivos=
- lee la ruta relativa de /folder/to/backup desde este archivo
- limita el ancho de banda de E/S; KBytes por segundo
Además, el script debe tener permiso de escritura solo para el propietario (root, por supuesto) (vea NetworkManager#Network services with NetworkManager dispatcher para más detalles).
Realizar copia de seguridad automatizada con systemd e inotify
En lugar de ejecutar copias de seguridad a intervalos de tiempo según se haya programado, como las implementadas en cron, es posible ejecutar una copia de seguridad cada vez que uno de los archivos de los que está realizando una copia de seguridad cambia. Las unidades usan para monitorear el sistema de archivos, y se pueden usar junto con los archivos para iniciar cualquier proceso (en este caso su copia de seguridad con rsync) basado en un evento del sistema de archivos.
Primero, cree el archivo que monitoreará los archivos que está respaldando:
~/.config/systemd/user/backup.path
[Unit] Description=Comprueba si las rutas que se están copiando actualmente han cambiado [Path] PathChanged=%h/documents PathChanged=%h/music [Install] WantedBy=default.target
Luego cree un archivo que se activará cuando detecte un cambio. De manera predeterminada, se activará un archivo de servicio con el mismo nombre que la unidad de ruta (en este caso, ), salvo por la extensión en lugar de (en este caso ).
Type=oneshot
. Esto le permite especificar múltiples parámetros ExecStart=
, uno para cada órden rsync, que se ejecutará. Alternativamente, puede simplemente escribir un script para realizar todas sus copias de seguridad, al igual que con los scripts de cron.Ahora todo lo que tiene que hacer es iniciar/activar como un servicio de systemd normal y comenzará a monitorear los cambios de los archivos e iniciará en consecuencia .
Realizar copia de seguridad diferencial por semana
Esta es una opción útil de rsync, que consiste en realizar una copia de seguridad completa (en cada ejecución) y mantener una copia de seguridad diferencial solo de los archivos modificados en un directorio separado para cada día de la semana.
Primero, cree un script que contenga las opciones de órdenes apropiadas:
- implica la actualización de los archivos de destino en el lugar
Realizar copia de seguridad basada en instantáneas
La misma idea se puede utilizar para mantener un árbol de instantáneas de sus archivos. En otras palabras, un directorio con copias de los archivos ordenadas por fecha. Las copias se realizan mediante enlaces, lo que significa que solo los archivos que cambiaron ocuparán espacio. En términos generales, esta es la idea detrás de TimeMachine de Apple.
Este script básico es fácil de implementar y crea instantáneas incrementales rápidas utilizando la opción --link-dest
para enlazar archivos sin cambios:
Debe existir un enlace simbólico a una copia de seguridad completa como destino para --link-dest
. Si se elimina la instantánea más reciente, será necesario volver a crear el enlace simbólico para que apunte a la instantánea más reciente. Si --link-dest
no encuentra un enlace simbólico que funcione, rsync procederá a copiar todos los archivos de origen en lugar de solo los cambios.
Una versión más sofisticada mantiene una copia de seguridad completa actualizada y, en caso de que un cierto número de archivos haya cambiado desde la última copia de seguridad completa, crea una instantánea de la copia de seguridad completa actual utilizando para vincular archivos sin cambios:
Para hacer las cosas realmente simples, este script puede ejecutarse desde una unidad systemd/Timers.
Realizar copia de seguridad completa del sistema
Esta sección trata sobre el uso de rsync para transferir una copia de todo el árbol , excluyendo algunas carpetas seleccionadas. Se considera que este enfoque es mejor que clonar un disco con dd
dado que ello utilizar un tamaño diferente, una tabla de partición y un sistema de archivos, y mejor que copiar con también, porque permite un mayor control sobre los permisos de archivos, atributos, Listas de control de acceso y Atributos extendidos.
rsync funcionará incluso mientras el sistema se está ejecutando, pero los archivos modificados durante la transferencia pueden o no transferirse, lo que puede causar un comportamiento inesperado de algunos programas que usan los archivos transferidos.
Este enfoque funciona bien para migrar una instalación existente a un nuevo disco duro o SSD.
Ejecute la siguiente orden como root para asegurarse de que rsync pueda acceder a todos los archivos del sistema y preservar su propiedad:
# rsync -aAXv --exclude={"/dev/*","/proc/*","/sys/*","/tmp/*","/run/*","/mnt/*","/media/*","/lost+found"} / /path/to/backup/folder
Al utilizar el conjunto de opciones , los archivos se transfieren en modo de comprimido, lo que garantiza que los enlaces simbólicos, los dispositivos, los permisos, las propiedades, los tiempos de modificación, los ACL y los atributos extendidos se conserven, suponiendo que el sistema de archivos de destino dé soporte a esta función.
La opción hace que se excluyan los archivos que coinciden con los patrones dados. Se excluye el contenido de /dev
, , , y en la orden anterior, porque se rellenan en el arranque, aunque las carpetas no se crean por sí mismas. es específico del sistema de archivos. La orden anterior depende de la expansión de llaves disponible tanto en las shells bash como zsh.Cuando se utiliza un shell diferente, los patrones deben repetirse manualmente. Citar los patrones de exclusión evitará la expansión por la shell, lo cual es necesario, por ejemplo, cuando se realiza una copia de seguridad mediante SSH. Al terminar las rutas excluidas con se garantiza que dichos directorios se creen si aún no existen.
Es posible que desee incluir opciones rsync adicionales, como las siguientes. Consulte rsync(1) para ver la lista completa.
- Si usa muchos enlaces duros (por ejemplo, si está usando Flatpak), considere agregar la opción , que está desactivada por defecto debido a su gasto de memoria. Sin embargo, no debería ser un problema en la mayoría de los ordenadores modernos. Muchos enlaces duros residen en el directorio
/usr/
. - Es posible que desee agregar la opción
--delete
de rsync si está ejecutando esto varias veces en la misma carpeta de respaldo. En este caso, asegúrese de que la ruta de origen no termine con , o esta opción solo tendrá efecto en los archivos dentro de los subdirectorios del directorio de origen, pero no tendrá ningún efecto en los archivos que residen directamente dentro del directorio de origen. - Si utiliza archivos dispersos, como discos virtuales, imágenes Docker y similares, debe agregar la opción .
- La opción desactivará la asignación de nombres de usuarios y grupos; en su lugar, se transferirán las identificaciones numéricas de grupo y de usuario. Esto es útil cuando se realiza una copia de seguridad mediante SSH o cuando se utiliza un sistema live para hacer una copia de seguridad de un disco con sistema diferente.
- Al elegir la opción en lugar de se mostrará la información general del progreso y la velocidad de transferencia, en lugar de la lista de archivos que se están transfiriendo.
- To avoid crossing a filesystem boundary when recursing, add the option /. This will prevent backing up any mount point in the hierarchy.
Restaurar una copia de seguridad
Si desea restaurar una copia de seguridad, use la misma orden de rsync que se ejecutó, pero con el origen y el destino invertidos.
Clonar el sistema de archivos
rsync proporciona una forma de hacer una copia de todos los datos en un sistema de archivos al tiempo que conserva la mayor cantidad de información posible, incluidos los metadatos del sistema de archivos. Es un procedimiento de clonación de datos en un nivel de sistema de archivos donde los sistemas de archivos de origen y de destino no necesitan ser del mismo tipo. Se puede utilizar para realizar copias de seguridad, migrar sistemas de archivos o recuperar datos.
El modo archive de rsync está cerca de ser apto para el trabajo, pero no realiza una copia de seguridad de los metadatos especiales del sistema de archivos, como listas de control de acceso, atributos extendidos o propiedades de archivos dispersos. Para una clonación exitosa a nivel del sistema de archivos, se deben proporcionar algunas opciones adicionales:
rsync -qaHAXS DIRECTORIO_ORIGEN DIRECTORIO_DESTINO
Y su significado es (de la página de manual):
-H, --hard-links preserva los enlaces duros -A, --acls preserva las ACL (implica -p) -X, --xattrs preserva los atributos extendidos -S, --sparse manejar archivos dispersos de manera eficiente
Además, use si tiene otros sistemas de archivos montados bajo el árbol que desea excluir de la copia. La copia producida se puede volver a leer y verificar (por ejemplo, después de un intento de recuperación de datos) a nivel del sistema de archivos con la opción recursiva de :
diff -r DIRECTORIO_ORIGEN DIRECTORIO_DESTINO
Es posible realizar una migración exitosa del sistema de archivos usando rsync como se describe en este artículo y actualizando fstab y bootloader como se describe en Migrate installation to new hardware.Básicamente, esto proporciona una forma de convertir cualquier sistema de archivos raíz a otro.
Demonio rsync
rsync se puede ejecutar como demonio en un servidor que escucha el puerto 873
.
Edite la plantilla , configure un recurso compartido e inicie el servicio .
Utilización del cliente, por ejemplo listar el contenido del servidor:
$ rsync rsync://server/share
Transferir archivo del cliente al servidor:
$ rsync local-file rsync://server/share/
Tenga en cuenta iptables para abrir el puerto 873
y la autenticación de usuario.
Véase también
- Se pueden buscar más ejemplos de uso en los foros Community Contributions y General Programming
- Howto – local and remote snapshot backup using rsync with hard links Includes file deduplication with hard-links, MD5 integrity signature, 'chattr' protection, filter rules, disk quota, retention policy with exponential distribution (backups rotation while saving more recent backups than older)
- Using SSH keys/identity files with rsync