25% off on first invoice for all services*

SPRING SALE

Use coupon

*Offer valid for new customers only

25% off on first invoice for all services*

SPRING SALE

Use coupon

*Offer valid for new customers only

Need help?

Our experts have had an average response time of 11.43 minutes in March 2024 to fix urgent issues.

We will keep your servers stable, secure, and fast at all times for one fixed price.

How to configure SFTP server with chroot ?

by | Oct 13, 2020

Secure File Transfer Protocol/SSH File Transfer Protocol (SFTP) is a common method used to transfer files securely.  Configuring SFTP server with chroot ensures to generate a Jail like environment where users cannot access any folders beyond their home directory.

As a part of our Server Management Services, we help our Customers to fix SFTP related errors regularly.

Let us today discuss the on how to configure SFTP server with chroot.

Create a Group for sftp using groupadd command

First step here is to create a group for SFTP. Open the terminal, create a group with a name “sftp_users” using below groupadd command:

root@server:~# groupadd sftp_users

 

Add Users to Group ‘sftp_users’ and set permissions

To create new user and want to add that user to ‘sftp_users’ group, then run the following command:

# useradd -m -G sftp_users 

Replace user_name in the command with the exact username. Set the password using following chpasswd command:

root@server:~# echo "user_name:" | chpasswd

To add existing users to ‘sftp_users’ group, then run beneath usermod command. Let us suppose already existing user name is ‘user1’.

root@server:~# usermod -G sftp_users user1

Now set the required permissions on Users.

root@server:~# chown root /home/user_name /home/user1/

Create an upload folder in both the user’s home directory and set the correct ownership:

mkdir /home/user_name/upload
mkdir /home/user1/upload
chown user_name /home/user_name/upload
chown user1 /home/user1/upload

Edit sftp configuration file

Sftp configuration file is  at “/etc/ssh/sshd_config“. Before making any changes, first take the backup with cp command. Then edit this file to add the following content:

#Subsystem sftp /usr/lib/openssh/sftp-server
Subsystem sftp internal-sftp

Match Group sftp_users
X11Forwarding no
AllowTcpForwarding no
ChrootDirectory %h
ForceCommand internal-sftp

Save and exit the file.

To make above changes into the affect, restart ssh service using following systemctl command:

root@server:~# systemctl restart sshd

In above ‘sshd_config’ file we have commented out the line which starts with “Subsystem” and added new entry “Subsystem sftp internal-sftp” and new lines like,

  • “Match Group sftp_users” – It means if a user is a part of ‘sftp_users’ group then apply rules which are mentioned below to this entry.
  • “ChrootDierctory %h” – It means users can only change directories within their respective home directories. They cannot access any other user’s and system’s directories.
  • “ForceCommand internal-sftp” – It means users are limited to sftp command only.

 

Test and Verify sftp

Login to any other Linux system which is on the same network of the sftp server and then try to ssh sftp server via the users that we have mapped in ‘sftp_users’ group.

We will most probably receive an message that “Write failed: Broken pipe”. It confirms that users are not allowed to SSH. Now if we try sftp using following command, we receive an output that we have connected to the server.

[root@web-server ~]# sftp user_name@IP_address

We can use the ‘get’ command to download a file. Also when we try to navigate to directories outside of the users’s home directory, it shows a message “Couldn’t stat remote file: No such file or directory”.

Similarly, we can use the ‘put’ command to upload files to the server.

[Need any further assistance to Configure SFTP Server with Chroot? – We’re available 24*7]

 

Conclusion

In short,configuring SFTP server with chroot ensures to generate a Jail like environment where users cannot access any folders beyond their home directory. Today, we saw how our Support Engineers configure SFTP server with chroot.

 

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";

2 Comments

  1. Jota

    after doing this i am not able to login again as root via ssh

    Reply
    • Hiba Razak

      Hi,
      Our experts can help you with the issue.we will be happy to talk to you through our live chat(click on the icon at right-bottom).

      Reply

Submit a Comment

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

Categories

Tags

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

IDE, test_cookie, 1P_JAR, NID, DV, NID
IDE, test_cookie
1P_JAR, NID, DV
NID
hblid

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