一键部署 LNMP 架构

本文涉及的产品
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云解析 DNS,旗舰版 1个月
简介: 一、将安装包传到/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


相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
24天前
|
存储 关系型数据库 算法框架/工具
Ceph 架构以及部署
Ceph 架构以及部署
65 26
|
4天前
|
弹性计算 运维 关系型数据库
云上Serverless高可用架构一键部署体验与测评
在数字化转型背景下,Serverless架构因其实现业务敏捷、降低成本及提升服务可靠性而备受青睐。本文以阿里云Serverless应用引擎(SAE)为核心,展示了一种高可用、低成本且易于扩展的解决方案。通过单地域双可用区部署,构建了具备自动伸缩与故障恢复能力的架构。借助阿里云的一键部署功能,大幅简化了搭建流程,实现了快速部署,并通过性能与成本分析验证了其优势。对比传统ECS,SAE在资源利用与运维效率上表现更佳,特别适合平均负载较低的应用场景。
|
6天前
|
Kubernetes Docker 容器
使用 Kubeadm 部署 Kubernetes(K8S) 安装--附K8S架构图
使用 Kubeadm 部署 Kubernetes(K8S) 安装--附K8S架构图
47 0
|
1月前
|
弹性计算 运维 关系型数据库
Serverless高可用架构体验与部署反馈
Serverless高可用架构体验与部署反馈
60 3
|
1月前
|
Kubernetes Cloud Native 持续交付
云原生架构的核心组成部分通常包括容器化(如Docker)、容器编排(如Kubernetes)、微服务架构、服务网格、持续集成/持续部署(CI/CD)、自动化运维(如Prometheus监控和Grafana可视化)等。
云原生架构的核心组成部分通常包括容器化(如Docker)、容器编排(如Kubernetes)、微服务架构、服务网格、持续集成/持续部署(CI/CD)、自动化运维(如Prometheus监控和Grafana可视化)等。
|
1月前
|
消息中间件 API 数据库
在微服务架构中,每个服务通常都是一个独立运行、独立部署、独立扩展的组件,它们之间通过轻量级的通信机制(如HTTP/RESTful API、gRPC等)进行通信。
在微服务架构中,每个服务通常都是一个独立运行、独立部署、独立扩展的组件,它们之间通过轻量级的通信机制(如HTTP/RESTful API、gRPC等)进行通信。
|
1月前
|
弹性计算 负载均衡 关系型数据库
使用资源编排 ROS 轻松部署高可用架构网站——以 WordPress 为例
WordPress 是流行的开源 CMS,阿里云的资源编排服务 (ROS) 提供 IaC 功能,简化云上资源自动化部署,如创建 VPC、ECS、SLB、RDS 和弹性伸缩等。通过 ROS 模板(JSON/YAML),用户能快速部署高可用的 WordPress 环境,包括负载均衡、多可用区的 ECS 服务器集群、高可用 RDS 数据库等。模板定义了资源、参数和输出,用户在 ROS 控制台配置参数后一键部署。ROS 提升了部署效率,便于跨地域复制相同架构。
59 0
使用资源编排 ROS 轻松部署高可用架构网站——以 WordPress 为例
|
2天前
|
监控 负载均衡 API
从单体到微服务:架构转型之道
【8月更文挑战第17天】从单体架构到微服务架构的转型是一项复杂而系统的工程,需要综合考虑技术、团队、文化等多个方面的因素。通过合理的规划和实施策略,可以克服转型过程中的挑战,实现系统架构的升级和优化。微服务架构以其高度的模块化、可扩展性和灵活性,为业务的持续发展和创新提供了坚实的技术保障。
|
11天前
|
Cloud Native 云计算 微服务
云原生时代:企业分布式应用架构的惊人蜕变,从SOA到微服务的大逃亡!
【8月更文挑战第8天】在云计算与容器技术推动下,企业分布式应用架构正经历从SOA到微服务再到云原生的深刻变革。SOA强调服务重用与组合,通过标准化接口实现服务解耦;微服务以细粒度划分服务,增强系统灵活性;云原生架构借助容器化与自动化技术简化部署与管理。每一步演进都为企业带来新的技术挑战与机遇。
40 6
|
9天前
|
设计模式 监控 API
探索微服务架构中的API网关模式
在微服务的宇宙里,API网关是连接星辰的桥梁。它不仅管理着服务间的通信流量,还肩负着保护、增强和监控微服务集群的重任。本文将带你走进API网关的世界,了解其如何成为微服务架构中不可或缺的一环,以及它在实际应用中扮演的角色和面临的挑战。