LNMP主流架构的提前准备工作,尽量选用干净的系统,环境初始化,如下:
systemctl stop firewalld
systemctl disable firewalld &> /dev/null
setenforce 0
sed -i ‘/SELINUX/{s/enforcing/disabled/}’ /etc/selinux/config
1,用脚本源码安装nginx,脚本如下:
#!/bin/bash
#by 运维部chen
#install nginx
NGX_VER="1.24.0"
NGX_DIR="/usr/local/nginx"
NGX_URL="http://nginx.org/download"
NGX_SOFT="nginx-${NGX_VER}.tar.gz"
NGX_ARGS="--user=www --group=www --with-http_stub_status_module --with-http_ssl_module"
if [ $# -eq 0 ];then
echo -e "\033[32m--------------------\033[0m"
echo -e "\033[32mUsage:{/bin/sh $0 1.24.0|1.21.6|help }\033[0m"
exit
fi
CHECK_NUM=$(rpm -qa|grep -E "gcc|pcre-devel"|wc -l);
if [ $CHECK_NUM -lt 3 ];then
echo "your bag not install ,now right installing "
yum install -y wget gzip gcc make tar net-tools
yum install -y pcre pcre-devel zlib-devel
yum -y install deltarpm openssl-devel
fi
if [ -f $NGX_DIR/sbin/nginx ];then
echo "the nginx service already exists, please exit"
else
wget -c $NGX_URL/$NGX_SOFT -P /usr/src/
cd /usr/src/
ls -l $NGX_SOFT
tar -xzvf $NGX_SOFT
cd nginx-$NGX_VER
sed -i -e 's/1\.24\.0/2.2/' -e '/NGINX_VER/s/nginx/JFWS/' src/core/nginx.h
useradd -s /sbin/nologin www -M
./configure --prefix=$NGX_DIR/ $NGX_ARGS
if [ $? -eq 0 ];then
make
make install
fi
ls -l $NGX_DIR/
$NGX_DIR/sbin/nginx
ps -ef|grep nginx
netstat -tnlp|grep 80
firewall-cmd --add-port=80/tcp --permanent
systemctl restart firewalld
setenforce 0
fi
2,安装好源码mysql5.7;脚本如下
#!/bin/bash
#by 运维部chen
#初始化。卸载内置mariadb的包
rpm -e –nodeps mariadb-libs-5.5.60-1.el7_5.x86_64
yum remove mariadb* -y
#下载mysql5.7包,mysql-5.7.21.tar.gz
http://mirrors.163.com/mysql/Downloads/MySQL-5.7/mysql-5.7.21.tar.gz
#下载boost安装包,tar xzf boost_1_59_0.tar.gz
wget http://downloads.sourceforge.net/project/boost/boost/1.59.0/boost_1_59_0.tar.gz
yum install lrzsz vim -y
tar zxvf boost_1_59_0.tar.gz
tar xzf mysql-5.7.21.tar.gz
mv boost_1_59_0 /usr/local/boost
yum -y install gcc-c++ ncurses-devel cmake make perl gcc autoconf automake zlib libxml libgcrypt libtool bison
mkdir -p /data/mysql
useradd -s /sbin/nologin mysql -M
chown -R mysql:mysql /data/mysql
cd mysql-5.7.21
cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql5/ -DMYSQL_UNIX_ADDR=/tmp/mysql.sock -DMYSQL_DATADIR=/data/mysql/ -DSYSCONFDIR=/etc -DMYSQL_USER=mysql -DMYSQL_TCP_PORT=3306 -DWITH_XTRADB_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_PARTITION_STORAGE_ENGINE=1 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_READLINE=1 -DENABLED_LOCAL_INFILE=1 -DWITH_EXTRA_CHARSETS=1 -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DEXTRA_CHARSETS=all -DWITH_BIG_TABLES=1 -DWITH_DEBUG=0 -DDOWNLOAD_BOOST=1 -DWITH_BOOST=/usr/local/boost
make
make install
cd /usr/local/mysql5
#初始化:
/usr/local/mysql5/bin/mysqld –initialize –user=mysql –basedir=/usr/local/mysql5 –datadir=/data/mysql
cp support-files/mysql.server /etc/init.d/mysqld
chmod o+x /etc/init.d/mysqld
#这句用来启动程序
/usr/local/mysql5/bin/mysqld_safe –user=mysql &
#做软链
ln -s /usr/local/mysql5/bin/* /usr/bin/
##这句用来登录数据库
mysql -uroot -p
#查看:目录权限:ls -l /data/mysql/ ##如果权限不够要给他授权,具体命令为:
chown -R myql:mysql /data/mysql/
#查看mysql进程
ps -ef|grep mysql
#查看是否安装完成
ls -l /usr/local/mysql*
3,安装php72,写入脚本
#!/bin/bash
##by 运维部chen
echo "正在安装PHP..."
echo -e "\033[32m--------------------\033[0m"
PHP_VER=remi-php72
yum install -y epel-release
yum install -y https://mirrors.tuna.tsinghua.edu.cn/remi/enterprise/remi-release-7.rpm
yum install -y yum-utils
yum-config-manager --disable 'remi-php*'
yum-config-manager --enable $PHP_VER
yum clean all
yum install -y php php-fpm php-cli php-mysql php-devel php-xml
php -v
systemctl start php-fpm
systemctl status php-fpm
##整合最最关键的地方
nginx配置文件如下四个位置:
PHP的承前启后
nginx作前端和php-fpm进行对发布目录的解释:所以在nginx配置文件要配置和php-fpm的连接设置。而mysql作为和php-fpm之间的使用。就是php-fpm的配置文件一方面要对nginx作准入配置,mysql的配置方面无需过度操作,只要授权好了即可,在php代码发布目录,修改mysql数据库信息,或者在系统启动的时候再进行写入配置也是一样的。
##修改php-fpm的配置文件一般叫 www.conf,改的地方有以下:
1)大概第38行,listen=0.0.0.0:9000
2)第64行 ,listen.allowed_clients=nginx的ip
3)user=www和group=www要修改成nginx同一个用户名。
4)php-fpm上创建www用户:useradd www -s /sbin/nologin -M
5)重启所有服务
报错:502说明nginx连不上php-fpm,确认查看防火墙
浏览器file found报错:
1,把discuz放一份在fpm上,一份在nginx上。上传upload目录的文件,分别授权www用户拥有对发布目录的权限