Ich bevorzuge die Verwendung des Rsync-Daemons für alle meine Rync-Anforderungen, da er eine saubere zentrale Verwaltung bietet und Systemressourcen spart. Dementsprechend /etc/rsyncd.conf
enthält mein Daemon mehrere Moduleinträge.
Meine Wrapper-Skripte für meine eigentlichen Rsync-Befehle sind alle while
Schleifen, die im Falle einer unterbrochenen Verbindung sofort/mehrfach die Verbindung zu den entsprechenden Rsync-Daemons wiederherstellen.
Problem:
Der max connections = 1
Variableneintrag für jedes Modul wird gelesenglobalstattindividuellpro Modul. Dadurch wird bewirkt, dass @ERROR: max connections (1) reached -- try again later
(der rsync-Daemon, der sich zuerst verbindet, erhält den einzelnen verfügbaren falschweltweit max connection = 1
, wodurch alle anderen Verbindungen fehlschlagen ... ärgerlich).
Ohne die kann max connections = 1
die while
Schleife eine unbegrenzte Anzahl von Threads hochfahren und unnötige Ressourcen verbrauchen, was zu einer Begrenzung der Verbindungen pro Modul führt. In der Zwischenzeit max connections = 1
verfügt die über die zugehörige per module
Datei.lock gemäß Dokumentation.
Das ist mein /etc/rsyncd.conf
:
[home]
path = /home/username
list = yes
use chroot = false
strict modes = false
uid = root
gid = root
read only = yes
# Data source information
max connections = 1
lock file = /var/run/rsyncd-home.lock
[prod-bkup]
path = /media/username/external/Server-Backups/Prod/today
list = yes
use chroot = false
strict modes = false
uid = root
gid = root
# Don't allow to modify the source files
read only = yes
max connections = 1
lock file = /var/run/rsyncd-prod-bkup.lock
[test-bkup]
path = /media/username/external/Server-Backups/Test/today
list = yes
use chroot = false
strict modes = false
uid = root
gid = root
# Don't allow to modify the source files
read only = yes
max connections = 1
lock file = /var/run/rsyncd-test-bkup.lock
[VminRoot2]
path = /root/VDI-Files
list = yes
use chroot = false
strict modes = false
uid = root
gid = root
# Don't allow to modify the source files
read only = yes
max connections = 1
lock file = /var/run/rsyncd-VminRoot2.lock
Dies ist ein Beispiel für eines meiner Rsync-Daemon-Wrapper-Skripte:
#!/bin/sh
#
#
while [ 1 ]
do
cputool --load-limit 7.5 -- nice -n -15 rsync -avxP --no-i-r --rsync-path="rsync" --log-file=/var/log/rsync-home.log --exclude 'snap' --exclude 'lost+found' --exclude=".*" --exclude=".*/" 127.0.0.1::home /media/username/external/home-files-only && sync && echo 3 > /proc/sys/vm/drop_caches
if [ "$?" = "0" ] ; then
echo "rsync completed normally"
exit
else
echo "Rsync failure. Backing off and retrying..."
sleep 10
fi
done
#end of shell script
Frage
Wie kann ich den Fehler beheben ERROR: max connections (1) reached -- try again later
?