How To Use SCP (Secure Copy) With SSH Key Authentication

How To Use SCP (Secure Copy) With SSH Key Authentication

Home » News » How To Use SCP (Secure Copy) With SSH Key Authentication
Table of Contents

Anybody who administers Linux machines is aware of safe shell. With out this instrument, administering these servers remotely can be fairly difficult. It will additionally grow to be more durable to maneuver recordsdata forwards and backwards, a minimum of with a modicum of safety. That’s the place safe copy comes into play. With the SCP command, you possibly can copy recordsdata to and from a distant Linux server by means of an encrypted SSH tunnel.

SEE: Easy methods to View Your SSH Keys in Linux, macOS, and Home windows

Nonetheless, with the assistance of SSH key authentication, you can also make that much more safe. I need to present you the way you need to use safe key authentication and SCP so you possibly can relaxation assured your recordsdata are being moved forwards and backwards securely. I’ll display on an Elementary OS consumer and Ubuntu 16.04.1 server and assume you might have a safe shell put in and dealing.

SSH keys

The very first thing that have to be achieved is to create an SSH key pair. To do that, open up a terminal window and subject the command:

ssh-keygen -t rsa

You’ll be requested to call the file (use the default) and provides the keypair a passphrase.

As soon as the important thing’s randomart prints, your key is able to go.

The following step is to repeat the important thing to the distant server. That is achieved with the command:

ssh-copy-id USER@SERVER

The place USER is the username of the distant server, and SERVER is the deal with of the distant server.

You’ll be prompted for the distant consumer password. When you efficiently authenticate, the general public key will likely be copied to the server. You’re able to go.

SEE: Securing Linux coverage (Tech Professional Analysis)

Utilizing SCP along with your key

Now that our keys are in all the appropriate locations, let’s see how we will use them by means of SCP. Assuming you accepted the default title to your SSH key upon creation, the command to ship a file to your distant server utilizing your SSH secret is:

scp -i ~/.ssh/id_rsa.pub FILENAME USER@SERVER:/dwelling/USER/FILENAME

The place FILENAME is the title of the file, USER is the username on the distant machine, and SERVER is the deal with of the distant server.

You have to be prompted for the SSH key password (not the consumer password). As soon as authenticated, the file will likely be transferred.

The identical holds true if it is advisable pull a file from the distant server. The construction of that command can be:

scp -i ~/.ssh/id_rsa.pub USER@SERVER:/dwelling/USER/FILENAME /dwelling/USER/FILENAME

Once more, you can be requested to your SSH key password, and the file will likely be pulled from the server and copied to the native machine.

SEE: Easy methods to Add an SSH Fingerprint to Your known_hosts File in Linux

Neglect that password

Let’s say you’re about to bear a protracted session of copying recordsdata to your server. Positive, you could possibly tar all of them up into one greater file. However say they should all be positioned in numerous directories. That’s a number of typing. You may make this barely extra environment friendly by utilizing the ssh-agent and ssh-add instructions.

That’s proper, utilizing the mixture of SCP, SSH key authentication, and ssh-agent works effectively. This may maintain you from having to sort that SSH key password each time you subject the SCP command. The one caveat is that you need to bear in mind the PID of the agent session and kill it once you’re achieved.

Right here’s what it’s important to do.

  1. Earlier than issuing the SCP command subject eval ssh-agent to begin the session.
  2. Make an observation of the Course of ID you’re given when the session begins.
  3. Add your SSH key to the session with the command ssh-add.
  4. Begin utilizing SCP to repeat your recordsdata.

That’s all there may be to it. If you’re achieved with the session, guarantee to subject the command kill PID (the place PID is the precise quantity given to you once you began the ssh-agent session with eval).

SEE: 20 fast tricks to make Linux networking simpler (free PDF) (roosho)

Is SCP nonetheless safe?

Somebody asking if SCP is safe has doubtless learn the 2019 launch announcement for OpenSSH 8.0, which said that the SCP protocol is “outdated, rigid and never readily fastened” and advisable SFTP and Rsync as alternate options for file switch.

Earlier than OpenSSH 8.0, SCP couldn’t confirm file integrity throughout transfers, leaving customers uncovered to unauthorized overwrites and injection assaults if their server was compromised (CVE-2019-611). Nonetheless, the replace launched stricter filename checking because the default for the SCP command, making it safer, and moved its earlier non-checking habits to the command scp -T.

Then, in OpenSSH 9.0, launched in 2022, SFTP was adopted because the default backend for SCP as an alternative of the legacy SCP/RCP protocol, that means that transfers at the moment are encrypted and authenticated with the SSH protocol. Whereas broadly thought to be safe, customers ought to nonetheless be cautious of different dangers like misconfigured servers or outdated software program variations.

What can I exploit as an alternative of SCP?

  • SFTP: Whereas SCP defaults to utilizing the SFTP protocol, you possibly can think about using native SFTP purchasers for superior file administration because it permits for extra operations, comparable to viewing directories and file deletion.
  • Rsync: Supreme for synchronizing recordsdata and directories, particularly for incremental backups and huge datasets. See roosho’s information on how you can again up a community utilizing Rsync.
  • FTPS: A safe possibility for conventional FTP transfers with SSL/TLS encryption, however it may be advanced to configure.
  • HTTPS-based instruments: Comparable to curl or wget, for safe downloads over HTTPS. That is nice for automation, however they don’t present full listing administration like SFTP.

Fiona Jackson up to date this text in January 2025.

author avatar
roosho Senior Engineer (Technical Services)
I am Rakib Raihan RooSho, Jack of all IT Trades. You got it right. Good for nothing. I try a lot of things and fail more than that. That's how I learn. Whenever I succeed, I note that in my cookbook. Eventually, that became my blog. 
share this article.

Enjoying my articles?

Sign up to get new content delivered straight to your inbox.

Please enable JavaScript in your browser to complete this form.
Name