用到的软件: 链接: https://pan.baidu.com/s/1Jrt3rSATArYmJutZp1j94w 提取码: bfvh
目前的网站一般都会有动态和静态数据,默认nginx仅可以处理静态数据,用户访问任何数据都是直接返回对应的文件,如果如果访问的是一个脚本的话,就会导致直接返回一个脚本给用户,而用户没有脚本解释器,也看不懂脚本源代码!网站拓扑如图-1所示。
因此需要整合LNMP(Linux、Nginx、MySQL、PHP)实现动态网站效果。
安装必要的依赖软件
图一
安装软件,使用yum安装基础依赖包
yum -y install bzip2-devel curl-devel freetype-devel gcc libjpeg-devel libpng-devel libxslt-devel libxml2-devel openssl-devel pcre-devel pcre-devel zlib-devel
源码安装Nginx(如果已经安装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
解压mysql-5.7.17.tar 软件包
[root@proxy ~]# tar -xvf mysql-5.7.17.tar
安装MySQL软件包
[root@proxy ~]# yum -y install mysql-community-*.rpm
安装php和php-fpm
[root@proxy ~]# yum -y install php php-mysql
[root@proxy ~]# yum -y install php-fpm
启动服务
1)启动Nginx服务(如果已经启动nginx,则可以忽略这一步)
这里需要注意的是,如果服务器上已经启动了其他监听80端口的服务软件,则需要先关闭该服务,否则会出现冲突。
[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
启动MySQL服务
[root@proxy ~]# systemctl start mysqld //启动服务器
[root@proxy ~]# systemctl status mysqld //查看服务状态
[root@proxy ~]# systemctl enable mysqld //设置开机启动
启动PHP-FPM服务
[root@proxy ~]# systemctl start php-fpm //启动服务
[root@proxy ~]# systemctl status php-fpm //查看服务状态
[root@proxy ~]# systemctl enable php-fpm //设置开机启动
构建LNMP平台
通过调整Nginx服务端配置,实现以下目标:
配置Fast-CGI支持PHP网页
创建PHP测试页面,测试使用PHP连接数据库的效果
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 //最小进程数量
修改Nginx配置文件并启动服务
[root@proxy ~]# vim /usr/local/nginx/conf/nginx.conf
location / {
root html;
index index.php index.html index.htm;
#设置默认首页为index.php,当用户在浏览器地址栏中只写域名或IP,不说访问什么页面时,服务器会把默认首页index.php返回给用户
}
location ~ \.php$ {
root html;
fastcgi_pass 127.0.0.1:9000; #将请求转发给本机9000端口,PHP解释器
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
#请先确保nginx是启动状态,否则运行该命令会报错,报错信息如下:
#[error] open() "/usr/local/nginx/logs/nginx.pid" failed (2: No such file or directory)
创建PHP页面,测试LNMP架构能否解析PHP页面
1)创建PHP测试页面
[root@proxy ~]# vim /usr/local/nginx/html/test.php
<?php
$i="This is a test Page";
echo $i;
?>
创建PHP测试页面,连接并查询MySQL数据库
[root@proxy ~]# vim /usr/local/nginx/html/mysql.php
<?php
$mysqli = new mysqli(‘localhost’,‘root’,‘密码’,‘mysql’);
//注意:root为mysql数据库的账户名称,密码需要修改为实际mysql密码,无密码则留空即可
//localhost是数据库的域名或IP,mysql是数据库的名称
if (mysqli_connect_errno()){
die(‘Unable to connect!’). mysqli_connect_error();
}
$sql = “select * from user”;
$result =
m
y
s
q
l
i
−
>
q
u
e
r
y
(
mysqli->query(
mysqli−>query(sql);
while($row = KaTeX parse error: Expected '}', got 'EOF' at end of input: …intf("Host:%s",row[0]);
printf("");
printf(“Name:%s”,$row[1]);
printf("");
}
?>
客户端使用浏览器访问服务器PHP首页文档,检验是否成功:
[root@client ~]# firefox http://192.168.4.5/test.php
[root@client ~]# firefox http://192.168.4.5/mysql.php
LNMP常见问题
Nginx的默认访问日志文件为/usr/local/nginx/logs/access.log
Nginx的默认错误日志文件为/usr/local/nginx/logs/error.log
PHP默认错误日志文件为/var/log/php-fpm/www-error.log
如果动态网站访问失败,可用参考错误日志,查找错误信息。