FTP Port Explained

ftp port

FTP by definition uses the TCP transport protocol exclusively and doesn’t use the UDP for its transport purposes. Usually an application layer protocol will use one or the other. One important exception of that rule is DNS or Domain Name System. FTP also is kind of different due to the fact that it uses two ports to complete its task. It usually utilizes port 20 for transferring data and port 21 for listening to commands. It’s also true that transferring data over FTP port 20 is not mandatory and it can be done trough an another port as well. This is where it gets confusing for many users. FTP has two modes of operation – active and passive. Both are started by the FTP client, and then acted upon by the FTP server.

Active FTP

Active FTP port

In active mode the FTP client connects from a random unprivileged port (N, which is usually 20) to the FTP server’s command FTP port, which is port 21. Then, the client starts listening to port N+1 and sends a command to the FTP server. After that the server connects back to the client’s specified data port from its local one. From the server-side firewall’s point of view, to support FTP in active mode these ports have to be opened: FTP server’s port 21 from anywhere (Client initiates connection); FTP server’s port 21 to ports > 1023 (Server responds to client’s control port); FTP server’s port 20 to ports > 1023 (Server initiates data connection to client’s data port); FTP server’s port 20 from ports > 1023 (Client sends ACKs to server’s data port).

Passive FTP

passive ftp port

In this mode the FTP client initiates two connections to the FTP server. We need to keep in mind as well that both of these connections are using ephemeral ports themselves, and that’s ok. By opening two connections, or sockets with the FTP server, the client is able to resolve the issue of its firewall denying access to the FTP server initiating contact on one of the client’s high ephemeral ports. One of the connections opened by the client will contact the server on FTP port 21, and issue it the PASV (passive) command, vice the normal PORT command when using active FTP. Now what happens is that the FTP server opens an ephemeral port and issues the PORT command to the FTP client. With this in hand the client then starts a connection back to the server FTP port for the data transfer.

FTP Hosting

FTP port free hosting

Try our FTP hosting that offers free FTP, MySQL & Email accounts that you can access via our in-house Control Panel. You can also install one of the FTP clients that we have prepared: FileZilla (you can use it for FTP over SSH), CoffeeCup Free FTP and Cyberduck that enable you to easily create SSL, TLS and SSH-secured connections.

FREE Hosting Plan

$0.00£0.000.00€ per year

    1000 MB Disk Space
    5 GB Monthly Traffic
    1 Domains Hosting
    MySQL, 1 FTP account
    PHP5, Perl
    Advanced Control Panel

Personal Hosting Plan

$24.00£24.0024.00€ per year

    Unlimited Disk Space
    Unlimited Monthly Traffic
    2 Domains Hosting
    Unlimited FTP accounts
    PHP5, Perl, ASP.NET
    1 FREE domain for 1 year
<< Go Back to Hosting Encyclopedia  
We use cookies to ensure you can get the best experience on our site. If you keep using this site we assume that you agree to our use of cookies. Privacy Policy OK