一键部署 LNMP 架构

本文涉及的产品
RDS AI 助手,专业版
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
简介: 一、将安装包传到/opt/目录下nignx安装包:nginx-1.12.2.tar.gzmysql安装包:mysql-boost-5.7.20.tar.gzphp安装包:php-7.1.10.tar.bz2

一、将安装包传到/opt/目录下

nignx安装包:nginx-1.12.2.tar.gz

mysql安装包:mysql-boost-5.7.20.tar.gz

php安装包:php-7.1.10.tar.bz2

Discuz论坛安装包:Discuz_X3.4_SC_UTF8.zip

[root@yuji ~]# cd /opt/
 [root@yuji opt]# ls
 Discuz_X3.4_SC_UTF8.zip    nginx-1.12.2.tar.gz
 mysql-boost-5.7.20.tar.gz  php-7.1.10.tar.bz2
复制代码


网络异常,图片无法展示
|


二、搭建本地yum仓库

写一个一键搭建本地yum仓库的脚本:

vim /lnmp/yum01.sh

#!/bin/bash
 mount /dev/sr0 /mnt/
 cd /etc/yum.repos.d/
 mkdir bakup
 mv *.repo bakup/
 echo "[local]
 name=local
 baseurl=file:///mnt
 enabled=1
 gpgcheck=0" > local.repo
 yum clean all && yum makecache
复制代码


小贴士:

如果使用yum安装软件时,提示进程被占用,可以运行如下命令删除PID文件:

rm -f /var/run/yum.pid    #删除PID文件。yum安装前运行,就可以不报进程占用。
复制代码


三、编译安装nginx服务

写一个一键安装nginx服务的脚本:

vim /lnmp/nginx01.sh

#!/bin/bash
 #======编译安装nginx服务======
 #安装所需开发包和编译环境、编译器
 rm -f /var/run/yum.pid 
 yum -y install pcre-devel zlib-devel openssl-devel gcc gcc-c++ make
 #如果yum安装失败,则退出脚本
 [ $? != 0 ] && exit
 #创建程序用户,便于准确控制访问
 useradd -M -s /sbin/nologin nginx
 #解压安装包
 cd /opt
 tar zxvf nginx-1.12.2.tar.gz -C /opt
 #指定安装路径、指定用户名、组名、启用模块以支持统计状态
 cd nginx-1.12.2/
 ./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_stub_status_module --with-file-aio --with-http_gzip_static_module --with-http_flv_module --with-http_ssl_module
 #编译及安装,开2核编译,注意虚拟机的处理器数量要设置为2
 make -j 2 && make install
 #软链接便于系统识别nginx操作命令
 ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/
 #添加nginx系统服务
 echo '[Unit]
 Description=nginx
 After=network.target
 [Service]
 Type=forking
 PIDFile=/usr/local/nginx/logs/nginx.pid
 ExecStart=/usr/local/nginx/sbin/nginx
 ExecrReload=/bin/kill -s HUP $MAINPID
 ExecrStop=/bin/kill -s QUIT $MAINPID
 PrivateTmp=true
 [Install]
 WantedBy=multi-user.target' > /lib/systemd/system/nginx.service
 #赋权及开启服务、开启开机自启
 chmod 754 /lib/systemd/system/nginx.service
 systemctl start nginx.service
 systemctl enable nginx.service
复制代码


四、编译安装mysql服务

写一个一键安装mysql服务的脚本:

vim /lnmp/mysql01.sh

