How to Install WordPress on AWS EC2
This guide will walk you through connecting an AWS EC2 Instance to SpinupWP. Before you start this process, you will need to sign up for an Amazon AWS account if you don’t already have one.
#Launch An Instance
Once signed in to Amazon AWS, navigate to Services > EC2. If you’re presented with the EC2 dashboard, click Launch Instance about halfway down the screen.
Alternatively, if you’re presented with the list of instances, click Launch Instances on the top right of that list.
You’ll be asked to choose an Amazon Machine Image (AMI), select “Ubuntu Server 24.04 LTS”, the “64-bit (x86)” version.
You’ll be asked to choose the Instance Type. For this guide, we’ll be using the default “t2.micro” instance, which has 1 vCPU and 1GB of memory. Click Review and Launch.
A modal will appear asking you to choose a key pair. As you’ll be adding the SpinupWP SSH key to the instance’s authorized_keys
file before we provision the server, select “Proceed without a key pair” from the dropdown, check the checkbox, and click Launch Instances.
If everything works as expected, you’ll be presented with the “Launch Status” screen. Click View Instances to continue.
The newly created instance will appear in your Instances list, with an Instance State of “Running”.
#Connect Your Instance To SpinupWP
Once you have a freshly created EC2 instance, you are ready to provision the server via SpinupWP.
You will need to connect to the server so that you can add the SpinupWP SSH key to the authorized_keys
file. Within AWS, tick the checkbox next to the Instance in the list, then click the Connect button.
The next “Connect to Instance screen” shows the details of the instance. Make a note of the “Public IP address” and click Connect. This will open a terminal connection via a new browser window or tab.
The SSH console will connect using the default SSH user which is generated based on the type of AMI you used. In the case of Ubuntu, the username is ubuntu
.
Now, head over to SpinupWP and click Spin Up a New Server followed by Use Another Provider.
Choose AWS from the list of supported providers.
Enter the server’s external “IP address”, the “SSH Port” should default to 22 and the “SSH Username” to ubuntu
, and select Public Key authentication. Copy the command provided by SpinupWP for adding the SpinupWP SSH key to the EC2 instance’s authorized_keys
file.
Paste this string into the SSH terminal browser window you opened earlier, and hit Enter.
Switch back to SpinupWP and confirm that it can connect to the EC2 instance by Next. Once you see the success message, you can Click Next again to continue.
Enter the server’s hostname and choose a timezone, then select the desired database server. Click Provision Server to begin the provisioning process.
Once the server has finished provisioning you’re ready to start adding sites.
#Next Steps
Once you’ve completed the SpinupWP provision process, you are ready to fine-tune settings and add a site. For more information on these steps, see our Getting Started doc.
What to expect after adding a site? You’ll have the option to configure your server and sites to your needs via the SpinupWP dashboard.
You’ll be able to quickly enable page caching. When enabled, SpinupWP configures full page caching, essentially turning your site into a static site and dramatically improving the load time of your site.
You can also toggle on an SSL certificate to enable HTTPS. This generates a free Let’s Encrypt certificate so you don’t have to manually manage this yourself. If you’d prefer to use a custom SSL certificate, you’ll have the opportunity to upload that instead.
If you’re looking to add rewrite rules or prevent PHP scripts from being executed in the uploads folder, the Nginx settings steps will cover that.
We’ll also cover enabling SFTP & SSH access to your site and setting up site backups.
SpinupWP can take care of automated daily site backups which include full backups of your site files (media, themes and plugins). You’ll have the option to backup to Amazon S3, DigitalOcean Spaces, Akamai/Linode, Google Cloud Storage, Wasabi or Backblaze B2.
Follow our Getting Started Guide for step by step instructions for all of the above mentioned features and more.