KEMBAR78
Linux FTPS Server Setup Guide | PDF | File Transfer Protocol | Transport Layer Security
0% found this document useful (0 votes)
133 views5 pages

Linux FTPS Server Setup Guide

1. vsftpd is a popular FTP server for Linux but lacks security as it transfers data like usernames and passwords in plain text. FTPS uses SSL/TLS encryption to secure data transfers. 2. The article explains how to set up an encrypted FTPS server in Linux using vsftpd and OpenSSL. This involves generating an SSL certificate, configuring vsftpd to use encryption, and enabling TLS. 3. Local users can then be added to access the new secure FTPS server using encrypted connections and strong authentication.

Uploaded by

Cecoprod Semar
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
133 views5 pages

Linux FTPS Server Setup Guide

1. vsftpd is a popular FTP server for Linux but lacks security as it transfers data like usernames and passwords in plain text. FTPS uses SSL/TLS encryption to secure data transfers. 2. The article explains how to set up an encrypted FTPS server in Linux using vsftpd and OpenSSL. This involves generating an SSL certificate, configuring vsftpd to use encryption, and enabling TLS. 3. Local users can then be added to access the new secure FTPS server using encrypted connections and strong authentication.

Uploaded by

Cecoprod Semar
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 5

2/2/23, 8:27 How to set up an FTPS Server in Linux | Open Source

Set Up an FTPS Server in Linux


By Mandar Shinde - March 23, 2015

vsftpd is a very popular package for FTP (File Transfer Protocol) but poses a security threat because it transfers vital data
like usernames, passwords, etc, in plain text. To eliminate this risk, FTP offers encryption with the help of the SSL and TLS
protocols. This article explains how to set up an FTPS server in Linux.

FTP is a standardised network protocol and probably the quickest as well as easiest option available when a large chunk of
data is to be transferred from one host to another, over a TCP-based network. FTP defines a client-server architecture that
uses two separate well-known ports for data (Port No 20, used for data transfer) and control (Port No 21, used for
authentication) connections, in order to establish connectivity between the server and the client.

When it comes to the Linux operating system, the most popular package used to set up an FTP server is vsftpd or very
secure FTP daemon. It offers very basic features such as anonymous enabling/disabling, local enabling/disabling and chroot
jail for the users. But, when looked at from the security perspective, vsftpd has very few features to offer.

Whenever the file transfer is initiated, all the data, including user credentials and passwords, get transferred in an
unencrypted format, as plain text, which is considered to be very risky in any public network.

As a security measure, we have two options that offer secure file transfer capabilities, which are SFTP and FTPS. SFTP uses
an SSH connection to run file transfers over a secure channel, while FTPS uses cryptographic protocols such as SSL (Secure
Socket Layer) and TLS (Transport Layer Security). This article elaborates on the SFTP protocol in order to set up a secure
FTP server using SSL certificates.

Installation of the required packages


To install openssl and vsftpd in Debian-based systems,

you can run:

sudo apt-get install vsftpd


sudo apt-get install openssl

https://www.opensourceforu.com/2015/03/set-up-an-ftps-server-in-linux/ 1/5
2/2/23, 8:27 How to set up an FTPS Server in Linux | Open Source

In Red Hat Linux-based systems, you can run:

yum install vsftpd


yum install openssl

Generating the SSL certificate and RSA key file


This step involves creating a SSL certificate file (rsa_cert_file) and RSA key file (rsa_private_key_file) that will be used by
vsftpd for data encryption purposes. It is very important to set the paths of both these files, as those must be mentioned in
the vsftpd configuration file (Red Hat -/etc/vsftpd/vsftpd.conf and Debian – /etc/vsftpd.conf) in the rsa_cert_file and
rsa_private_key_file variables. By default (in RHEL), the rsa_cert_file will point to /usr/share/ssl/certs/vsftpd.pem.

For our convenience, lets put the certificate and the key in the same file, and store that file as /etc/vsftpd/vsftpd.pem.

openssl req -x509 -nodes -days 365 -newkey rsa:1024 -keyout \


/etc/vsftpd/vsftpd.pem -out /etc/vsftpd/vsftpd.pem

Once the above command is executed, you will be asked to provide some basic information. The output will be very similar
to:

Generating a 1024 bit RSA private key


....................................................++++++
........++++++
writing new private key to ‘/etc/vsftpd/vsftpd.pem’
-----
You are about to be asked to enter information that will be incorporated
into your certificate request.
What you are about to enter is what is called a Distinguished Name or a DN.
There are quite a few fields but you can leave some blank
For some fields there will be a default value,
If you enter ‘.’, the field will be left blank.
-----
Country Name (2 letter code) [XX]:IN
State or Province Name (full name) []:Maharashtra
Locality Name (eg, city) [Default City]:Pune
Organization Name (eg, company) [Default Company Ltd]:MyTestOrganizationLtd
Organizational Unit Name (eg, section) []:Information Technology
Common Name (eg, your name or your server’s hostname) []:My Test FTP Server
Email Address []:mandar.shinde2007@gmail.com

