Search icon CANCEL
Subscription
0
Cart icon
Your Cart (0 item)
Close icon
You have no products in your basket yet
Save more on your purchases! discount-offer-chevron-icon
Savings automatically calculated. No voucher code required.
Arrow left icon
Explore Products
Best Sellers
New Releases
Books
Videos
Audiobooks
Learning Hub
Free Learning
Arrow right icon
Arrow up icon
GO TO TOP
Raspberry Pi: Amazing Projects from Scratch

You're reading from   Raspberry Pi: Amazing Projects from Scratch Explore the powers of Raspberry Pi and build your very own projects right out of the box

Arrow left icon
Product type Course
Published in Sep 2016
Publisher
ISBN-13 9781787128491
Length 593 pages
Edition 1st Edition
Arrow right icon
Authors (4):
Arrow left icon
Matthew Poole Matthew Poole
Author Profile Icon Matthew Poole
Matthew Poole
Ashwin Pajankar Ashwin Pajankar
Author Profile Icon Ashwin Pajankar
Ashwin Pajankar
Richard Grimmett Richard Grimmett
Author Profile Icon Richard Grimmett
Richard Grimmett
Arush Kakkar Arush Kakkar
Author Profile Icon Arush Kakkar
Arush Kakkar
Arrow right icon
View More author details
Toc

Chapter 13. Setting Up a Web Server on the Raspberry Pi

In the previous two chapters, we discussed the networking capabilities of the Raspberry Pi. In Chapter 11, Build Your Own Supercomputer with Raspberry Pi, we built a network of Raspberry Pi devices that were able to communicate with each other and share the computational burden, thereby significantly reducing the time required for a task to complete. In the next chapter, Chapter 12, Advanced Networking with Raspberry Pi, we learned about more advanced networking concepts such as DHCP servers, DNS systems, and so on. In addition to that, we made our own intranet with a few Pi devices.

Continuing the same theme, we will now set up a web server on a single Raspberry Pi and set up a WordPress installation on it. The web server that we will be using is Apache, as it is one of the most popular servers, and has high usage within the open source community. In this chapter, we will be covering the following topics:

  • Introducing and installing Apache
  • Learning to serve HTML websites
  • Installing PHP and MySQL
  • Installing WordPress
  • Configuring WordPress

Introducing and installing Apache on Raspbian

The Apache HTTP server is extremely popular and is the world's most used web server software currently. It enjoys the support of the open source community because it is developed and maintained by an open community of developers under the umbrella of the Apache Software Foundation. Although most commonly used on a Unix-like system, it is available for a variety of other operating systems including Microsoft Windows. In 2009, it became the first web server to be used by more than a hundred million websites and currently it is estimated to serve over 50 percent of all websites and 37 percent of the top servers across domains.

One of the reasons it is so popular is that it supports a wide variety of features and many more features can be implemented as compiled modules that can extend the core functionality. For example, on its own, Apache can serve HTML files over HTTP, but with additional modules installed, it can also serve web pages using languages such as Python. It also has a variety of language interfaces that include Python, PHP, and Perl.

Now, installing the web server on a Raspbian distribution is extremely easy. We need to install the apache2 package with the following command:

$ sudo apt-get install apache2

During installation, the package automatically creates our demo HTML file that you can see if you type 127.0.0.1 or http://localhost/ on your URL bar. We can also see this if we navigate to the Pi's IP address from another machine connected to the same network such as 192.168.1.5. Replace this IP address with your own Pi's IP address in the network. You can find the IP address by typing the following on the Raspberry Pi's terminal:

$ hostname -I

The default page looks like this:

Introducing and installing Apache on Raspbian

If we see this page, it means that our installation has been successful. This is just a single HTML file that can be found at /var/www/html/index.html. Let's look at the details of this folder. Navigate to the folder by:

$ cd /var/www/html/

And then execute the following command to see the properties of the files in the folder:

$ ls -al

This command lists the files and a few of their properties. You will see the following output:

Introducing and installing Apache on Raspbian

The meaning of the columns respectively is:

  • Permissions of the file
  • Number of files in the directory
  • User that owns the file/directory
  • Group that owns the file/directory
  • File size
  • Last modified date

