It is a high performance web server that is responsible for handling the load of some of the largest and high traffic websites on the internet.
In this Tutorial we will show you How to install LEMP on your CentOS 6.7 Server. LEMP is a software bundle that is made up of four parts (Linux, Nginx, MySQL, and PHP). In this Tutorial we will be using CentOS 6.7 which was released on August 7th, 2015, Nginx version 1.0.15, MySQL version 5.1.73 and php-fpm using PHP version 5.3.3.
Prerequisites
we will require a VPS or a Dedicated server with Centos 6.7 64bit. you can get one from here.
Installing EPEL in CentOS 6.7 for LEMP
First we will install the Fedora epel release to quickly install Nginx. Run the following command to install EPEL
yum install epel-release
Installing and Configuring NGINX in CentOS 6.7 for LEMP
Install NGINX with the following command:
sudo yum install nginx
Start the NGINX service with the following command:
sudo /etc/init.d/nginx start
Configure NGINX to start when the system is rebooted:
sudo chkconfig nginx on
You will now have NGINX installed on your server. This can be verified by typing in the following with your IP ADDRESS on your browser. Also, all configuration files are provided on the page.
We can now verify Apache is working by opening your browser and entering the URL http://your-server’s-address. you should get a blue Nginx test page similar to the image below.
Note: If you do not know your IP address, run the following command:
sudo ip addr show eth0
In our example we would put http://192.168.100.10 into our browser’s address bar.
Installing and Configuring MySQL on CentOS 6.7 for LEMP
Install MySQL with the following command to begin the install:
sudo yum install mysql-server
Start the service with the following command:
sudo service mysqld start
Set root MySQL password with the following command:
sudo /usr/bin/mysql_secure_installation
Note: You will be prompted with a series of questions. Just type Y for yes on all of them, see the screen shot below:
Configure MySQL to start when the system is rebooted:
sudo chkconfig mysqld on
Installing and Configuring php-fpm on CentOS 6.7 for LEMP
Install php-fpm with the following command:
sudo yum install php-fpm php-mysql
Start the php-fpm service with the following command:
sudo service php-fpm restart
Make sure php-fpm starts on boot with the following command:
sudo chkconfig php-fpm on
Using your favorite editor, edit the file /etc/php-fpm.d/www.con and change user and group from apache to nginx. It should look similar to the block below.
; Unix user/group of processes
; Note: The user is mandatory. If the group is not set, the default user’s group
; will be used.
; RPM: apache Choosed to be able to access some dir as httpd
user = nginx
; RPM: Keep a group allowed to write in log dir.
group = nginx
Now we need to make some changes to the Nginx configuration file so that php-fpm works correctly with Nginx. Using your favorite editor, edit the file /etc/nginx/conf.d/default.conf and carry out the following changes or copy the following block below into your conf file.
1) Add the index.php to the index location
2) Change the root location to /usr/share/nginx/html
3) Uncomment the Pass PHP scripts to FastCGI section.
4) Change the fastcgi_param SCRIPT_FILENAME to use /usr/share/nginx/html$fastcgi_script_name
#
# The default server
#
server {
listen 80 default_server;
server_name _;
#charset koi8-r;
#access_log logs/host.access.log main;
# Load configuration files for the default server block.
include /etc/nginx/default.d/*.conf;
location / {
root /usr/share/nginx/html;
index index.php index.html index.htm;
}
error_page 404 /404.html;
location = /404.html {
root /usr/share/nginx/html;
}
# redirect server error pages to the static page /50x.html
#
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root /usr/share/nginx/html;
}
# proxy the PHP scripts to Apache listening on 127.0.0.1:80
#
#location ~ \.php$ {
# proxy_pass http://127.0.0.1;
#}
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
#
location ~ \.php$ {
root /usr/share/nginx/html;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /usr/share/nginx/html$fastcgi_script_name;
include fastcgi_params;
}
# deny access to .htaccess files, if Apache’s document root
# concurs with nginx’s one
#
#location ~ /\.ht {
# deny all;
#}
}
Create a test PHP file in the following directory with the following command:
sudo vi /usr/share/nginx/html/info.php
Insert the following code in the space then save and exit:
Restart apache so all the changes take effect:
sudo service nginx restart
Test your page in your browser with the following hyperlink changed with yourIP address:
http://YOUR.IP.ADD.RESS/info.php
You should removed the info.php file as it could be used against you by an attacker. Delete it with the following command:
sudo rm /usr/share/nginx/html/info.php
Congratulations! You have just installed LEMP on your CentOS 6.7 Server. Thank you for reading.
In today’s digital age, having a website is not just a luxury but a necessity for businesses, entrepreneurs, and even individuals looking to establish an online presence. Hosting your website can seem daunting, but with the right techniques and tools, it becomes a manageable and rewarding task. This comprehensive guide will walk you through the…
Reverse Proxy refer to a kind of proxy server, which takes HTTP requests and distributes them transparently to many backend servers. These reverse proxies are valuable because lots of contemporary web apps are processing incoming HTTP requests with backend apps servers. These are not intended to be accessed by users openly and often just support…
In an increasingly connected world, having a multilingual website is no longer a luxury—it’s a necessity. Whether you run an e-commerce store, a blog, or a corporate website, the ability to communicate with a global audience can significantly enhance your reach, engagement, and revenue. Thankfully, WordPress offers several translation plugins that make it easy to…
DDoS (Distributed Denial-of-Service) attacks are a growing threat to organizations of all sizes, often resulting in disrupted services, financial loss, and damaged reputations. Preventing a DDoS attack involves using proactive security measures, real-time monitoring, and strategic planning to protect networks and ensure business continuity. With BlueAngelHost, you get reliable, scalable DDoS Attack Prevention that prioritizes…
Choosing the right website builder is crucial for anyone looking to establish an online presence. With numerous options available, two of the most popular choices are Squarespace vs Wix. Both platforms offer unique features and benefits, making it challenging to decide which one suits your needs best. This comprehensive guide delves into various aspects of…
Offshore hosting is becoming an increasingly popular choice for businesses and individuals seeking secure and flexible web hosting solutions. This form of hosting involves placing your website on servers located outside your home country, offering various benefits from enhanced privacy to better performance in certain markets. Understanding the nuances and advantages of offshore hosting can…