The vsftpd configuration part


After generating the SSL certificate, we need to instruct vsftpd to use that SSL certificate to carry out the encryption
process. Just like many services, vsftpd has its own configuration file, vsftpd.conf, which is located in
/etc/vsftpd/vsftpd.conf for Red Hat-based systems and /etc/vsftpd.conf in Debian-based systems.

https://www.opensourceforu.com/2015/03/set-up-an-ftps-server-in-linux/ 2/5
2/2/23, 8:27 How to set up an FTPS Server in Linux | Open Source

Now, let us edit the configuration file as per our requirements. You might need to find out the lines, or add them if they do
not pre-exist.

Step 1: Turn on SSL


We would like to enable encryption not only for data transfer, but also for authentication process. For this, you can edit
following lines as:

ssl_enable=YES
allow_anon_ssl=NO
force_local_data_ssl=YES
force_local_logins_ssl=YES

Step 2: Mention the certificate and key file location.


rsa_cert_file=/etc/vsftpd/vsftpd.pem
rsa_private_key_file=/etc/vsftpd/vsftpd.pem

Step 3: Enable TLS


TLS is considered to be more secure than SSL so we would definitely like to use it whenever required.

ssl_sslv2=YES
ssl_sslv3=YES

Step 4: This includes other basic configurations


To allow all the local users added to the system to use FTP service, edit the following line:

local_enable=YES

To prevent anonymous logins, edit the following line:

anonymous_enable=NO

To accept FTP write commands, edit the following line:

write_enable=YES

https://www.opensourceforu.com/2015/03/set-up-an-ftps-server-in-linux/ 3/5
2/2/23, 8:27 How to set up an FTPS Server in Linux | Open Source

With this setting, only a local user can access the FTP server and can issue write commands. But if you want to preserve
the individuality of the users and their contents, you can set up a chroot jail for the users, so that users are bound to work
in their home directories and are not permitted to access any files outside them.

chroot_local_user=YES

To enable logging of the transfers carried out, edit the following lines:

xferlog_enable=YES
xferlog_std_format=YES
xferlog_file=/var/log/ftp/xferlog

Add the vsftpd service to start up


With the configuration done, you will have to restart the service so that the changes incorporated can take effect:

service vsftpd restart

By default, after a fresh installation of any package, the service associated with that package is disabled on every run level.
This indicates that you will have to manually restart the service after the operating system switches from one run level to
another. In simple words, after every reboot or system startup, you will have to start the service manually.
You can verify this by issuing the chkconfig command
as follows:

chkconfig --list vsftpd

The output is:

$ chkconfig --list vsftpd


vsftpd   0:off  1:off  2:off  3:off  4:off  5:off   6:off

To overcome this and to configure the service to start automatically, you can use:

chkconfig vsftpd on

To confirm, run the command given below:

$ chkconfig --list vsftpd


vsftpd  0:off   1:off   2:on    3:on    4:on    5:on    6:off

https://www.opensourceforu.com/2015/03/set-up-an-ftps-server-in-linux/ 4/5
2/2/23, 8:27 How to set up an FTPS Server in Linux | Open Source

Adding FTP users


Now, your FTP server is ready to used and you can add users who can access it. Adding FTP users is very similar to adding
users in the operating system, using the useradd command. With this, every user will get a separate home directory and
with the chroot jail activated, users will be forced to work within their home directories.
To add the user ‘mandar, simply run:

useradd mandar

To set the password for mandar, use the passwd command as follows:

passwd mandar

You will have to mention the new password and confirm it once:

Changing password for user mandar.


New password:
Retype new password:
passwd: all authentication tokens updated successfully.

Now, the user ‘mandar’ will be able to use the FTPS services with any FTP client that supports SSL/TLS, such as FileZilla.
In order to access the FTPS server through browsers, you may require to install some add-ons like fireFTP.

You can limit access to the FTPS server, but allow people to use FTPS services at the same time, by changing their shell to
/sbin/nologin.  Further, you can set a password policy for the users (/etc/pam.d/system-auth) to make them select a strong
password and change it regularly (chage command).

Mandar Shinde
The author works in the IT division of one of the largest commercial automotive organisations in India. His technical interests include Linux,
networking, backups and virtualisation.

Show/Write Comments

https://www.opensourceforu.com/2015/03/set-up-an-ftps-server-in-linux/ 5/5

You might also like