#LNMP之MYSQL和PHP的安装与配置
LNMP简介:
互联网最常用的经典Web服务环境组合就是LAMP(即Linux、Apache、Mysql、PHP),近几年随着Nginx Web服务的逐渐流行,又出现了新的Web服务环境组合-LNMP(即Linux、Nignx、Mysql、PHP)。
LNMP组合工作流程介绍:
当LNMP组合工作时,首先是用户通过浏览器输入域名请求Nginx Web服务,如果请求是静态资源,则由Nginx解析返回给用户;如果是动态请求(.php结尾),那么Nginx就会把它通FastCGI接口(生产常用方法)发送给php引擎服务(fastcgi进程php-fpm)进行解析,如果这个动态请求要求读取数据库数据,那么php就会继续向后请求MYSQL数据库,读取需要的数据,并且最终通过nginx服务把获取的数据返回给用户。
一.LNMP之mysql数据库:
1.用源码编译安装mysql数据库:
下载:cmake-2.8.12.2-4.el6.x86_64.rpm
mysql-boost-5.7.17.tar.gz ##源码编译安装的时间长,特点是可以定制
cmake后面接选择需要定制的内容进行编译:(根据自己的使用情况定制)
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
#安装目录
-DMYSQL_DATADIR=/usr/local/mysql/data \
#数据库存放目录
-DMYSQL_UNIX_ADDR=/usr/local/mysql/data/mysql.sock \ #Unix socket 文件路径
-DWITH_MYISAM_STORAGE_ENGINE=1 \
#安装 myisam 存储引擎
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
#安装 innodb 存储引擎
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \
#安装 archive 存储引擎
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
#安装 blackhole 存储引擎
-DWITH_PARTITION_STORAGE_ENGINE=1 \
#安装数据库分区
-DENABLED_LOCAL_INFILE=1 \
#允许从本地导入数据
-DWITH_READLINE=1 \
#快捷键功能
-DWITH_SSL=yes \
#支持 SSL
-DDEFAULT_CHARSET=utf8 \
#使用 utf8 字符
-DDEFAULT_COLLATION=utf8_general_ci \
#校验字符
-DEXTRA_CHARSETS=all \
#安装所有扩展字符集
-DMYSQL_TCP_PORT=3306 \
#MySQL 监听端口
开始安装mysql:
rpm -ivh cmake-2.8.12.2-4.el6.x86_64.rpm ##先安装cmake
yum install cmake-2.8.12.2-4.el6.x86_64.rpm -y
tar zxf mysql-boost-5.7.17.tar.gz
cd mysql-boost-5.7.17
cmake -DCMAKE_INSTALL_PREFIX=/usr/local/lnmp/mysql -DMYSQL_DATADIR=/usr/local/lnmp/mysql/data -DMYSQL_UNIX_ADDR=/usr/local/lnmp/mysql/data/mysql.sock -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_MYISAM_STORAGE_ENGINE=1 -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DEXTRA_CHARSETS=all -DWITH_BOOST=boost/boost_1_59_0/
**注意路径的设置!!!
**注意解决依赖性的问题
2.数据库初始化
groupadd -g 27 mysql
useradd -u 27 -g 27 -s /sbin/nologin -M -d /usr/local/lnmp/mysql/data mysql
cd /usr/local/lnmp/mysql
chown mysql.mysql . -R
vim ~/.bash_profile ##将mysql命令倒入环境变量
source ~/.bash_profile ##
cp /etc/my.cnf /etc/cnf.bak ##备份主配置文件
cd /usr/local/lnmp/mysql
cd support_files/ ##support_file下有my.cnf的各种配置
cp my-default.cnf /etc/my.cnf
cp mysql.server /etc/init.d/mysqld ##拷贝mysql的运行脚本到mysql的命令路径
mysqld –initalize –user=mysql ##数据库初始化,会生成一个临时密码
chown root.root . -R
chown mysql data -R
/etc/init.d/mysqld start ##开启mysql服务
mysql_secure_installation
二.LNMP之PHP(FastCGI方式)服务的安装准备:
下载:php-5.6.20.tar.bz2
安装:tar jxf php-5.6.20.tar.bz2
./configure --prefix=/usr/local/lnmp/php --with-config-file-path=/usr/local/lnmp/php/etc --with-mysql=mysqlnd --with-mysqli=mysqlnd --with-pdo-mysql=mysqlnd --with-openssl --with-snmp --with-gd --with-zlib --with-curl --with-libxml-dir --with-png-dir --with-jpeg-dir --with-freetype-dir --with-gmp --with-gettext --enable-inline-optimization --enable-soap --enable-ftp --enable-sockets --enable-mbstring --enable-fpm --with-fpm-user=nginx --with-fpm-group=nginx --with-mcrypt --with-mhash
cd /mnt/php-5.6.20 ##定制特性检查编译环境
make && make install ##编译程序
在检查编译环境时出现的几种报错:
这是没有安装服务的原因,直接执行yum install libxml2-devel -y
如果出现这种情况,先执行yum provides */jpeglib.h找出提供这个头文件的服务然后安装
三.配置Nginx支持PHP程序请求访问:
php:
cd /mnt/php-5.6.20
cd sapi/
cp init.d.php-fpm /etc/init.d/php.fpm
chmod +x /etc/init.d/php.fpm
cd /mnt/php-5.6.20
cp php.ini-production /usr/local/lnmp/php/etc/php.ini
cd php.ini
ls
cp php-fpm.conf.default php-fpm.conf ##备份主配置文件
vim php-fpm.conf ##设置时区
vim ~/.bash_profile
source ~/.bash_profile
/etc/init.d/start ##启动服务
nginx:
cd /usr/local/lnmp/nginx/conf
vim ~/.bash_profile
cd /usr/local/lnmp/nginx/html
vim index.php
nginx -s reload ##重新加载nginx服务
测试:
在浏览器输入172.25.254.1/index.php,得到以下界面
四.搭建论坛:
下载:Discuz_X3.2_SC_UTF8.zip
unzip Discuz_X3.2_SC_UTF8.zip ##解压文件之后会生成三个目录(readme、upload、utility)
cd /usr/local/lnmp/php/etc
vim php.ini ##开启socket连接
mv upload/ /usr/local/lnmp/nginx/html/bbs
测试:
在浏览器输入172.25.254.1/bbs
chown 777 config/ data/ uc_client/ uc_server/ -R
**出现上图错误的原因是没有建立好socket连接。
**还要将data的权限改为mysql root;并且执行chown 755 /usr/local/lnmp/mysql/data