Skip to main content

Deploy Laravel 5.4 App on LEMP Stack (DigitalOcean Guide) Part - 2

This tutorial is the second part of the Deploy Laravel 5.4 App on LEMP Stack (DigitalOcean Guide).

Before I install LEMP stack, I am going to update the package installer. To do that run the following command in the terminal. It will grab the package list and update it.

sudo apt-get update


Install Nginx (Engine-X)


Run the following command to install Nginx server.

sudo apt-get install nginx

 
After the installation, you should be able to visit your IP address and it will show the Nginx default page.


Install MySQL


Run the following command to install MySQL on your server.

sudo apt-get install mysql-server

The above command will start the MySQL installation process. You will have to enter 'Y' and proceed. After few steps you will see the following screen. Enter root password and proceed.


Default MySQL installation is famous for insecure. MySQL has a helper script to secure the MySQL installation. To run the script type the following command in your terminal.

sudo mysql_secure_installation

You will be prompt to enter the root password. It will ask whether you want to install VALIDATE PASSWORD plugin. If you install that plugin it will check whether the password is strong enough for the security of the system.

If you think your root password is not strong enough you will be able to change it in the next step.

Next step is to remove the anonymous users. Since having anonymous users is a major security risk remove users by entering the Y key.

Normally, root should only be allowed to connect from 'localhost'. This ensures that someone cannot guess at the root password from the network. Disallow remote access since it is a security risk.

It is a good idea to remove test database. Click Y to remove it.

Finally, allow the system to reload privilege tables. Click Y to reload the table. You will get the Success. All done! message.


Install PHP and Configure PHP


I'm going to install both php-fpm and php-mysql which allows PHP to communicate with MySQL. Lastly, I will install php-mbstring which is a major requirement for Laravel. Following, command will PHP version 7 as well.

sudo apt-get install php-fpm php-mysql php-mbstring

To configure PHP open the php.ini file using the following command.

sudo nano /etc/php/7.0/fpm/php.ini

Find the cgi.fix_pathinfo=1 line and change it to cgi.fix_pathinfo=0. You can use ctrl+w keys to search the texts. You will see a semicolon the left of this line. Delete the semicolon and then change the 1 into a 0 save the file and exit.


You have to restart the php-fpm changes to take effect. Run the following command to restart the php-fpm.

sudo systemctl restart php7.0-fpm

Configure Nginx


Let's configure the Nginx server. Open the /etc/nginx/sites-available/default using the following command.

sudo nano /etc/nginx/sites-available/default 


Let's allow it to recognize index.php as a valid file to deliver. Let's add index.php to the list of allowed file types to deliver by default.


Let's add IP address to the server_name line. This tells Nginx which domain to respond. I am going to use an IP address since I don't want to register a new domain for this server. But if you have a domain name change the name servers to the DigitalOcean and add the domain name to this line.



Go to the location section.

        #location ~ \.php$ {
        #       include snippets/fastcgi-php.conf;
        #
        #       # With php7.0-cgi alone:
        #       fastcgi_pass 127.0.0.1:9000;
        #       # With php7.0-fpm:
        #       fastcgi_pass unix:/run/php/php7.0-fpm.sock;
        #}

        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
        #location ~ /\.ht {
        #       deny all;
        #}


Uncomment the following section. And uncommented sections should be like following code. We want to tell Nginx to use php-fpm that we installed earlier. The second block tells Nginx to ignore .htaccess files.

location ~ \.php$ {
                include snippets/fastcgi-php.conf;
        #
        #       # With php7.0-cgi alone:
        #       fastcgi_pass 127.0.0.1:9000;
        #       # With php7.0-fpm:
                fastcgi_pass unix:/run/php/php7.0-fpm.sock;
        }

        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
        location ~ /\.ht {
                deny all;
        }



Write the changes to the file save it and exit. You can check whether the files contain any errors using the following command.

sudo nginx -t

If it doesn't contain any error, you will get a syntax is ok message.


Now you have to restart the Nginx server using the following command.

sudo systemctl reload nginx

Now the server is ready to deploy PHP applications. You can access the part three of this series from this link.

Comments

Popular posts from this blog

Alternatives to the SQLite in Android

At the moment there are several embeddable databases and libraries out there that you can use in a mobile application. In this post, I examine most popular libraries and databases and highlight some of their characteristics. Realm Realm is a mobile platform and a replacement for SQLite & Core Data. According to the website, it has more than 100k active developers. Realm is fully open source and distributes under Apache License. Realm Mobile Database is much faster than an ORM, and often faster than raw SQLite due to zero-copy design. Some of the benefits of Realm are fast queries, safe threading, encryption of data and reactive architecture. You can learn more about Realm by visiting this page . Sugar ORM Sugar ORM is a library that can be used to interact with SQLite database using Object-Relational Mapping. Object-Relational Mapping (ORM) is a technique that used to query and manipulate data from a SQLite database using an object-oriented paradigm. And Suga...

Laravel 5.4 Bootstrap row class for every 3 columns

Sometimes you need to show three or four columns in a row using Laravel 5.4 and blade template engine. Here I show how to do it using chunk function in Laravel blade. As the first step let's get products from the database and pass it to the blade view. And let's check our blade file. In the following example,  @ foreach  takes the  $ products array and chuck it. In this example, I split it by three. You can pass any number according to your specification. And you will see the inner @ foreach loop through  $ items. If you have any question please comment it and I will try to solve it.

Mobile Backend As A Service (BaaS) platform for Android

Many mobile apps and games rely on a backend service for things that can’t be done solely on hosted device, such as sharing and processing data from multiple users, or storing large files. Backend as a service (BaaS) provides a centralised database and other features to manage user-generated data and application data. The developer can link applications to the backend service and backend service expose APIs to manage users, integrate push notification and analytics. BaaS is a recent development of cloud computing technology. Using backend services provide developers functionalities to manage users, data and to analyse real-time changes actively. Backend service should be able to handle the offline case gracefully and minimise battery drain. Back in the day developers had to develop custom backend platforms using server-side technologies. And developers had to scale up and down according to the user base and app usage. It was time-consuming in terms of resources and skills. Most mob...