From Wikiversity
Jump to navigation Jump to search

OpenSSH is a popular suite of software utilities implementing Secure Shell (SSH) protocol. OpenSSH includes the ability to set up a TCP secured channel and it is widely use as a replacement for not secured telnet and secure replacement of file transfers such as rcp and ftp. OpenSSH offers a great number of features including ssh session multiplexing. [1][2]

The OpenSSH suite includes the following command-line utilities and daemons:

  • ssh, TCP secure replacement for rlogin, rsh and telnet to allow shell access to a remote machine.
  • scp, a replacement for rcp
  • sftp, a replacement for ftp to copy files between computers
  • sshd, the SSH server daemon which allows shell access and file transfers to a remote machine.
  • ssh-keygen, a tool to inspect and generate the RSA, DSA and Elliptic Curve keys that are used for user and host authentication
  • ssh-agent and ssh-add, utilities to ease authentication by holding keys ready and avoid the need to enter passphrases every time they are used
  • ssh-keyscan, which scans a list of hosts and collects their public keys
  • ssh-copy-id, copy local keys to remote machine.



  • Add links to relevant demonstration videos here ...




  • Learn about different client connection options, such us: -oBatchMode=yes or -o ConnectTimeout=2[5]
  • Connect to remote server temporarily turning off host key checking, (security implications): ssh -oStrictHostKeyChecking=no SERVER_NAME


  1. Read ssh documentation about multiplexing and its implementation details:
  2. Configure ssh session multiplexing
  3. Use ProxyJump directive to connect using a "Jump Server"[6]
  4. Run a shell script on a remote machine using ssh: ssh root@MachineB 'bash -s' <[7]. See also: parallel

See also[edit]