linux-运维进阶-28 LNMP动态网站架构
LNMP动态网站架构
LNMP动态网站部署架构是一套由Linux + Nginx + MySQL + PHP组成的动态网站系统解决方案。LNMP中的字母L是Linux系统的意思,不仅可以是RHEL、CentOS、Fedora,还可以是Debian、Ubuntu等系统
开发环境的部署
在使用源码包安装服务程序之前,首先要让安装主机具备编译程序源码的环境,他需要具备C语言、C++语言、Perl语言的编译器,以及各种常见的编译支持函数库程序。因此请先配置妥当Yum软件仓库,然后把下面列出的这些软件包都统统安装上
1 | [root@localhost src]# yum install -y apr* autoconf automake bc bison bzip2 bzip2* compat* cpp curl curl-devel elfutils-libelf-devel flex fontconfig fontconfig-devel freetype freetype* freetype-devel gcc gcc-c++ gd gettext gettext-devel glibc kernel kernel-headers keyutils keyutils-libs-devel krb5-devel libcom_err-devel libpng libpng-devel libjpeg* libsepol-devel libselinux-devel libstdc++-devel libtool* libgomp libxml2 libxml2-devel libXpm* libtifflibtiff* make mpfr ncurses* ntp ncurses-devel openssl openssl-devel patch pcre-devel perlphp-common php-gd policycoreutils telnet t1lib t1lib* nasm nasm* wget zlib-devel unzip |
下载软件包
下载安装LNMP动态网站部署架构所需的16个软件源码包和1个用于检查效果的论坛网站系统软件包
1 | [root@localhost ~]# cd /usr/local/src/ |
安装cmake
CMake是Linux系统中一款常用的编译工具。要想通过源码包安装服务程序,就一定要严格遵守上面总结的安装步骤—下载及解压源码包文件、编译源码包代码、生成二进制安装程序、运行二进制的服务程序安装包。
1 | [root@localhost src]# tar xzvf cmake-2.8.11.2.tar.gz |
配置MySQL服务
1 | [root@localhost cmake-2.8.11.2]# cd .. |
接下来解压、编译、安装MySQL数据库服务程序。在编译数据库时使用的是cmake命令,其中,
-DCMAKE_INSTALL_PREFIX参数用于定义数据库服务程序的保存目录,
-DMYSQL_DATADIR参数用于定义真实数据库文件的目录,
-DSYSCONFDIR则是定义MySQL数据库配置文件的保存目录。(编译时间较长,为了防止ssh断开,建议screen运行!)
1 | [root@localhost src]# tar xzvf mysql-5.6.19.tar.gz |
为了让MySQL数据库程序正常运转起来,需要先删除/etc目录中的默认配置文件。
然后在MySQL数据库程序的保存目录scripts内找到一个名为mysql_install_db的脚本程序。
执行这个脚本程序并使用–user参数指定MySQL服务的对应账号名称(在前面步骤已经创建)。
使用–basedir参数指定MySQL服务程序的保存目录。
使用–datadir参数指定MySQL真实数据库的文件保存目录。
这样即可生成系统数据库文件,也会生成出新的MySQL服务配置文件。
1 | [root@linuxprobe mysql-5.6.19]# rm -rf /etc/my.cnf |
把系统新生成的MySQL数据库配置文件链接到/etc目录中,然后把程序目录中的开机程序文件复制到/etc/rc.d/init.d目录中,以便通过service命令来管理MySQL数据库服务程序。记得把数据库脚本文件的权限修改成755以便于让用户有执行该脚本的权限:
1 | [root@localhost mysql]# ln -s my.cnf /etc/my.cnf |
编辑刚复制的MySQL数据库脚本文件,把第46、47行的basedir与datadir参数分别修改为MySQL数据库程序的保存目录和真实数据库的文件内容。
1 | [root@localhost mysql]# vim /etc/rc.d/init.d/mysqld |
启动mysql,并且设置开机启动
1 | [root@localhost mysql]# service mysqld start |
把命令所保存的目录永久性地定义到PATH变量中,需要编辑/etc/profile文件并写入追加的命令目录,这样当物理设备在下一次重启时就会永久生效了。如果不想通过重启设备的方式来生效,也可以使用source命令加载一下/ect/profile文件,此时新的PATH变量也可以立即生效了。
1 | [root@localhost mysql]# vim /etc/profile |
MySQL数据库服务程序还会调用到一些程序文件和函数库文件。由于当前是通过源码包方式安装MySQL数据库,因此现在也必须以手动方式把这些文件链接过来。
1 | [root@linuxprobe mysql]# mkdir /var/lib/mysql |
初始化数据库
- 设置root管理员在数据库中的密码值(注意,该密码并非root管理员在系统中的密码,这里的密码值默认应该为空,可直接按回车键)。
- 设置root管理员在数据库中的专有密码。
- 随后删除匿名账户,并使用root管理员从远程登录数据库,以确保数据库上运行的业务的安全性。
- 删除默认的测试数据库,取消测试数据库的一系列访问权限。
- 刷新授权列表,让初始化的设定立即生效。
1 |
|
登录数据库
1 |
|
配置nginx服务
解决相关的软件依赖关系
提供Perl语言兼容的正则表达式库的软件包pcre
1 | [root@localhost ~]# cd /usr/local/src |
openssl软件包是用于提供网站加密证书服务的程序文件,在安装该程序时需要自定义服务程序的安装目录,以便于稍后调用它们的时候更可控。
1 | [root@localhost pcre-8.35]# cd /usr/local/src |
openssl软件包安装后默认会在/usr/local/openssl/bin目录中提供很多的可用命令,我们需要像前面的操作那样,将这个目录添加到PATH环境变量中,并写入到配置文件中,最后执行source命令以便让新的PATH环境变量内容可以立即生效
1 | [root@localhost openssl-1.0.1h]# vim /etc/profile |
zlib软件包是用于提供压缩功能的函数库文件。其实Nginx服务程序调用的这些服务程序无需深入了解,只要大致了解其作用就已经足够了
1 | [root@localhost openssl-1.0.1h]# cd /usr/local/src/ |
创建一个用于执行Nginx服务程序的账户。账户名称可以自定义
1 | [root@localhost zlib-1.2.8]# cd .. |
其中,–prefix参数用于定义服务程序稍后安装到的位置,
–user与–group参数用于指定执行Nginx服务程序的用户名和用户组。
在使用参数调用openssl、zlib、pcre软件包时,请写出软件源码包的解压路径,而不是程序的安装路径
1 | [root@localhost src]# tar xzvf nginx-1.6.0.tar.gz |
要想启动Nginx服务程序以及将其加入到开机启动项中,也需要有脚本文件。
1 | [root@localhost nginx-1.6.0]# curl https://raw.githubusercontent.com/xcracker/linux_shell/master/init.d/nginx > /etc/rc.d/init.d/nginx |
上面curl链接的网址存放着脚本代码,如下图:
浏览器打开服务器ip,查看是否成功
配置PHP服务
yasm源码包是一款常见的开源汇编器
1 | [root@localhost nginx-1.6.0]# cd .. |
libmcrypt源码包是用于加密算法的扩展库程序
1 | [root@localhost yasm-1.2.0]# cd .. |
libvpx源码包是用于提供视频编码器的服务程序
1 | [root@linuxprobe libmcrypt-2.5.8]# cd .. |
tiff源码包是用于提供标签图像文件格式的服务程序
1 | [root@localhost libvpx-v1.3.0]# cd .. |
libpng源码包是用于提供png图片格式支持函数库的服务程序
1 | [root@localhost tiff-4.0.3]# cd .. |
freetype源码包是用于提供字体支持引擎的服务程序
1 | [root@localhost libpng-1.6.12]# cd .. |
jpeg源码包是用于提供jpeg图片格式支持函数库的服务程序
1 | [root@localhost freetype-2.5.3]# cd .. |
libgd源码包是用于提供图形处理的服务程序,在编译libgd源码包时,请记得写入的是jpeg、libpng、freetype、tiff、libvpx等服务程序在系统中的安装路径,即在上面安装过程中使用–prefix参数指定的目录路径
1 | [root@localhost jpeg-9a]# cd .. |
t1lib源码包是用于提供图片生成函数库的服务程序
安装后把/usr/lib64目录中的函数文件链接到/usr/lib目录中,以便系统能够顺利调取到函数文件
1 | [root@localhost libgd-2.1.0]# cd .. |
此时终于把编译php服务源码包的相关软件包都已经安装部署妥当了。
在开始编译php源码包之前,先定义一个名为LD_LIBRARY_PATH的全局环境变量,该环境变量的作用是帮助系统找到指定的动态链接库文件,这些文件是编译php服务源码包的必须元素之一。
编译php服务源码包时,除了定义要安装到的目录以外,还需要依次定义配置php服务程序配置文件的保存目录、MySQL数据库服务程序所在目录、MySQL数据库服务程序配置文件所在目录,以及libpng、jpeg、freetype、libvpx、zlib、t1lib等服务程序的安装目录路径,并通过参数启动php服务程序的诸多默认功能
1 | [root@localhost t1lib-5.1.2]# cd .. |
在php源码包程序安装完成后,需要删除当前默认的配置文件,然后将php服务程序目录中相应的配置文件复制过来
1 | [root@localhost php-5.5.14]# rm -rf /etc/php.ini |
php-fpm.conf是php服务程序重要的配置文件之一,我们需要启用该配置文件中第25行左右的pid文件保存目录(去掉那一行备注),然后分别将第148和149行的user与group参数分别修改为www账户和用户组名称
1 | [root@localhost php-5.5.14]# vim /usr/local/php/etc/php-fpm.conf |
配置妥当后便可把用于管理php服务的脚本文件复制到/etc/rc.d/init.d中了。为了能够执行脚本,请记得为脚本赋予755权限。最后把php-fpm服务程序加入到开机启动项中
1 | [root@localhost php-5.5.14]# cp sapi/fpm/init.d.php-fpm /etc/rc.d/init.d/php-fpm |
为了安全,编辑php.ini配置文件,在305行的disable_functions参数后面追加上要禁止的功能。(注意:disable_functions = 后面直接接那一大串东西,不要回车换行!)
1 | [root@localhost php-5.5.14]# vim /usr/local/php/etc/php.ini |
编辑Nginx服务程序的主配置文件,
把第2行的井号(#)删除,然后在后面写上负责运行Nginx服务程序的账户名称和用户组名称;
在第45行的index参数后面写上网站的首页名称。
最后是将第65~71行参数前的井号(#)删除来启用参数,主要是修改第69行的脚本名称路径参数,
其中$document_root变量即为网站信息存储的根目录路径,若没有设置该变量,则Nginx服务程序无法找到网站信息,因此会提示“404页面未找到”的报错信息。
在确认参数信息填写正确后便可重启Nginx服务与php-fpm服务
1 | [root@localhost php-5.5.14]# vim /usr/local/nginx/conf/nginx.conf |
要改动的地方上面也都写了,参考自网上的文章,如果你担心配错要检查的话,看下面配置文件原文:
1 | user www www; |
搭建Discuz论坛
为了检验LNMP动态网站环境是否配置妥当,可以使用在上面部署Discuz!系统,然后查看结果。如果能够在LNMP动态网站环境中成功安装使用Discuz!论坛系统,也就意味着这套架构是可用的。Discuz! X3.2是国内最常见的社区论坛系统,在经过十多年的研发后已经成为了全球成熟度最高、覆盖率最广的论坛网站系统之一。
Discuz! X3.2软件包的后缀是.zip格式,因此应当使用专用的unzip命令来进行解压。解压后会在当前目录中出现一个名为upload的文件目录,这里面保存的就是Discuz!论坛的系统程序。我们把Nginx服务程序网站根目录的内容清空后,就可以把这些这个目录中的文件都复制进去了。我们已经把Nginx服务程序的网站根目录的所有者和所属组修改为本地的www用户了,并为其赋予755权限以便于能够读、写、执行该论坛系统内的文件。
1 | [root@localhost php-5.5.14]# cd /usr/local/src/ |
打开IP地址,加上/install,如果是下面这个样子,那九成九都是你的配置文件配置错了,需要再次检查:
1 | vim /usr/local/nginx/conf/nginx.conf |
如果你的配置文件正确,那么基本上不会有问题,可以开始安装Discuz论坛了。
浏览器敲入ip,它会跳转到http://192.168.141.132/install/,开始安装。
之前初始化mysql的时候你设置的root密码填上,另外再给你的论坛管理员admin想一个密码
论坛登录成功!本篇到此结束。