Skip to main content

How to migrate your PHP website to Amazon EC2

Amazon Elastic Compute Cloud (Amazon EC2) and is one of the most popular hosting solutions nowadays. Using EC2's virtual servers you don't need to invest in hardware up front, and you can easily manage performance, networking and security of your applications.

The AWS Free Tier provides the following free services for 12 months, and with a competitive price afterwards:
  • 750 hours per month of Linux, RHEL, or SLES t2.micro instance usage
  • 750 hours per month of Windows t2.micro instance usage
  • Run one instance at a time or multiple instances simultaneously
In this post I will explain how can you easily migrate your application from your local server to this high-performance cloud solution.

1) Sign up.
Sign up for free on Amazon Web Services. Credit card information is required, but you won't be charged during the first 12 months.

2) Set up EC2.
On your Amazon Management Console, apply for a EC2 account following these instructions. Keep the resulting key_pair.pem file somewhere safe. Make sure that you have set the security group with inbound rules for SSH, HTTP and HTTPS (see figure below).

3) Launch your instance. On your EC2 dashboard select the option Launch Instance and follow these instructions. For a PHP website I recommend choosing the Amazon Linux  t2.micro. Remember to connect your instance with the key_pair.pem file that you had generated before, and select the security group that you created on step 2.

4) Connect to your instance. From Linux or MAC just type the following command on your terminal:
$ ssh -i /path/key_pair.pem ec2-user@public_dns_name
Replace the elements in red with the path to your key pair and the public DNS name that you can find on your EC2 instances dashboard. For example:
$ ssh -i /home/arturo/Docs/arturo_key_pair.pem ec2-user@ec2-14-129-140-123.us-west-2.compute.amazonaws.com 
You will be granted access to your brand new Amazon Linux machine.

5) Install the Server and Database. In our case we are going to use PHP with a MySQL database. If you need to install any other package, such as Node.js, you can use the command sudo yum install package_to_install. In order to set up our web server and database, just follow the steps from 2 to 5 of this tutorial.

6) Test the web server. If you type your public DNS on your browser (in our example http://ec2-14-129-140-123.us-west-2.compute.amazonaws.com) you will see the Apache test page. Your web server is running!

7) Copy your files. You just need to copy your PHP project in /var/www/html. That's it!


Popular posts from this blog

How to disable cookies on Google Analytics so that you don't need a consent banner

The integration of Google Analytics into a website or blog is not GDPR-compliant by default . You must first obtain explicit consent of the end-users to store cookies, describing in your privacy policy how you intend to use collected personal data. This is the reason why most websites nowadays display an annoying (but necessary) consent banner. If you fail to do so or if you only ask for implicit consent, you are at risk of being fined. However, it is possible to disable cookies on Google Analytics (GA) respecting end-users privacy, so that you don't need to ask for consent. The downside is that you will not be able to distinguish the type of user (unique vs new vs returning) and you will miss some session insights. If these details are not relevant for you, here is how you do it. Disable Google Analytics cookies on a custom website If you have a custom website with full access to the source code, you can simply insert the script below between the <head>  and </head>

How to convert a PWA into an Android app in 5 minutes

In early 2021 I developed a memory game called Kobadoo  as a PWA (Progressive Web App) using ReactJS. It works pretty well as a browser game and gets decent traffic, but I wanted to reach more potential users by making it available on the official mobile app marketplaces. Since I didn't want to spend any time coding a native app, the easiest solution I found was to convert the PWA into a TWA (Trusted Web Activities) app. It barely takes 5 minutes to do it. TWA essentially allows you to easily create an Android app ( .apk file) that displays a full-screen browser view of your PWA. The user experience is almost identical to a web app and the views from the TWA will count as traffic on your web app. This means that if you have ads on your PWA, they will still work (and generate revenue) from the TWA. Another advantage is that every update you make on the PWA will be immediately reflected on the TWA without the need to submit a new version on Google Play. Here's how I convert

How to jump to time offsets in HTML5 video

Let's say that you have a 30-minute WEBM video file, from which you just want to play the following video segments , jumping from one to the other automatically  without interruptions : [00:01:25.00 - 00:02:25.00] -> from second 85 to 145 [00:11:40.00 - 00:11:55.00] -> from second 700 to 715 [00:20:26.00 - 00:21:07.00] -> from second 1226 to 1267 [00:26:11.00 - 00:28:01.00] -> from second 1571 to 1681 To increase the complexity, let's think that you have these video segments in a PHP variable $arrayVideoSegments  (normally the case if they were retrieved from the database).   $arrayVideoSegments[0]->startTime = 85   $arrayVideoSegments[0]->endTime = 145   $arrayVideoSegments[1]->startTime = 700   $arrayVideoSegments[1]->endTime = 715   $arrayVideoSegments[2]->startTime = 1226   $arrayVideoSegments[2]->endTime = 1267   $arrayVideoSegments[3]->startTime = 1571   $arrayVideoSegments[3]->endTime = 1681 The fo