Bobcares

Rsync error protocol incompatibility – Different causes and fixes

by | Nov 9, 2020

The rsync error protocol incompatibility occurs while transferring data using rsync to a remote server which has a .bashrc file.

Here at Bobcares, we have seen several such rsync command related errors as part of our Server Management Services for web hosts and online service providers.

Today we’ll take a look at the causes for this error and see the fix.

 

Different causes and fixes for ‘rsync error protocol incompatibility’

Now let’s see the different causes for this error to occur and fixes provided by our Support Engineers for it.

 

1. .bashrc outputting anything

Cause: Sometimes, if the .bashrc on the remote server output anything to the terminal then you may run into problems. Since rsync won’t expect this, it may also run into problems.

In order to check if it is the case, run the below command.

ssh remoteuser@ip-address true | wc -c

Where you would need to update the ‘remoteuser‘ with the username and IP-address with your IP address.

If the above command returns more than 0 then it means that there is some output being produced.

Solution: In order to resolve this issue, remove any commands in the .bashrc that output text, or you can try piping any output to /dev/null.

vi /root/.bashrc

if [[ $- != *i* ]] ; then
# Shell is non-interactive. Be done now!
return
fi

Manually, log in to this machine and look if you get any such message. Because for the rsync to work, you should get the remote command prompt. In case, if you receive a message, then try to disable it. Look at your shell config files (e.g. ~/.bashrc, /etc/bash.bashrc for the bash shell) if they contain any command producing this output.

 

2. Difference in version

Cause: If there is any difference in rsync version between source and destination servers

Solution: You can simply upgrade the rsync version so that both the source and destination servers have the same rsync version.

 

3. Access restriction for a user

Cause: If there is restricted access for a user to SFTP only and is jailed to his home directory

Solution: To fix this problem, undo the restriction to SFTP in sshd_config. Or create a directory inside the directory user2 jailed/bind to. This directory is owned by user1, and hence able to rsync files into it.

The process will be as below: user2 was jailed / chrooted using

Match Group sftponly
ChrootDirectory /var/ftp
ForceCommand internal-sftp
AllowTcpForwarding no

inside /etc/ssh/sshd_config.

The directory was bind to his home directory by using:

mount –bind /var/ftp /home/user2/ftp

After that, inside /var/ftp/ execute the below command:

mkdir tempDir
chown -R user1:user1 tempDir

After the files sync to that directory, they automatically appear in the user2 jail directory and the user can read them.

[Need any further assistance in fixing rsync errors? – We are here to help you.]

 

Conclusion

In short, the ‘rsync error protocol incompatibility’ occurs while transferring data using rsync to a remote server which has a .bashrc file. In today’s writeup, we saw the different causes and fixes our Support Engineers provide to our customers to fix this error.

PREVENT YOUR SERVER FROM CRASHING!

Never again lose customers to poor server speed! Let us help you.

Our server experts will monitor & maintain your server 24/7 so that it remains lightning fast and secure.

GET STARTED

var google_conversion_label = "owonCMyG5nEQ0aD71QM";

0 Comments

Submit a Comment

Your email address will not be published. Required fields are marked *

Never again lose customers to poor
server speed! Let us help you.

Privacy Preference Center

Necessary

Necessary cookies help make a website usable by enabling basic functions like page navigation and access to secure areas of the website. The website cannot function properly without these cookies.

PHPSESSID - Preserves user session state across page requests.

gdpr[consent_types] - Used to store user consents.

gdpr[allowed_cookies] - Used to store user allowed cookies.

PHPSESSID, gdpr[consent_types], gdpr[allowed_cookies]
PHPSESSID
WHMCSpKDlPzh2chML

Statistics

Statistic cookies help website owners to understand how visitors interact with websites by collecting and reporting information anonymously.

_ga - Preserves user session state across page requests.

_gat - Used by Google Analytics to throttle request rate

_gid - Registers a unique ID that is used to generate statistical data on how you use the website.

smartlookCookie - Used to collect user device and location information of the site visitors to improve the websites User Experience.

_ga, _gat, _gid
_ga, _gat, _gid
smartlookCookie
_clck, _clsk, CLID, ANONCHK, MR, MUID, SM

Marketing

Marketing cookies are used to track visitors across websites. The intention is to display ads that are relevant and engaging for the individual user and thereby more valuable for publishers and third party advertisers.

IDE - Used by Google DoubleClick to register and report the website user's actions after viewing or clicking one of the advertiser's ads with the purpose of measuring the efficacy of an ad and to present targeted ads to the user.

test_cookie - Used to check if the user's browser supports cookies.

1P_JAR - Google cookie. These cookies are used to collect website statistics and track conversion rates.

NID - Registers a unique ID that identifies a returning user's device. The ID is used for serving ads that are most relevant to the user.

DV - Google ad personalisation

_reb2bgeo - The visitor's geographical location

_reb2bloaded - Whether or not the script loaded for the visitor

_reb2bref - The referring URL for the visit

_reb2bsessionID - The visitor's RB2B session ID

_reb2buid - The visitor's RB2B user ID

IDE, test_cookie, 1P_JAR, NID, DV, NID
IDE, test_cookie
1P_JAR, NID, DV
NID
hblid
_reb2bgeo, _reb2bloaded, _reb2bref, _reb2bsessionID, _reb2buid

Security

These are essential site cookies, used by the google reCAPTCHA. These cookies use an unique identifier to verify if a visitor is human or a bot.

SID, APISID, HSID, NID, PREF
SID, APISID, HSID, NID, PREF