部署LNMP环境
1.1 问题
安装部署Nginx、MariaDB、PHP环境
- 安装部署Nginx、MariaDB、PHP、PHP-FPM;
- 启动Nginx、MariaDB、FPM服务;
- 并测试LNMP是否工作正常。
1.2 方案
在RHEL7系统中,源码安装Nginx,使用RPM包安装MariaDB、PHP、PHP-FPM软件。
操作过程中需要安装的软件列表如下:
- nginx
- mariadb、mariadb-server、mariadb-devel
- php、php-fpm、php-mysql
1.3 步骤
实现此案例需要按照如下步骤进行。
步骤一:安装软件
1)使用yum安装基础依赖包
- [root@svr5 ~]# yum -y install gcc openssl-devel pcre-devel zlib-devel
- .. ..
2)源码安装Nginx
- [root@svr5 ~]# useradd –s /sbin/nologin nginx
- [root@svr5 ~]# tar -zxvf nginx-1.8.0.tar.gz
- [root@svr5 ~]# cd nginx-1.8.0
- [root@svr5 nginx-1.8.0]# ./configure \
- > --prefix=/usr/local/nginx \
- > --user=nginx --group=nginx \
- > --with-http_ssl_module
- [root@svr5 ~]# make && make install
- .. ..
3)安装MariaDB
Mariadb在新版RHEL7光盘中包含有该软件,配置yum源后可以直接使用yum安装:
- [root@svr5 ~]# yum –y install mariadb mariadb-server mariadb-devel
4)php和php-fpm
- [root@svr5 ~]# yum –y install php php-mysql
- [root@svr5 ~]# tar –xf lnmp_soft-2017-03-28.tar.gz
- [root@svr5 ~]# cd lnmp_soft
- [root@svr5 ~]# yum –y localinstall php-fpm-5.4.16-36.el7_1.x86_64.rpm
步骤二:启动服务
1)启动Nginx服务
这里需要注意的是,如果服务器上已经启动了其他监听80端口的服务软件(如httpd),则需要先关闭该服务,否则会出现冲突。
- [root@svr5 ~]# systemctl stop httpd //如果该服务存在则关闭该服务
- [root@svr5 ~]# systemctl disable httpd //关闭httpd的开机启动功能
- [root@svr5 ~]# /usr/local/nginx/sbin/nginx //启动Nginx服务
- [root@svr5 ~]# netstat -utnlp | grep :80
- tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 32428/nginx
2)启动MySQL服务
- [root@svr5 ~]# systemctl start mariadb
- [root@svr5 ~]# systemctl status mariadb
- [root@svr5 ~]# systemctl enable mariadb
3)启动PHP-FPM服务
- [root@svr5 ~]# systemctl start php-fpm
- [root@svr5 ~]# systemctl status php-fpm
- [root@svr5 ~]# systemctl enable php-fpm
2 案例2:构建LNMP平台
2.1 问题
沿用练习一,通过调整Nginx服务端配置,实现以下目标:
- 配置Fast-CGI支持PHP网页
- 创建PHP测试页面,测试使用PHP连接数据库的效果
2.2 方案
使用2台RHEL7虚拟机,其中一台作为LNMP服务器(192.168.4.5)、另外一台作为测试用的Linux客户机(192.168.4.100),如图-1所示。
图-1
Nginx结合FastCGI技术即可支持PHP页面架构,因此本案例,需要延续练习一的实验内容,通过修改Nginx及php-fpm配置文件实现对PHP页面的支持。
php-fpm需要修改的常见配置如下:
listen = 127.0.0.1:9000 //PHP端口号
pm.max_children = 32 //最大进程数量
pm.start_servers = 15 //最小进程数量
pm.min_spare_servers = 5 //最少需要几个空闲着的进程
pm.max_spare_servers = 32 //最多允许几个进程处于空闲状态
2.3 步骤
实现此案例需要按照如下步骤进行。
步骤一:创建并修改php-fpm配置文件
1)查看php-fpm配置文件
- [root@svr5 etc]# vim /etc/php-fpm.d/www.conf
- [www]
- listen = 127.0.0.1:9000
- listen.allowed_clients = 127.0.0.1
- user = apache
- group = apache
- pm = dynamic
- pm.max_children = 50
- pm.start_servers = 5
- pm.min_spare_servers = 5
- pm.max_spare_servers = 35
2)确认php-fpm服务已经启动
- [root@svr5 ~]# systemctl restart php-fpm
- [root@svr5 ~]# systemctl status php-fpm
步骤二:修改Nginx配置文件并启动服务
- [root@svr5 ~]# vim /usr/local/nginx/conf/nginx.conf
- location / {
- root html;
- index index.php index.html index.htm;
- }
- location ~ \.php$ {
- root html;
- fastcgi_pass 127.0.0.1:9000;
- fastcgi_index index.php;
- #fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
- include fastcgi.conf;
- }
- [root@svr5 ~]# /usr/local/nginx/sbin/nginx -s reload
步骤三:创建PHP页面,测试LNMP架构能否解析PHP页面
1)创建PHP测试页面1:
- [root@svr5 ~]# vim /usr/local/nginx/html/test1.php
- <?php
- $i="This is a test Page";
- echo $i;
- ?>
2)创建PHP测试页面,连接MariaDB数据库:
- [root@svr5 ~]# vim /usr/local/nginx/html/test2.php
- <?php
- $links=mysql_connect("localhost","root","密码");
- //注意:root为mysql账户名称,密码需要修改为实际mysql密码,无密码则留空即可
- if($links){
- echo "link db ok!!!";
- }
- else{
- echo "link db no!!!";
- }
- ?>
3)创建PHP测试页面,连接并查询MariaDB数据库:
- [root@svr5 ~]# vim /usr/local/nginx/html/test3.php
- <?php
- $mysqli = new mysqli(‘localhost‘,‘root‘,‘‘,‘mysql‘);
- if (mysqli_connect_errno()){
- die(‘Unable to connect!‘). mysqli_connect_error();
- }
- $sql = "select * from user";
- $result = $mysqli->query($sql);
- while($row = $result->fetch_array()){
- printf("Host:%s",$row[0]);
- printf("</br>");
- printf("Name:%s",$row[1]);
- printf("</br>");
- }
- ?>
4)客户端使用浏览器访问服务器PHP首页文档,检验是否成功:
- [root@client ~]# firefox http://192.168.4.5/test1.php
- [root@client ~]# firefox http://192.168.4.5/test2.php
- [root@client ~]# firefox http://192.168.4.5/test3.php
3 案例3:地址重写
3.1 问题
沿用练习一,通过调整Nginx服务端配置,实现以下目标:
- 所有访问a.html的请求,重定向到b.html;
- 所有访问192.168.4.5的请求重定向至www.tmooc.cn;
- 所有访问192.168.4.5/下面子页面,重定向至www.tmooc.cn/下相同的页面;
- 实现curl访问不同的页面。
3.2 方案
关于Nginx服务器的地址重写,主要用到的配置参数是rewrite:
- rewrite regex replacement flag
3.3 步骤
实现此案例需要按照如下步骤进行。
步骤一:修改配置文件(访问a.html重定向到b.html)
1)修改Nginx服务配置:
- [root@svr5 ~]# vim /usr/local/nginx/conf/nginx.conf
- .. ..
- server {
- listen 80;
- server_name localhost;
- location / {
- root html;
- index index.html index.htm;
- rewrite /a.html /b.html;
- }
- }
2)重新加载配置文件
- [root@svr5 ~]# /usr/local/nginx/sbin/nginx -s reload
3)客户端测试
- [root@client ~]# firefox http://192.168.4.5/a.html
步骤二:修改配置文件(访问192.168.4.5的请求重定向至www.tmooc.cn)
1) 修改Nginx服务配置
- [root@svr5 ~]# vim /usr/local/nginx/conf/nginx.conf
- .. ..
- server {
- listen 80;
- server_name localhost;
- rewrite ^/ http://www.tmooc.cn/;
- location / {
- root html;
- index index.html index.htm;
- }
- }
2)重新加载配置文件
- [root@svr5 ~]# /usr/local/nginx/sbin/nginx -s reload
3)客户端测试
- [root@client ~]# firefox http://192.168.4.5
步骤三:修改配置文件(访问192.168.4.5/下面子页面,重定向至www.tmooc.cn/下相同的页面)
1) 修改Nginx服务配置
- [root@svr5 ~]# vim /usr/local/nginx/conf/nginx.conf
- .. ..
- server {
- listen 80;
- server_name localhost;
- rewrite ^/(.*) http://www.tmooc.cn/$1;
- location / {
- root html;
- index index.html index.htm;
- }
- }
2)重新加载配置文件
- [root@svr5 ~]# /usr/local/nginx/sbin/nginx -s reload
3)客户端测试
- [root@client ~]# firefox http://192.168.4.5
步骤三:修改配置文件(实现curl和火狐访问相同连接返回的页面不同)
1) 修改Nginx服务配置
- .. ..
- server {
- listen 80;
- server_name localhost;
- location / {
- root html;
- index index.html index.htm;
- }
- if ($http_user_agent ~* url) { //识别客户端curl浏览器
- rewrite ^(.*)$ /curl/$1 break;
- }
- }
2)创建网页目录以及对应的页面文件:
- [root@svr5 ~]# echo "I am Normal page" > /usr/local/nginx/html/test.html
- [root@svr5 ~]# mkdir -p /usr/local/nginx/html/curl/
- [root@svr5 ~]# echo "I am is curl page" > /usr/local/nginx/html/curl/test.html
- [root@svr5 ~]# cp /usr/share/backgrounds/gnome/Road.jpg \
- > /usr/local/nginx/curl/test.jpg
2)重新加载配置文件
- [root@svr5 ~]# /usr/local/nginx/sbin/nginx -s reload
4)客户端测试
- [root@client ~]# firefox http://192.168.4.5/test.html
- [root@client ~]# curl http://192.168.4.5/test.html
- [root@client ~]# curl http://192.168.4.5/test.jsp