Since the owner of the index.html file is root, we need to take ownership of the file before editing it. To do that, enter the following command:

$ sudo chown pi: index.html

We can also replace the index.html file with our own HTML file and serve a fully fledged HTML website complete with CSS classes.

However, a simple HTML website sounds too basic, right? Since we are on the final leg of this book, we should do something more advanced. That's right, in the following sections we will be learning how to set up a WordPress website. For that, however, we first need to install a few tools that WordPress uses.

Installing PHP and MySQL

PHP is one of the most popular programming languages in use today for the web look at. It is the code that runs on the server when it receives a request for a website. Unlike HTML, PHP can generate dynamic web pages that can change the look and content on the fly. We chose PHP to work with because WordPress uses PHP. Now, install PHP and the accompanying Apache packages with the following command:

$ sudo apt-get install php5 libapache2-mod-php5

We now have PHP installed with its accompanying Apache packages, and we will proceed to test it.

Navigate to the HTML folder and create a new index.php file:

$ cd /var/www/html/
$ sudo nano index.php

Add a test line to it:

<?php echo "hello world"; ?>

Save the file and exit by pressing Ctrl + X and then Y. We also need to remove the index.html file because HTML takes precedence over PHP. Do that with the following command:

sudo rm index.html

Navigate to 127.0.0.1 or localhost in the browser and you will be greeted by the hello world message. Let's now set up something static.

Replace the hello world line with the following:

<?php echo date('Y-m-d H:i:s'); ?>

Now that we have installed PHP to process the web pages that we want, the next step is to install a database to store some data. Our database of choice will be MySQL simply because WordPress uses it to store IDs of things such as Post, Pages, Comments, Users, and so on.

To install MySQL and its PHP packages, run the following command:

sudo apt-get install mysql-server php5-mysql

Once the installation proceeds, you will be asked for a root password for creating the databases. Enter the password and remember it for future use.

Installing WordPress

Now that we are done installing the dependencies, the next step is getting the WordPress files in the HTML folder. Fortunately for us, WordPress provides a tar archive of the latest version of WordPress on this link: http://wordpress.org/latest.tar.gz. We now need to place the files contained in this folder in our web server folder. To do that, we first need to take ownership of the folder. To carry out that entire process, we execute the following commands:

$ cd /var/www/html/
$ sudo chown pi:
$ sudo rm *
$ wget http://wordpress.org/latest.tar.gz

In a nutshell, we first navigate to the HTML folder, take ownership of the folder, remove all the pre-existing files, and then fetch the WordPress archive. Next, we extract the contents of the archive and place them in the HTML folder. We do that with the following commands:

