自动化部署LNMP架构的Shell脚本方案,该脚本将传统2小时的手动部署过程缩减至5分钟。脚本采用模块化设计,包括Nginx、MySQL、PHP的独立安装函数,严格遵循安装顺序并实现资源隔离(如为MySQL创建专用材料目录)。核心消除了版本兼容性问题(预设Nginx1.9.5+MySQL5.7.26+PHP5.6.40组合)和服务配置难题,自动结束防火墙关闭、权限配置等关键操作。

目录

一、原理与理论

LNMP架构核心

脚本设计原理

二、背景及目的

痛点背景:

脚本价值:

三、关键步骤说明 

关键步骤解析:

四、常见问题及解决方案

五、总结与心得

 脚本获取:


一、原理与理论

  1. LNMP架构核心

    • Linux:操作系统基础环境

    • Nginx:高性能Web服务器(处理静态请求)

    • MySQL:关系型数据库(存储动态数据)

    • PHP:服务端脚本语言(动态内容生成)

    • 工作流程用户请求 → Nginx接收 → PHP处理动态请求 → MySQL读写数据 → 返回结果

  2. 脚本设计原理

    • 模块化函数:将各组件安装拆分为独立函数(nginx_install()mysql_install()等)

    • 依赖顺序控制:严格遵循 Nginx → MySQL → PHP 的编译安装顺序

    • 安全隔离:为服务创建专用系统用户(www/mysql)

    • 资源分离:数据库存储独立挂载到 /data/mysql


