构建LNMP

                                                                         构建LNMP

案例1:部署LNMP环境

案例2:构建LNMP平台

案例3:地址重写

1案例1:部署LNMP环境

1.1问题

安装部署NginxMariaDBPHP环境

安装部署NginxMariaDBPHPPHP-FPM

启动NginxMariaDBFPM服务;

并测试LNMP是否工作正常。        

                   

1.2方案

RHEL7系统中,源码安装Nginx,使用RPM包安装MariaDBPHPPHP-FPM软件。

操作过程中需要安装的软件列表如下:

nginx

mariadbmariadb-servermariadb-devel

phpphp-fpmphp-mysql

1.3步骤

实现此案例需要按照如下步骤进行。

步骤一:安装软件

1)使用yum安装基础依赖包

[root@proxy~]#yum -y install gcc openssl-devel pcre-devel zlib-devel

2)源码安装Nginx

[root@proxy~]#useradd  -s /sbin/nologin nginx

[root@proxy~]#tar -xvf nginx-1.12.2.tar.gz

[root@proxy~]#cd nginx-1.12.2

[root@proxy nginx-1.12.2]#./configure\

>--user=nginx--group=nginx\

>--with-http_ssl_module

[root@proxy~]#make && make install

....

3)安装MariaDB

Mariadb在新版RHEL7光盘中包含有该软件,配置yum源后可以直接使用yum安装:

[root@proxy~]#yum -y install mariadb mariadb-server mariadb-devel

4phpphp-fpm(该软件包在lnmp_soft中提供)

[root@proxy~]#yum -y install php php-mysql

[root@proxy~]#yum -y install php-fpm-5.4.16-42.el7.x86_64.rpm

步骤二:启动服务

1)启动Nginx服务

这里需要注意的是,如果服务器上已经启动了其他监听80端口的服务软件(如httpd),则需要先关闭该服务,否则会出现冲突。

[root@proxy~]#systemctl stop httpd//如果该服务存在则关闭该服务

[root@proxy~]#/usr/local/nginx/sbin/nginx//启动Nginx服务

[root@proxy~]#netstat -utnlp | grep:80

tcp 0 0 0.0.0.0:80 0.0.0.0:*LISTEN 32428/nginx

2)启动MySQL服务

[root@proxy~]#systemctl start mariadb//启动服务器

[root@proxy~]#systemctl status mariadb//查看服务状态

[root@proxy~]#systemctl enable mariadb//设置开机启动

3)启动PHP-FPM服务

[root@proxy~]#systemctl start php-fpm//启动服务

[root@proxy~]#systemctl status php-fpm//查看服务状态

[root@proxy~]#systemctl enable php-fpm//设置开机启动

4)设置防火墙与SELinux

[root@proxy~]#firewall-cmd --set-default-zone=trusted

[root@proxy~]#setenforce 0


 案例2:构建LNMP平台

2.1问题

沿用练习一,通过调整Nginx服务端配置,实现以下目标:

配置Fast-CGI支持PHP网页

创建PHP测试页面,测试使用PHP连接数据库的效果

2.2方案

使用2RHEL7虚拟机,其中一台作为LNMP服务器(192.168.4.5)、另外一台作为测试用的Linux客户机(192.168.4.100),如图-1所示。

-1

Nginx结合FastCGI技术即可支持PHP页面架构,因此本案例,需要延续练习一的实验内容,通过修改Nginxphp-fpm配置文件实现对PHP页面的支持。

2.3步骤

实现此案例需要按照如下步骤进行。

步骤一:创建并修改php-fpm配置文件

1)查看php-fpm配置文件

[root@proxy etc]#vim /etc/php-fpm.d/www.conf

[www] 

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)确认php-fpm服务已经启动

[root@proxy~]#systemctl restart php-fpm//重启服务

[root@proxy~]#systemctl status php-fpm

步骤二:修改Nginx配置文件并启动服务

[root@proxy~]#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@proxy~]#/usr/local/nginx/sbin/nginx-s reload

