一、LNMP概念
LNMP架构是一种常见的网站服务器架构,由Linux操作系统、Nginx Web服务器、MySQL数据库和PHP后端脚本语言组成。
1 用户请求:用户通过浏览器输入网址,请求发送到Nginx Web服务器。
2 Nginx处理:Nginx接收请求后,如果是静态资源(如HTML、图片、CSS文件),直接返回给用户;如果是动态请求(如PHP页面),则通过FastCGI接口转发给PHP-FPM。
3 PHP处理:PHP-FPM接收请求后,解析PHP代码。如果需要读取数据库数据,PHP会向MySQL数据库发起请求。
4 数据返回:MySQL返回数据后,PHP处理完成,最终通过Nginx将结果返回给用户。
二、系统、服务的环境
以下是服务对应的环境要求,nginx和mysql以及php都是在官网下载源包
组件版本表 | ||
组件 | 版本要求 | 备注 |
操作系统(linux) | Centos7 | 稳定且支持广泛的操作系统 |
Nginx | 1.22.0 | 高性能 Web 服务器和反向代理 |
MySQL | 5.7 | 稳定且广泛使用的关系型数据库 |
PHP | 7.1 | 适用于大多数 Web 应用的 PHP 版本 |
三、LNMP编译过程
1. 编译安装nginx服务
1.1 更新yum源,安装阿里云的yun源。提高下载速度,并提高稳定性。
curl -o /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo
1.2 通过ssh连接软件,将nginx包放在服务器的/opt/目录下,并解压和安装对应的依赖包
cd /opt
yum -y install pcre-devel zlib-devel gcc gcc-C++ make
tar zxvf nginx-1.22.0.tar.gz
1.3 创建一个nginx用户,使用专门的用户可以隔离Nginx的运行环境,避免与其他系统服务或用户进程冲突。
useradd -M-s /sbin/nologin nginx
tail -1 /etc/passwd
1.4 进入nginx目录,开始编译nginx,编译安装可以提高程序的安全性。
./configure \
prefix=/usr/local/nginx
user=nginx
group=nginx
with-http_ stub_status module
1.5 编译完成后,安装nginx。
make && make install
1.6 创建nginx的软链接,并将这个服务加入system管理。重启系统服务,并启动nginx服务。解决路径依赖,避免每次都要输入完整安装路径。
ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/
tee /lib/systemd/system/nginx.service <<eof
[Unit]
Description=nginx
After=network.target
[Service]
Type=forking
PIDFile=/usr/local/nginx/logs/nginx.pid
ExecStart=/usr/local/nginx/sbin/nginx
ExecReload=/bin/kill -1 $MAINPID
ExecStop=/bin/kill -3 $MAINPID
PrivateTmp=true
[Install]
WantedBy=multi-user.target
eof
#重启系统并查看服务
systemctl daemon-reload
systemctl start nginx
systemctl status nginx
1.7 查看nginx的端口情况,并在终端验证nginx服务是否安装成功。
ss -antp | grep nginx
2. 编译安装mysql服务
2.1 通过ssh连接软件,将mysql包放在服务器的/opt/目录下,并解压
cd /opt
tar zxvf mysql-boost-5.7.20.tar.gz
2.2 在终端安装mysql的依赖包。确保了核心功能的使用,并防止常见的编译安装错误问题。
yum -y install gcc gcc-c++ cmake bison bison-devel zlib-devel libcurl-devel libarchive-devel boost-devel ncurses-devel gnutls-devel libxml2-devel openssl-devel libevent-devel libaio-devel
2.3 创建mysql用户,便于管理mysql的权限和文件。
useradd -M -s /sbin/nologin mysql
2.4 进入mysql目录下,编译mysql包。
注:在CentOS 7.9上,由于默认的软件仓库不包含最新版本的Boost库,boost的版本号是1.53.0版本,与mysql5.7版本不兼容,在编译mysql之前,先编译安装boost1.59.0版本
cd /opt/mysql-5.7.20/
cmake \
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \
-DSYSCONFDIR=/etc \
-DSYSTEMD_PID_DIR=/usr/local/mysql \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DWITH_EXTRA_CHARSETS=all \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \
-DMYSQL_DATADIR=/usr/local/mysql/data \
-DWITH_BOOST=boost \
-DWITH_SYSTEMD=1
2.5 编译安装mysql
make -j2 && make install
2.6 将mysql的配置文件并添加到系统环境变量内,并重新加载环境变量,进入mysql的bin目录下,初始化mysql服务。在编写mysql文件,将mysql服务加入system管理,并启动mysql服务。
vim /etc/my.cnf
[client]
port = 3306
socket=/usr/local/mysql/mysql.sock
[mysqld]
user = mysql
basedir=/usr/local/mysql
datadir=/usr/local/mysql/data
port = 3306
character-set-server=utf8
pid-file = /usr/local/mysql/mysqld.pid
socket=/usr/local/mysql/mysql.sock
bind-address = 0.0.0.0
skip-name-resolve
max_connections=2048
default-storage-engine=INNODB
max_allowed_packet=16M
server-id = 1
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_AUTO_VALUE_ON_ZERO,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,PIPES_AS_CONCAT,ANSI_QUOTES
#添加环境变量
echo 'export PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH' >> /etc/profile
source /etc/profile
#mysql服务加入system中的操作步骤
cd /usr/local/mysql/bin/
./mysqld \
--initialize-insecure \
--user=mysql \
--basedir=/usr/local/mysql \
--datadir=/usr/local/mysql/data
cp /usr/local/mysql/usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/
systemctl daemon-reload
systemctl enable --now mysqld
systemctl start mysqld
systemctl status mysqld
2.7 查看mysql的端口情况,登录mysql,设置mysql密码。
ss -antp | grep mysql
mysql -uroot -p (密码部分直接回车,如果之前安装mysql时有密码弹出,直接输入系统自动生成的密码)
#进入mysql输入以下内容
CREATE DATABASE bbs;
GRANT all ON bbs.* TO 'bbsuser'@'%' IDENTIFIED BY 'admin123';
GRANT all ON bbs.* TO 'bbsuser'@'localhost' IDENTIFIED BY 'admin123';
flush privileges;
3. 编译安装php服务
3.1 通过ssh连接软件,将php包放在服务器的/opt/目录下,并解压
cd /opt
tar xf php-7.1.10.tar.bz2
3.2 安装php的依赖包,避免在编译的过程中可以确保服务在运行时不会因为缺少必要的组件而崩溃。
yum -y install gd \
libjpeg libjpeg-devel \
libpng libpng-devel \
freetype freetype-devel \
libxml2 libxml2-devel \
zlib zlib-devel \
curl curl-devel \
openssl openssl-devel
3.3 解压php文件,进入php目录下,开始编译php服务。
cd /opt/php-7.1.10/
./configure \
--prefix=/usr/local/php \
--with-mysql-sock=/usr/local/mysql/mysql.sock \
--with-mysqli \
--with-zlib \
--with-curl \
--with-gd \
--with-jpeg-dir \
--with-png-dir \
--with-freetype-dir \
--with-openssl \
--enable-fpm \
--enable-mbstring \
--enable-xml \
--enable-session \
--enable-ftp \
--enable-pdo \
--enable-tokenizer \
--enable-zip
3.4 安装php服务。
make -j2 && make install
3.5 为php服务添加软链接,确保php服务能够被系统正确识别和调用。
ln -s /usr/local/php/bin/* /usr/local/bin/
ln -s /usr/local/php/sbin/* /usr/local/sbin/
3.6 修改php服务的3个配置文件,以适应OA系统的特定需求。调整文件中的参数,如内存限制、执行时间限制和文件上传大小等。
php.ini 主配置文件
php-fpm.conf 进程服务配置文件
www.conf 扩展配置文件
#修改 ----------- php.ini 文件
cp /opt/php-7.1.10/php.ini-development /usr/local/php/lib/php.ini
#修改 1170 行
mysqli.default_socket = /usr/local/mysql/mysql.sock
#修改 939 行
date.timezone = Asia/Shanghai
#修改 ----------- php-fpm.conf文件
cd /usr/local/php/etc/
cp php-fpm.conf.default php-fpm.conf
vim php-fpm.conf
#--17行--去掉";"注释
pid = run/php-fpm.pid
#修改第三个文件 ------------------ www.conf
cd /usr/local/php/etc/php-fpm.d/
cp www.conf.default www.conf
3.7 将php服务加入system中,确保服务在系统启动时自动运行。配置完成后,重启服务器以使更改生效。
cd /opt/php-7.1.10/sapi/fpm
cp php-fpm.service /usr/lib/systemd/system/php-fpm.service
systemctl daemon-reload
systemctl start php-fpm.service
systemctl status php-fpm.service
4. 调试nginx,mysql,php服务
4.1 修改nginx的配置文件,确保与php交互没有问题,修改完成后,重启nginx服务。验证php服务能否顺利与nginx服务进行交互,确保nginx能正确地把请求转发给php处理。
vi /usr/local/nginx/conf/nginx.conf
location / {
root html;
index index.html index.htm index.php;
}
location ~ \.php$ {
root html;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /usr/local/nginx/html$fastcgi_script_name;
include fastcgi_params;
}
systemctl restart nginx
systemctl status nginx
vim /usr/local/nginx/html/index.php
<?php
phpinfo();
?>
4.2 测试mysql服务于与php服务能否正常,运行一个简单的php脚本来检查数据库连接是否成功。
#测试 数据库是否可以访问
vim /usr/local/nginx/html/index.php #替换原来的测试页内容
<?php
$link=mysqli_connect('本地服务器的IP地址','bbsuser','admin123');
if($link) echo "<h1>Success!!</h1>";
else echo "Fail!!";
?>