????????众所周知,LAMP平台是目前应用最为广泛的网站服务器架构,其中的“A”对应着Web服务软件Apache HTTP Server。随着Nginx在企业中的使用越来越多,LNMP架构也受到越来越多Linux系统工程师的青睐
? ? ? ? 就像构建LAMP平台一样,构建LNMP平台也需要Linux服务器,Mysql数据库,PHP解析环境,区别主要在Nginx与PHP的协作配置上。下面将以前安装的Nginx服务器作为基础,介绍LNMP平台的构建方法
? ? ? ? 为了与Nginx、PHP环境保持一致,仍选择采用源码代码编译的方式安装Mysql组件。以8.0.27版本为例,安装过程如下所述
[root@node1 ~]# yum -y install ncurses-devel
[root@node1 ~]# tar zxvf cmake-2.8.6.tar.gz
[root@node1 ~]# cd cmake-2.8.6/
[root@node1 cmake-2.8.6]# ./configure
[root@node1 cmake-2.8.6]# gmake
[root@node1 cmake-2.8.6]# gmake install
[root@node1 cmake-2.8.6]# cd
(1)创建运行用户
为了加强数据库服务的权限控制,建议使用专门的运行用户,如 mysql。此用户不需要直接登录到系统,可以不创建宿主文件夹
[root@node1 ~]# groupadd mysql
[root@node1 ~]# useradd -M -s /sbin/nologin mysql -g mysql
(2)解包
将下载的 MySQL 源码包解压,释放到/usr/src 目录下,并切换到展开后的源码目录?
[root@node1 ~]# tar zxvf mysql-5.6.36.tar.gz -C /usr/src/
[root@node1 ~]# cd /usr/src/mysql-5.6.36/
[root@node1 mysql-5.6.36]#
在内容丰富、结构庞大的企业网站平台中,可能会用到多种字符集的网页,相应地数据库系统也应该支持不同的字符集编码。在配置过程中,可以将默认使用的字符集设置为 utf8,并添加其他字符集的支
[root@node1 mysql-5.6.36]# cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_EXTRA_CHARSETS=all -DSYSCONFDIR=/etc
上述配置命令中,各选项的含义如下
-DCMAKE_INSTALL_PREFIX:指定将 MySQL 数据库程序安装到某目录下,如目 录/usr/local/mysql
-DSYSCONFDIR:指定初始化参数文件目录
-DDEFAULT_CHARSET:指定默认使用的字符集编码,如 utf8
-DDEFAULT_COLLATION:指定默认使用的字符集校对规则,utf8_general_ci 是适用于 UTF-8 字符集的通用规则
-DWITH_EXTRA_CHARSETS:指定额外支持的其他字符集编码
(4)编译及安装
[root@node1 mysql-5.6.36]# make && make install
(1)对数据库目录进行权限设置
[root@node1 mysql-5.6.36]# chown -R mysql:mysql /usr/local/mysql/
(2)建立配置文件
[root@node1 mysql-5.6.36]# rm -rf /etc/my.cnf
//如果原来etc文件夹下有my.cnf文件可以删除
[root@node1 mysql-5.6.36]# cp support-files/my-default.cnf /etc/my.cnf
(3)初始化数据库
为了能够正常使用 MySQL 数据库系统,应以运行用户 mysql 的身份执行初始化脚本 mysql_install_db,指定数据存放目
[root@node1 mysql-5.6.36]# /usr/local/mysql/scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data/
(4)设置环境变量
为了方便在任何目录下使用 mysql 命令,需要在/etc/profile 设置环境变量
[root@node1 mysql-5.6.36]# echo "PATH=$PATH:/usr/local/mysql/bin" >> /etc/profile
4. 启动并访问Mysql服务
MySQL 源码包中提供的服务控制脚本,使用该脚本即可控制 MySQL 服务。找到 support-files 文件夹下的 mysql.server 脚本文件,将其复制到/etc/rc.d/init.d 目录下,并改名为 mysqld,然后再设置执行权
[root@node1 mysql-5.6.36]# cp support-files/mysql.server /etc/rc.d/init.d/mysqld
[root@node1 mysql-5.6.36]# chmod +x /etc/rc.d/init.d/mysqld
这样,以后就可以直接执行/etc/init.d/mysqld 脚本来控制 MySQL 数据库服务了。 例如,若要启动 mysqld 服务,并查看其运行状态,可以执行以下操作
[root@node1 mysql-5.6.36]# /etc/init.d/mysqld start
Starting MySQL.Logging to '/usr/local/mysql/data/node1.err'.
SUCCESS!
[root@node1 mysql-5.6.36]# /etc/init.d/mysqld status
SUCCESS! MySQL running (31916)
[root@node1 mysql-5.6.36]# netstat -anpt | grep mysqld
tcp6 0 0 :::3306 :::* LISTEN 31916/mysqld
[root@node1 mysql-5.6.36] chkconfig --add mysqld
[root@node1 mysql-5.6.36]# . /etc/profile
MySQL 服务器默认通过 TCP 3306 端口提供服务。通过编辑/etc/my.cnf 配置文件中[mysqld]配置段的“port = 3306”行,可以更改监听端口
经过安装后的初始化过程,MySQL 数据库的默认管理员用户名为“root”,为root设置密码
[root@node1 ~]# mysqladmin -u root password 123.123
Warning: Using a password on the command line interface can be insecure.
[root@node1 ~]#
? ? ? ? 较新版本(如5.5)的PHP已经自带FPM模块,用来对PHP解析实例进行管理,优化解析效率,单服务器的LNMP架构通常使用这种方式,因此在配置PHP编译选项时应添加“--enable-fpm”以启动此模块
(1)编译安装PHP
[root@node1 ~]# yum -y install gd libxml2-devel libjpeg-devel libpng-devel
[root@node1 ~]# tar zxvf php-5.5.38.tar.gz -C /usr/src/
[root@node1 php-5.5.38]# ./configure --prefix=/usr/local/php5 \
--with-gd \
--with-zlib \
--with-mysql=/usr/local/mysql --with-mysqli=/usr/local/mysql/bin/mysql_config \
--with-config-file-path=/usr/local/php5 \
--enable-mbstring \
--enable-fpm \
--with-jped-dir=/usr/lib
[root@node1 php-5.5.38]# make && make install
(2)安装后的调整
[root@node1 php-5.5.38]# cp php.ini-development /usr/local/php5/php.ini
[root@node1 php-5.5.38]# ln -s /usr/local/php5/bin/* /usr/local/bin/
[root@node1 php-5.5.38]# ln -s /usr/local/php5/sbin/* /usr/local/sbin/
(3)安装ZendGuardLoader
[root@node1 ~]# tar zxvf zend-loader-php5.5-linux-x86_64_update1.tar.gz -C /usr/src/
zend-loader-php5.5-linux-x86_64/
zend-loader-php5.5-linux-x86_64/ZendGuardLoader.so
zend-loader-php5.5-linux-x86_64/opcache.so
zend-loader-php5.5-linux-x86_64/README.txt
[root@node1 ~]# cd /usr/src/zend-loader-php5.5-linux-x86_64/
[root@node1 zend-loader-php5.5-linux-x86_64]# cp ZendGuardLoader.so /usr/local/php5/lib/php/
[root@node1 zend-loader-php5.5-linux-x86_64]# cd
[root@node1 ~]# vim /usr/local/php5/php.ini
zend_extension=/usr/local/php5/lib/php/ZendGuardLoader.so
zend_loader.enable=1
? ? ? ? 若要让Nginx能够解析PHP网页,有两种方法可以选择:其一,充当中介,将访问PHP页面的Web请求转交给其他服务器(LAMP)去处理;其二,通过使用PHP的FPM模块来调用本机的PHP环境
(1)启用php-fpm进程
如果启用FPM方式,则需要先启动 php-fpm进程,以便监听PHP解析请求,参考范例建立php-fpm.conf配置文件,并修改其中的PID文件,运行用户,服务数(进程数量)等相关设置,然后启动php-fpm程序即可(默认监听本机的9000端口)
[root@node1 ~]# cd /usr/local/php5/etc/
[root@node1 etc]# cp php-fpm.conf.default php-fpm.conf
[root@node1 etc]# useradd -M -s /sbin/nologin php
[root@node1 etc]# vim php-fpm.conf
...... //省略部分信息
pid = run/php-fpm.pid //确认pid文件位置
user = php //运行用户
group = php //运行组
pm.start_servers = 20 //启动时开启的进程数
pm.min_spare_servers = 5 //最少空闲进程数
pm.max_spare_servers = 35
pm.max_children = 50 //最多空闲进程数
[root@node1 etc]# /usr/local/sbin/php-fpm
[root@node1 etc]# netstat -anpt | grep php-fpm
tcp 0 0 127.0.0.1:9000 0.0.0.0:* LISTEN 61807/php-fpm: mast
[root@node1 etc]#
在php-fpm.conf文件中,pid配置行指出了PID信息的存放位置,对应的实际路径为/usr/local/php5/var/run/php-fpm.pid。根据上述信息,可以修改Nginx服务脚本,以便在启动/停止Nginx服务器时将php-fpm进程也自动启动/停止
#!/bin/bash
#chkconfig: - 99 20
PROG="/usr/local/nginx/sbin/nginx"
PIDF="/usr/local/nginx/logs/nginx.pid"
RPOG_FPM="/usr/local/sbin/php-fpm"
PIDF_FPM="/usr/local/php5/var/run/php-fpm.pid"
case "$1" in
start)
$PROG
;;
stop)
kill -s QUIT $(cat $PIDF) //根据PID终止Nginx进程
kill -s QUIT $(cat $PIDF_FPM) //根据PID终止php-fpm进程
;;
restart)
$0 stop
$0 start
;;
reload)
kill -s HUP $(cat $PIDF)
kill -s HUP $(cat $PIDF_FPM)
;;
*)
echo "Usage: $0 {start|stop|restart|reload}"
exit 1
esac
exit 0
因从,一旦启动或关闭Nginx服务,php-fpm程序也会随之启动或关闭,不需要额外再启动或关闭php-fpm
(2)配置Nginx支持PHP解析
无论是将PHP页面交给LAMP服务器去解析,还是调用本机的php-fpm进程进行解析,都需要在“server {}”配置段中添加location设置,以便指定访问.php页面时采用何种操作
对于第一种方法(转交给其他Web服务器处理),使用的配置语句如下。例如,交给IP地址为192.168.161.30的LAMP服务器进行处理,从而实现Nginx负责静态页面,LAMP负责动态页面的分离效果
server {
....
location ~ \.php& { //访问.php页面的配置段
proxy_pass http://192.168.161.30:80; //Apache服务器的监听地址
}
}
对于第二种方法(调用本机的php-fpm进程),使用的配置段如下。在conf/目录下的fastcgi.conf文件中已经包含必需的宏设置,可以通过include语句添加进来
server {
....
location ~ \.php$ {
root /var/www/bdqn;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
include fastcgi_conf;
}
}
上述方法中,选用任何一种都可以,本章的案例中建议选用第二种。完成修改后,重新加载Nginx服务即可生效
(3)PHP页面访问测试
以调用php-fpm解析为例,可以在PHP文档跟目录下创建一个测试网页,用以测试PHP语句能否正常解析,以及能否连接Mysql数据库
[root@node1 ~]# vim /var/www/bdqn/test.php
<?php
$link=mysqli_connect('localhost','root','123.123');
if($link) echo "<h1>恭喜你,数据库连接成功</h1>";
mysqli_close($link);
?>
###浏览器访问页面出现乱码问题
修改nginx配置文件中的Server语段进行更改语言设置为utf-8
server {
listen 80;
server_name localhost;
charset utf-8
访问测试页面,如http://192.168.161.10/test.php。若能够看到成功连接的提示信息如图,则表示PHP解析及数据库连接均正常,否则应根据页面提示,日志信息等进行检查,排除相应的故障
? ? ? ? LNMP平台与LAMP平台是非常相似的,区别主要在于所用Web服务软件不同,而这与使用PHP开发的Web应用程序并无太大关系,因此PHP应用的部署方法也是类似。下面将以“Discuz! 社区论坛”为例,介绍在LNMP平台中的部署过程
“Discuz! 社区论坛”是一个采用PHP与Mysql等多种数据库构建的性能优异,功能全面且安全稳定的社区论坛(BBS)软件,其中官方网站为http://www.discuz.net/。
将下载的Discuz!源码文件解压,找到其中的upload/文件夹并将其放置到LNMP服务器的网站根目录,然后适当调整权限(若此处不调整,也可以参考安装页面的提示再调整),以允许ngin、php-fpm程序拥有必要的写入权限
[root@node1 ~]# yum -y install unzip
[root@node1 ~]# unzip Discuz_X3.3_SC_UTF8.zip
[root@node1 ~]# mv upload/ /var/www/bdqn/bbs
[root@node1 ~]# chown -R php:php /var/www/bdqn/bbs/
Discuz!论坛中的帖子,板块等信息需要保存在数据库中,所以要针对Discuz!创建数据库。为了降低Web应用程序对数据库的风险,建议设置专用的数据库及授权用户,而不要直接使用root用户。例如,可新建bbs库,授权用户为runbbs,具体操作如下
[root@node1 ~]# mysql -u root -p
Enter password:
mysql> CREATE DATABASE bbs; //创建bbs库
Query OK, 1 row affected (0.01 sec)
mysql> GRANT all ON bbs.* TO runbbs@node1 IDENTIFIED BY '123.123'; //授权用户runbbs
Query OK, 0 rows affected (0.01 sec)
mysql>
3. 安装Web应用
访问http://192.168.161.10/bbs/install/index.php,将会打开Discuz!的安装程序,根据页面提示,只需三步即可轻松完成,如图
确保系统环境,目录权限,缓存可写性等检测通过,否则安装将无法继续,在第三步配置安装数据库的步骤中,除了应正确配置数据库连接外,还应该设置好管理账号,密码等基本信息。如图所示,完成安装以后,删除install目录,以降低安全风险
?4. 访问Web应用系统
完成安装后,提供访问http://192.168.161.10/bbs/forum.php,可以看到Discuz社区论坛站点首页,如图
通过访问http://192.168.161.10/bbs/admin.php并以管理员账号登录后,可以进入管理后台如图