$ tar xzf latest.tar.gz
$ mv wordpress/*
$ rm -rf wordpress latest.tar.gz

Now, if you run the ls command, you will see the following output:

Installing WordPress

Configuring the WordPress installation

Once the files are properly placed in the right locations, to activate the installation and start using the WordPress website, we first need to set up a MySQL database that WordPress can use. To set up the database, execute the following command:

$ mysql -uroot -p

This sets up the database so that the user is root and the -p option prompts the terminal to ask for the password. Enter the same password that you entered while installing the MySQL database. We are then greeted with a MySQL terminal that looks like this:

Configuring the WordPress installation

Once inside the terminal, execute the following statement:

mysql> create database wordpress;

You will be greeted by the following message:

Configuring the WordPress installation

Finally, exit the terminal by pressing Ctrl + D.

To complete the installation, we need to access the WordPress installation page, located on our local host. So go ahead and enter 127.0.0.1 in your browser and you will be greeted with the following page:

Configuring the WordPress installation

This means that WordPress is properly configured. We now hit Let's go! to proceed to the next step. This takes us to the following page:

Configuring the WordPress installation

Enter all the details for the database including the password that you set earlier. Enter the details on the page as given in the preceding screenshot, and then press Submit. The installation wizard will give an error message that it was unable to write the wp-config.php file to the filesystem. There is no reason to panic here, because it also gives us the content of the wp-config.php file that we can use to create the file manually. The error looks like this:

Configuring the WordPress installation

So, now copy the text given in the dialog box, and open a new terminal. Create a new wp-config.php file in the HTML folder with the following commands:

$ cd /var/www/html
$ sudo nano wp-config.php

Go ahead and paste the content that was copied. We can right-click to paste or simply press Ctrl + Shift + V. Save and exit the file by pressing Ctrl + X and then Y. Once the file is created, go back to the browser and hit the Run the Install button. After processing for a few seconds, the page returns the following screen:

Configuring the WordPress installation

Now, we are ready to enter our details to create a user and begin using the WordPress website. Enter the details, and you've successfully created it.

You can log in to your website by appending /wp-admin.php to your website URL. For example, in our case the admin page will be given by 127.0.0.1/wp-admin.php, and it looks like this:

Configuring the WordPress installation

Note

To find out more about WordPress, log on to their website:

https://wordpress.org/

It would be an interesting exercise for you to continue with the process and try to run a fully fledged website on the Raspberry Pi and see how it handles the loads of running a heavy website complete with custom theme, pictures, and so on.

Configuring the WordPress installation

Once the files are properly placed in the right locations, to activate the installation and start using the WordPress website, we first need to set up a MySQL database that WordPress can use. To set up the database, execute the following command:

$ mysql -uroot -p

This sets up the database so that the user is root and the -p option prompts the terminal to ask for the password. Enter the same password that you entered while installing the MySQL database. We are then greeted with a MySQL terminal that looks like this:

Configuring the WordPress installation

Once inside the terminal, execute the following statement:

mysql> create database wordpress;

You will be greeted by the following message:

Configuring the WordPress installation

Finally, exit the terminal by pressing Ctrl + D.

To complete the installation, we need to access the WordPress installation page, located on our local host. So go ahead and enter 127.0.0.1 in your browser and you will be greeted with the following page:

Configuring the WordPress installation

This means that WordPress is properly configured. We now hit Let's go! to proceed to the next step. This takes us to the following page:

Configuring the WordPress installation

Enter all the details for the database including the password that you set earlier. Enter the details on the page as given in the preceding screenshot, and then press Submit. The installation wizard will give an error message that it was unable to write the wp-config.php file to the filesystem. There is no reason to panic here, because it also gives us the content of the wp-config.php file that we can use to create the file manually. The error looks like this:

Configuring the WordPress installation

So, now copy the text given in the dialog box, and open a new terminal. Create a new wp-config.php file in the HTML folder with the following commands:

$ cd /var/www/html
$ sudo nano wp-config.php

Go ahead and paste the content that was copied. We can right-click to paste or simply press Ctrl + Shift + V. Save and exit the file by pressing Ctrl + X and then Y. Once the file is created, go back to the browser and hit the Run the Install button. After processing for a few seconds, the page returns the following screen:

Configuring the WordPress installation

Now, we are ready to enter our details to create a user and begin using the WordPress website. Enter the details, and you've successfully created it.

You can log in to your website by appending /wp-admin.php to your website URL. For example, in our case the admin page will be given by 127.0.0.1/wp-admin.php, and it looks like this:

Configuring the WordPress installation

Note

To find out more about WordPress, log on to their website:

https://wordpress.org/

It would be an interesting exercise for you to continue with the process and try to run a fully fledged website on the Raspberry Pi and see how it handles the loads of running a heavy website complete with custom theme, pictures, and so on.

Summary

This chapter was a general extension of the previous two chapters, expanding on the concepts of networking built previously and using them to set up a web server on our intranet.

In this chapter, we installed the Apache web server on our Pi. To set up the WordPress website, we installed all the dependencies including PHP and MySQL. Then we downloaded the WordPress files and set up a MySQL database to work with it.

Finally, we configured the installation and resolved the errors that we generated to arrive at a complete installation.

In next chapter, we will learn network programming with Raspberry Pi using sockets in Python.

lock icon The rest of the chapter is locked
Register for a free Packt account to unlock a world of extra content!
A free Packt account unlocks extra newsletters, articles, discounted offers, and much more. Start advancing your knowledge today.
Unlock this book and the full library FREE for 7 days
Get unlimited access to 7000+ expert-authored eBooks and videos courses covering every tech area you can think of
Renews at $19.99/month. Cancel anytime
Banner background image