步骤三:创建PHP页面,测试LNMP架构能否解析PHP页面

1)创建PHP测试页面1,可以参考lnmp_soft/php_scripts/test.php

[root@proxy~]#vim /usr/local/nginx/html/test1.php

<?php

$i="This is a test Page";

echo$i;

?>

2)创建PHP测试页面,连接并查询MariaDB数据库。

可以参考lnmp_soft/php_scripts/mysql.php:

[root@proxy~]#vim  /usr/local/nginx/html/test2.php

<?php

$mysqli=new mysqli('localhost','root','密码','mysql');

//注意:rootmysql账户名称,密码需要修改为实际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>");

}

?>

3)客户端使用浏览器访问服务器PHP首页文档,检验是否成功:

[root@client~]#firefox http://192.168.4.5/test1.php

[root@client~]#firefox http://192.168.4.5/test2.php

4LNMP常见问题

Nginx的默认访问日志文件为/usr/local/nginx/logs/access.log

Nginx的默认错误日志文件为/usr/local/nginx/logs/error.log

PHP默认错误日志文件为/var/log/php-fpm/www-error.log

如果动态网站访问失败,可用参考错误日志,查找错误信息。


 案例3:地址重写

3.1问题

沿用练习二,通过调整Nginx服务端配置,实现以下目标:

所有访问a.html的请求,重定向到b.html;

所有访问192.168.4.5的请求重定向至www.tmooc.cn

所有访问192.168.4.5/下面子页面,重定向至www.tmooc.cn/下相同的页面;

实现firefoxcurl访问相同页面文件,返回不同的内容。

3.2方案

关于Nginx服务器的地址重写,主要用到的配置参数是rewrite

rewrite regex replacement flag

rewrite旧地址新地址[选项]

3.3步骤

实现此案例需要按照如下步骤进行。

步骤一:修改配置文件(访问a.html重定向到b.html)

1)修改Nginx服务配置:

[root@proxy~]#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;

}

}

[root@proxy~]#echo "BB" > /usr/local/nginx/html/b.html

2)重新加载配置文件

[root@proxy~]#/usr/local/nginx/sbin/nginx -s reload

3)客户端测试

[root@client~]#firefox http://192.168.4.5/a.html

步骤二:访问a.html重定向到b.html(跳转地址栏)

1)修改Nginx服务配置:

[root@proxy~]#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 redirect;

}

}

2)重新加载配置文件

[root@proxy~]#/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@proxy~]#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;

#rewrite/a.html/b.html redirect;

}

}

2新加载配置文件

[root@proxy~]#/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@proxy~]#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;

#rewrite/a.html/b.html redirect;

}

}

2)重新加载配置文件

[root@proxy~]#/usr/local/nginx/sbin/nginx-s reload

3)客户端测试

[root@client~]#firefox http://192.168.4.5

步骤五:修改配置文件(实现curl和火狐访问相同链接返回的页面不同)

1)创建网页目录以及对应的页面文件:

[root@proxy~]#echo "I am Normal page"  >   /usr/local/nginx/html/test.html

[root@proxy~]#mkdir -p /usr/local/nginx/html/firefox/

[root@proxy~]#echo "firefox  page" >            /usr/local/nginx/html/firefox/test.html

2)修改Nginx服务配置

[root@proxy~]#vim /usr/local/nginx/conf/nginx.conf

....

server{

listen 80;

server_name localhost;

location/{

root html;

index index.html index.htm;

}

if($http_user_agent~*firefox){//识别客户端firefox浏览器

rewrite^(.*)$/firefox/$1;

}

}

3)重新加载配置文件

[root@proxy~]#/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

5)地址重写格式【总结】

rewrite旧地址新地址[选项];

last不再读其他rewrite

break不再读其他语句,结束请求

redirect临时重定向

permament永久重定向

猜你喜欢

转载自www.cnblogs.com/qingbai/p/11941910.html
今日推荐