LNMP之MYSQL和PHP的安装与配置

#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
这里写图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值