二、背景及目的

  • 痛点背景

    • 手动部署LNMP环境步骤繁琐,平均耗时2小时+

    • 组件版本兼容性问题频发(如PHP扩展依赖)

    • 配置参数易遗漏(如MySQL socket路径)

  • 脚本价值

    • ✅ 30分钟→5分钟:全自动化编译安装

    • ✅ 解决版本兼容:预设验证版本(Nginx 1.9.5+MySQL 5.7.26+PHP 5.6.40)

    • ✅ 开箱即用:集成WordPress CMS部署

    • ✅ 安全加固:自动关闭SELinux/firewalld(生产环境需调整


三、关键步骤说明

关键步骤解析

  • 前置处理

systemctl stop firewalld  # 关闭防火墙
sed -i 's/SELINUX=.*/SELINUX=disabled/g' /etc/selinux/config  # 禁用SELinux
  • MySQL安全初始化
chown -R mysql:mysql /data/mysql/  # 数据目录权限控制
/usr/local/mysql/bin/mysqld --initialize-insecure  # 免密初始化
  • PHP-FPM优化  PHP-FPM 优化
location ~ \.php$ {
fastcgi_pass 127.0.0.1:9000;  # PHP处理器监听
include fastcgi.conf;  # 关键配置文件
}

四、常见问题及解决方案

问题现象原因分析解决方案
make: *** No targets specified源码包未成功解压检查/usr/src/下文件完整性
MySQL启动失败mysql.sock权限不足执行chown -R mysql:mysql /usr/local/mysql/  香贤 chown -R mysql:mysql /usr/local/mysql/
PHP无法连接MySQL未配置socket路径修改php.inimysqli.default_socket = /usr/local/mysql/mysql.sock
Nginx 403错误WordPress目录权限不足运行chmod -R 777 /usr/local/nginx/html
无法外网访问防火墙未关闭确认执行了systemctl disable firewalld
确认执行了 systemctl disable firewalld

五、总结与心得

  1. 脚本优势

    • 版本控制精准:规避了依赖冲突问题

    • 资源隔离完善:数据库独立存储+服务专用用户

    • 自动化程度高:从环境配置到CMS部署一键完成

  2. 生产环境建议

    • 安全强化

      • 恢复SELinux并配置策略(setenforce 1

      • 改用非root用户运行Nginx(脚本已支持)

    • ⚙️ 配置优化

      • Nginx启用gzip压缩(取消配置文件中#gzip on;注释)

      • PHP升级到7.4+(修改脚本中PHP版本路径)

    • 运维改进

      • 增加服务监控重启机制(如用supervisord

  3. 开发心得

    “通过此脚本深入理解了LNMP组件的交互依赖关系,特别是PHP-FPM与Nginx的协议通信机制。在MySQL编译中处理boost依赖的过程,加深了对C/C++项目构建的理解。建议后续增加Let's Encrypt证书自动部署功能以实现HTTPS化。”

 脚本获取:

#!/bin/bash
#function:lnmp
##########################################
if
[  "$USER"  != "root"   ]
then
echo "错误:非root用户,权限不足!"
exit  0
fi
###############防火墙及SElinux############
systemctl stop firewalld && systemctl disable firewalld  && echo "防火墙已经关闭"
sed -i 's/SELINUX=.*/SELINUX=disabled/g'  /etc/selinux/config  && echo "关闭selinux"
sleep 5
cflj=/usr/src
zip_file="lnmp.zip"
##############检查文件是否存在##############
if [ -f "$cflj/$zip_file" ]; then
cd $cflj
unzip lnmp.zip
rm -rf $cflj/lnmp.zip
else
echo "请上传文件 $zip_file 到 $cflj"
exit 1
fi
######### install nginx #########
function nginx_install(){
nginx_path="$cflj/nginx-1.9.5.tar.gz"
if [ -e "$nginx_path" ]; then
cd $cflj;
tar -zxf nginx-1.9.5.tar.gz
cd nginx-1.9.5/
groupadd www
useradd -g www www -s /sbin/nologin
mkdir -p /var/log/nginx
yum install -y gcc gcc-c++ autoconf automake zlib zlib-devel openssl openssl-devel  pcre pcre-devel make automake
./configure \
--prefix=/usr/local/nginx \
--with-http_dav_module \
--with-http_stub_status_module \
--with-http_addition_module \
--with-http_sub_module \
--with-http_flv_module \
--with-http_mp4_module \
--with-pcre \
--with-http_ssl_module \
--with-http_gzip_static_module \
--user=www \
--group=www
if [ $? -eq 0 ]; then
make  && make install
if [ $? -eq 0 ]; then
echo "nginx编译安装完成"
else
echo "nginx编译安装失败"
exit 1
fi
else
echo"nginx编译安装失败"
exit 1
fi
else
echo "请上传nginx到/usr/src"
exit 0
fi
}
sleep 3
######### install mysql #########
function mysql_install(){
###########清理旧版本###########
rpm -qa | grep mariadb &>> /dev/null
rpm -qa | grep mysql  &>> /dev/null
rpm -e mariadb-libs --nodeps  mariadb-libs &>> /dev/null
yum -y remove mysql* mariadb*  &>> /dev/null
##########判断boost文件#############
boost_path="$cflj/boost_1_59_0.tar.bz2"
# 检查文件是否存在
if [ -e "$boost_path" ]; then
cd $cflj;
groupadd mysql
useradd mysql -g mysql -M -s /sbin/nologin
mkdir -p /data/mysql/{data,log}
chown -R mysql:mysql /data/mysql/
tar jxf boost_1_59_0.tar.bz2 -C /root/
else
echo "请上传boost到/usr/src"
exit 0
fi
##########判断mysql文件#############
mysql_path="$cflj/mysql-5.7.26.tar.gz"
if [ -e "$mysql_path" ]; then
cd $cflj;
tar xzf mysql-5.7.26.tar.gz
cd mysql-5.7.26/
yum install -y cmake make gcc gcc-c++ bison ncurses ncurses-devel bzip2
cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_DATADIR=/data/mysql/data \
-DSYSCONFDIR=/etc \
-DWITH_MYISAM_STORAGE_ENGINE=1 \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_MEMORY_STORAGE_ENGINE=1 \
-DWITH_READLINE=1 \
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \
-DMYSQL_TCP_PORT=3306 \
-DENABLED_LOCAL_INFILE=1 \
-DWITH_PARTITION_STORAGE_ENGINE=1 \
-DEXTRA_CHARSETS=all \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DDOWNLOAD_BOOST=1 \
-DWITH_BOOST=/root/boost_1_59_0
if [ $? -eq 0 ]; then
make  && make install
if [ $? -eq 0 ]; then
echo "mysql编译安装完成"
else
echo "mysql编译安装失败"
exit 1
fi
else
echo"mysql编译安装失败"
exit 1
fi
sleep 3
#####设置权限#########
chown -R mysql:mysql /usr/local/mysql/
#####定义配置文件#####
cat >> /etc/my.cnf  /usr/local/nginx/conf/nginx.conf <

posted @ 2025-07-28 17:02  yfceshi  阅读(13)  评论(0)    收藏  举报