Menu

Command Line Tools

January 2, 2025

The following are some commonly used tools for data transfer:

Tool

Summary

curl

curl is a command line tool for transferring data with URL syntax, supporting DICT, FILE, FTP, FTPS, GOPHER, HTTP, HTTPS, IMAP, IMAPS, LDAP, LDAPS, POP3, POP3S, RTMP, RTSP, SCP, SFTP, SMTP, SMTPS, TELNET and TFTP. curl supports SSL certificates, HTTP POST, HTTP PUT, FTP uploading, HTTP form based upload, proxies, cookies, user+password authentication (Basic, Digest, NTLM, Negotiate, kerberos...), file transfer resume, proxy tunneling and more.

Limitations: no parallel stream support.

wget

wget is a command line too for transferring URL via HTTP, HTTPS and FTP

Limitations: no parallel stream support.

scp/sftp/rsync

scp, sftp, and rsync are commonly used to copy data between hosts.  For large file transfers on the WAN, these tools should be avoided

aria2

Next generation download utility

Supports HTTP/HTTPS, FTP, SFTP, BitTorrent and Metalink. aria2 can be manipulated via built-in JSON-RPC and XML-RPC interfaces.  Allows for multiple connections. 

Sample commands:

  aria2c -x2 http://a/f.iso

lftp

Supports parallel file transfer, socket tuning, HTTP, FTP, SFTP, bittorent transfers, and more.

Limitations: non intuitive syntax

Sample commands:

  lftp -e 'set net:socket-buffer 4000000; pget -n 4 http://site/path/file; quit'
lftp -e 'set net:socket-buffer 4000000; pget -n 4 ftp://site/path/file; quit'

axel

Simple parallel accelerator for HTTP and FTP.

Limitations: no authentication support

Sample commands:

axel -n 4 http://site/file
axel -n 4 ftp://site/file

More info is here.

 

FDT

FDT is an Application for Efficient Data Transfers which is capable of reading and writing at disk speed over wide area networks (with standard TCP). It is written in Java, runs an all major platforms and it is easy to use. FDT is based on an asynchronous, flexible multithreaded system and is using the capabilities of the Java NIO libraries.

FDT can be used in one of these seven modes:

  • Server: java -jar fdt.jar [ OPTIONS ]
  • Client: java -jar fdt.jar [ OPTIONS ] -c [file1 …]|[-fl ] -d
  • SCP: java -jar fdt.jar [ OPTIONS ] [[[user@][host1:]]file1 [[[user@][host2:]]file2
  • Coordinator: java -jar fdt.jar [OPTIONS] -dIP -dp -sIP -p -d [-fl ] -coord
  • List Files: java -jar fdt.jar [OPTIONS] -c -ls
  • Agent: java -jar fdt.jar [OPTIONS] -c -tp <transfer,ports,separated,with,comma> -agent
  • Session log: java -jar fdt.jar [OPTIONS] -c -d -sID
 

HPNSSH

Drop in replacement for scp and sftp with much better performance.