#!/bin/bash
 #=======编译安装mysql服务=======
 #安装Mysql环境依赖包
 rm -f /var/run/yum.pid 
 yum -y install \
 expect \                   #安装expect免交互工具
 gcc \
 gcc-c++ \
 ncurses \
 ncurses-devel \
 bison \
 cmake
 #如果yum安装失败,则退出脚本
 [ $? != 0 ] && exit
 #创建程序用户,便于准确控制访问用户
 useradd -M -s /sbin/nologin  mysql
 #解压软件包
 cd /opt
 tar xzvf mysql-boost-5.7.20.tar.gz -C /opt
 #指定安装路径和安装模块
 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核编译,注意虚拟机的处理器数量要设置为2
 make -j 2 && make install
 #修改mysql 配置文件
 echo '[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' > /etc/my.cnf
 #更改mysql安装目录和配置文件的属主属组
 chown -R mysql:mysql /usr/local/mysql/
 chown mysql:mysql /etc/my.cnf
 #将mysql的可执行文件放入环境变量PATH的目录中,方便系统直接识别mysql命令
 cp /usr/local/mysql/bin/* /usr/bin/
 cp /usr/local/mysql/lib/* /usr/bin/
 #初始化数据库
 cd /usr/local/mysql/bin/
 ./mysqld \
 --initialize-insecure \
 --user=mysql \
 --basedir=/usr/local/mysql \
 --datadir=/usr/local/mysql/data
 #添加mysqld系统服务
 cp /usr/local/mysql/usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/ 
 #重新加载,启动mysql服务,将mysql设置为开机自启
 systemctl daemon-reload
 systemctl start mysqld.service
 systemctl enable mysqld
 #修改mysql 的登录密码
 function mima {
 /usr/bin/expect <<-EOF
 pass=$1
 spawn mysqladmin -u root -p password $pass
 expect "Enter password:" {send "\r"}
 EOF
 }
 mima abc123
 #授权远程登录mysql数据库
 #授予root用户可以在所有终端远程登录,使用的密码是abc123,并对所有数据库和所有表有操作权限。
 function shouquan {
 /usr/bin/expect <<-EOF
 spawn mysql -u root -p
 expect " Enter password: " {send "abc123\n"}
 expect "mysql>" {send "grant all privileges on *.* to 'root'@'%' identified by 'abc123';\n"}
 expect "mysql>" {send "quit\n"}
 EOF
 }
 shouquan
复制代码


五、编译安装 PHP 解析环境

写一个一键安装PHP解析环境的脚本:

vim /lnmp/php01.sh

#!/bin/bash
 #=====PHP=======
 #安装环境依赖包
 rm -f /var/run/yum.pid
 yum install -y gd \
 libjpeg libjpeg-devel \
 libpng libpng-devel \
 freetype freetype-devel \
 libxml2 libxml2-devel \
 zlib zlib-devel \
 curl curl-devel \
 openssl openssl-devel
 #如果yum安装失败,则退出脚本
 [ $? != 0 ] && exit
 #解压软件包
 cd /opt
 tar xjvf php-7.1.10.tar.bz2 -C /opt
 #指定安装路径和安装
 cd 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
 #编译及安装,开2核编译,注意虚拟机的处理器数量要设置为2
 make -j 2 && make install
 #路径优化。将php的所有可执行文件,放入环境变量PATH的目录下,便于系统识别
 ln -s /usr/local/php/bin/* /usr/local/bin/
 ln -s /usr/local/php/sbin/* /usr/local/sbin/
 #php有三个配置文件: 
 #php.ini 主配置文件
 #php-fpm.conf 进程服务配置文件
 #www.conf 扩展配置文件
 #调整主配置文件:php.ini
 #复制模版文件作为PHP的主配置文件,并进行修改。在测试环境时使用php.ini-development文件,而在生产环境时使用php.ini-production文件。
 cp /opt/php-7.1.10/php.ini-development /usr/local/php/lib/php.ini
 #修改第1170行
 sed -i '1170c mysqli.default_socket = /usr/local/mysql/mysql.sock' /usr/local/php/lib/php.ini
 #修改第939行
 sed -i '939c date.timezone = Asia/Shanghai' /usr/local/php/lib/php.ini
 #验证安装的模块
 php -m 
 #进程服务配置文件:php-fpm.conf
 cd /usr/local/php/etc/
 cp php-fpm.conf.default php-fpm.conf
 #修改第17行
 sed -i '17c pid = run/php-fpm.pid' /usr/local/php/etc/php-fpm.conf
 #扩展配置文件:www.conf
 cd /usr/local/php/etc/php-fpm.d/
 cp www.conf.default www.conf
 #启动php-fpm
 ln -s /usr/local/php/sbin/* /usr/local/sbin
 /usr/local/php/sbin/php-fpm -c /usr/local/php/lib/php.ini
 netstat -anpt | grep 9000
 #PHP-FPM(FastCGI Process Manager:FastCGI 进程管理器)是一个 PHPFastCGI 管理器, 由于Nginx服务器不能处理动态页面,需要由 Nginx 把动态请求交给 php-fpm 进程进行解析。
 cd /opt/php-7.1.10/sapi/fpm
 cp php-fpm.service /usr/lib/systemd/system/php-fpm.service
 systemctl restart php-fpm.service
 #配置 Nginx 支持 PHP 解析
 #--65行--取消注释,修改
 sed -i '65c location ~ .php$ {' /usr/local/nginx/conf/nginx.conf
 sed -i '66c root  html;' /usr/local/nginx/conf/nginx.conf
 sed -i '67c fastcgi_pass   127.0.0.1:9000;' /usr/local/nginx/conf/nginx.conf
 sed -i '68c fastcgi_index  index.php;' /usr/local/nginx/conf/nginx.conf
 #将 /scripts 修改为nginx的工作目录
 sed -i '69c fastcgi_param  SCRIPT_FILENAME  /usr/local/nginx/html$fastcgi_script_name;' /usr/local/nginx/conf/nginx.conf
 sed -i '70c include  fastcgi_params;' /usr/local/nginx/conf/nginx.conf
 sed -i '71c }' /usr/local/nginx/conf/nginx.conf
 systemctl restart nginx.service
 #验证PHP 测试页
 echo '<?php
 phpinfo();
 ?>' > /usr/local/nginx/html/index.php
 #验证数据库工作是否正常
 function yanzheng {
 /usr/bin/expect <<-EOF
 spawn mysql -u root -p
 expect " Enter password: " {send "abc123\n"}
 expect "mysql>" {send "CREATE DATABASE bbs;\r"}
 #把bbs数据库里面所有表的权限,授予给所有主机的bbsuser,使用的密码是abc123。
 expect "mysql>" {send "GRANT all ON bbs.* TO 'bbsuser'@'%' IDENTIFIED BY 'abc123';\r"}
 #把bbs数据库里面所有表的权限,授予给本地的bbsuser,使用的密码是admin123。localhost使用的是本地回环地址127.0.0.1进行访问。
 expect "mysql>" {send "GRANT all ON bbs.* TO 'bbsuser'@'localhost' IDENTIFIED BY 'abc123';\r"}
 #刷新数据库
 expect "mysql>" {send "flush privileges;\r"}
 expect "mysql>" {send "quit\r"}
 EOF
 }
 yanzheng
复制代码


六、 部署Discuz社区论坛

写一个一键部署Discuz社区论坛的脚本:

vim /lnmp/discuz01.sh

#!/bin/bash
 #部署Discuz社区论坛
 #创建一个新的数据库bbs,并进行授权
 function crebbs {
 /usr/bin/expect <<-EOF
 spawn mysql -u root -p
 expect " Enter password: " {send "abc123\n"}
 expect "mysql>" {send "CREATE DATABASE bbs;\r"}
 #把bbs数据库里面所有表的权限,授予给所有主机的bbsuser,使用的密码是abc123。
 expect "mysql>" {send "GRANT all ON bbs.* TO 'bbsuser'@'%' IDENTIFIED BY 'abc123';\r"}
 #把bbs数据库里面所有表的权限,授予给本地的bbsuser,使用的密码是admin123。localhost使用的是本地回环地址127.0.0.1进行访问。
 expect "mysql>" {send "GRANT all ON bbs.* TO 'bbsuser'@'localhost' IDENTIFIED BY 'abc123';\r"}
 #刷新数据库
 expect "mysql>" {send "flush privileges;\r"}
 expect "mysql>" {send "quit\r"}
 EOF
 }
 crebbs
 #解压安装包,因为是.zip格式,所以使用unzip命令进行解压
 cd /opt
 unzip Discuz_X3.4_SC_UTF8.zip  -d /opt/dis
 cd /opt/dis/dir_SC_UTF8/
 cp -r upload/ /usr/local/nginx/html/bbs/
 #调整论坛目录的权限
 cd /usr/local/nginx/html/bbs/
 chown -R nginx ./config/
 chown -R nginx ./data/
 chown -R nginx ./uc_client/
 chown -R nginx ./uc_server/
 chmod -R 777 ./config/
 chmod -R 777 ./data/
 chmod -R 777 ./uc_client/
 chmod -R 777 ./uc_server/
 #获取本机IP地址
 ip=`ifconfig ens33 | awk 'NR==2{print $2}'`
 echo -e "\033[31m 此时可访问:$ip/index.php \033[0m"
 echo -e "\033[31m 此时可进入浏览器安装论坛:http://$ip/bbs/install/index.php \033[0m"
 echo -e "\033[31m 数据库服务器:localhost \033[0m"     
 echo -e "\033[31m 数据库名字:bbs \033[0m"
 echo -e "\033[31m 数据库用户名:bbsuser \033[0m"
 echo -e "\033[31m 数据库密码:abc123 \033[0m"
 echo -e "\033[31m 管理员账号:admin \033[0m"
 echo -e "\033[31m 管理员密码:abc123 \033[0m"
 echo -e "\033[31m 论坛内部页面:http://$ip/bbs/index.php \033[0m"
 echo -e "\033[31m 论坛后台管理员页面:http://$ip/bbs/admin.php \033[0m"
复制代码


七、执行五个脚本,安装完成后使用浏览器访问验证

[root@yuji ~]# bash /lnmp/yum01.sh
 [root@yuji ~]# bash /lnmp/nginx01.sh
 [root@yuji ~]# bash /lnmp/mysql01.sh
 [root@yuji ~]# bash /lnmp/php01.sh
 [root@yuji ~]# bash /lnmp/discuz01.sh
 测试访问 http://172.16.10.101/bbs/install/index.php


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
5月前
|
存储 监控 安全
132_API部署:FastAPI与现代安全架构深度解析与LLM服务化最佳实践
在大语言模型(LLM)部署的最后一公里,API接口的设计与安全性直接决定了模型服务的可用性、稳定性与用户信任度。随着2025年LLM应用的爆炸式增长,如何构建高性能、高安全性的REST API成为开发者面临的核心挑战。FastAPI作为Python生态中最受青睐的Web框架之一,凭借其卓越的性能、强大的类型安全支持和完善的文档生成能力,已成为LLM服务化部署的首选方案。
|
10月前
|
监控 Linux 应用服务中间件
Linux多节点多硬盘部署MinIO:分布式MinIO集群部署指南搭建高可用架构实践
通过以上步骤,已成功基于已有的 MinIO 服务,扩展为一个 MinIO 集群。该集群具有高可用性和容错性,适合生产环境使用。如果有任何问题,请检查日志或参考MinIO 官方文档。作者联系方式vx:2743642415。
3404 57
|
12月前
|
资源调度 前端开发 算法
鸿蒙OS架构设计探秘:从分层设计到多端部署
本文深入探讨了鸿蒙OS的架构设计,从独特的“1+8+N”分层架构到模块化设计,再到智慧分发和多端部署能力。分层架构让系统更灵活,模块化设计通过Ability机制实现跨设备一致性,智慧分发优化资源调度,多端部署提升开发效率。作者结合实际代码示例,分享了开发中的实践经验,并指出生态建设是未来的关键挑战。作为国产操作系统的代表,鸿蒙的发展值得每一位开发者关注与支持。
|
10月前
|
消息中间件 数据可视化 Kafka
docker arm架构部署kafka要点
本内容介绍了基于 Docker 的容器化解决方案,包含以下部分: 1. **Docker 容器管理**:通过 Portainer 可视化管理工具实现对主节点和代理节点的统一管理。 2. **Kafka 可视化工具**:部署 Kafka-UI 以图形化方式监控和管理 Kafka 集群,支持动态配置功能, 3. **Kafka 安装与配置**:基于 Bitnami Kafka 镜像,提供完整的 Kafka 集群配置示例,涵盖 KRaft 模式、性能调优参数及数据持久化设置,适用于高可用生产环境。 以上方案适合 ARM64 架构,为用户提供了一站式的容器化管理和消息队列解决方案。
932 10
|
关系型数据库 MySQL 应用服务中间件
Linux 手动安装快速部署 LNMP 环境实战
本文详细记录了在阿里云ECS上手动搭建LNMP环境的过程,系统选用Ubuntu 24.04。主要内容包括:1) 使用`apt`安装Nginx和MySQL,并更新软件源;2) 编译安装PHP 8.4.5,配置PHP-FPM及环境路径;3) 配置MySQL root用户密码;4) 调整Nginx支持PHP解析并测试整体环境。通过此过程,重现手动配置服务器的细节,帮助熟悉各组件的安装与协同工作。
839 23
|
Serverless 决策智能 UED
构建全天候自动化智能导购助手:从部署者的视角审视Multi-Agent架构解决方案
在构建基于多代理系统(Multi-Agent System, MAS)的智能导购助手过程中,作为部署者,我体验到了从初步接触到深入理解再到实际应用的一系列步骤。整个部署过程得到了充分的引导和支持,文档详尽全面,使得部署顺利完成,未遇到明显的报错或异常情况。尽管初次尝试时对某些复杂配置环节需反复确认,但整体流程顺畅。
281 3
|
5月前
|
Cloud Native Serverless API
微服务架构实战指南:从单体应用到云原生的蜕变之路
🌟蒋星熠Jaxonic,代码为舟的星际旅人。深耕微服务架构,擅以DDD拆分服务、构建高可用通信与治理体系。分享从单体到云原生的实战经验,探索技术演进的无限可能。
微服务架构实战指南:从单体应用到云原生的蜕变之路
|
弹性计算 API 持续交付
后端服务架构的微服务化转型
本文旨在探讨后端服务从单体架构向微服务架构转型的过程,分析微服务架构的优势和面临的挑战。文章首先介绍单体架构的局限性,然后详细阐述微服务架构的核心概念及其在现代软件开发中的应用。通过对比两种架构,指出微服务化转型的必要性和实施策略。最后,讨论了微服务架构实施过程中可能遇到的问题及解决方案。