SSH is one of the best tools in a developers tool-belt. It can be used to set up advanced environments, manipulate sites, use great tools like WP-CLI for automating common WordPress tasks or to access a site when all else fails. In this article I’ll look at what SSH is and how you can connect via SSH to your server.

Getting Started With SSH

According to the specs, SSH is “a protocol for secure remote login and other secure network services over an insecure network”. In other words: it’s nothing more than a way to log in to a computer and access the services it offers.

To log into your site’s container you’ll need two things: An SSH client and login details.

SSH Clients

On OSX and Linux you have everything you need to get started, you can use SSH from the terminal without any special software. On Windows you’ll need and SSH client, the most popular one is Putty. I’ll give Windows users a quick Putty tutorial further down.

Login Details

To log in via SSH you’ll need at least four pieces of information:

  • Server address
  • username
  • password
  • port

The server address is usually your domain name or and IP. At Kinsta we use your
site’s IP address.

In some cases, if the default port is required, you might not need to specify it. At Kinsta we take security seriously so we use different ports for different sites.

If you are a Kinsta customer you can find your server’s details on your MyKinsta admin. Select the site you’d like to connect, you’ll find all the details you need.

In fact, if you’re using the terminal you can simply copy-paste the command generated for you in the SSH section to connect instantly (you’ll still need to enter your password of course).

Kinsta SSH Command

Kinsta SSH Command

Putty Setup

This section is for Windows users, if you’re on Mac or Linux, skip to the next section. Once you’ve downloaded Putty you can run it by double clicking the icon. You’ll see a screen that looks something like this:

Putty On Windows

Putty On Windows

You can get started right away by pasting your server address in the host name input field. Enter the port number next to it in the port field, make sure protocol is set to SSH and click open at the bottom.

You should see a Window which looks similar to a Linux terminal. It will ask for your username which you should enter and press enter. Do the same with your password, press enter and after a few moments you should be logged in.

Along the way you may get a notification about RSA fingerprints or other matters. Feel free to press OK to move on.

Connect via SSH in the Terminal

This section is for Mac and Linux users only, if you’re a Windows user and you’ve already set up Putty, skip below.

On Mac or Linux all you need to do is open the terminal and issue a command. The command takes the following form:

ssh username@hostname -p portnumber

Substitute the information with your actual username, host name and port number and press enter. You’ll be asked for your password which you should type in and press enter. If you receive any notifications about RSA fingerprints or other matters feel free to press enter or “y” to move on.

Issuing SSH Commands

From this point on the experience will be the same whether you’re on Windows or Mac. You now have the option to issue commands, just as you would in the terminal on your own computer. There are many neat things you can do, especially if you’re on a Kinsta server!

SSH opening message on Kinsta

SSH opening message on Kinsta

A word of warning. SSH access usually gives you a lot more freedom than you would normally have. This includes the ability to royally mess things up. You could delete your whole WordPress directory, all your images, stop essential services on your server. always use caution when using SSH you can do a lot of damage accidentally.

Using WP-CLI

WP-CLI is a command line interface for WordPress and gives you all sorts of neat tools. Kinsta servers have WP-CLI available out of the box so you can start using it as soon as you log in. For other servers, you may need to install it yourself, take a look at the website for more information.

Once you’re up and running with WP-CLI you can issue some commands! To do that you’ll need to move to a directory with WordPress installed. If you’re not sure where you are at the moment, use the ls command to show you the contents of the current directory.

Looking for ways to improve your WordPress development workflow?

Kinsta’s hosting solution was built by developers for developers. Git, PHP 7, SSH, and WP-CLI, along with powerful staging and cloning environments gives you the tools you need to build sites faster!

At Kinsta you’ll arrive in your site’s home directory. You’ll need to navigate to the public directory using cd public to get into the WordPress root directory.

Type wp plugin list to get a list of all plugins available to the site.

WP-CLI plugin list

WP-CLI plugin list

To do something more helpful you could run wp plugin update --all which would update all your plugins at once, or wp plugin update --all --dry-run which will give you a list of plugins that would be updated if you’d run the first command.

There are many useful commands WP-CLI commands, take a look at the Documentation for more info.

What Else Can I Do?

The short answer is: almost anything. You can now start using tools like git, npm, WP-CLI and others to give you more control over your website and your deployment environment. SSH is a great tool for interacting with your server and is pretty easy to get started with. Happy SSH-ing!