基于lnmp架构搭建论坛
LNMP代表的就是:Linux系统下Nginx+MySQL+PHP这种网站服务器架构。
实验环境:
系统环境: RHEL6 x86-64 selinux and iptables disabled
一、Mysql 安装
1.安装软件包依赖性:
[root@server1 ~]# yum install -y gcc gcc-c++ ncurses-devel bison openssl-devel zlib-devel
[root@server1 ~]# yum install -y cmake-2.8.12.2-4.el6.x86_64.rpm 用cmake[有进度条]
2.编译安装数据库
[root@server1 ~]# tar zxf mysql-boost-5.7.11.tar.gz
[root@server1 ~]# cd mysql-5.7.11/
[root@server1 mysql-5.7.11]# 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 \ #Unix socket 文件路径
> -DWITH_INNOBASE_STORAGE_ENGINE=1 \ #安装 innodb 存储引擎
> -DWITH_MYISAM_STORAGE_ENGINE=1 \ #安装 myisam 存储引擎
> -DDEFAULT_CHARSET=utf8 \ #使用 utf8 字符
> -DDEFAULT_COLLATION=utf8_general_ci \ #校验字符
> -DEXTRA_CHARSETS=all \ #安装所有扩展字符集
> -DWITH_BOOST=/root/mysql-5.7.11/boost/boost_1_59_0/
[root@server1 mysql-5.7.11]# make && make install
注意:
重新编译时,需要清除旧的对象文件和缓存信息
make clean
rm -f CmakeCache.txt
3.完成mysql初始化 [创建所需的用户及组]
[root@server1 mysql]# groupadd -g 27 mysql
[root@server1 mysql]# useradd -u 27 -g 27 -M -d /usr/local/lnmp/mysql/ mysql
[root@server1 local]# usermod -s /sbin/nologin mysql
[root@server1 mysql]# chown mysql.mysql . -R
4.解析mysql/bin的执行脚本
[root@server1 ~]# vim .bash_profile
[root@server1 ~]# source .bash_profile
[root@server1 mysql]# chown root . -R
5.修改配置文件中的数据库存放目录socket 文件路径与编译时一致
[root@server1 support-files]# vim /etc/my.cnf
6.拷贝执行脚本到本地执行目录下
[root@server1 support-files]# cp mysql.server /etc/init.d/mysqld
7.完成初始化 指定用户 并创建数据库
[root@server1 mysql]# mysqld --initialize --user=mysql
[root@server1 mysql]# chown mysql data -R 更改数据目录所有人为mysql
开启数据库 并修改密码
[root@server1 mysql]# /etc/init.d/mysqld start
[root@server1 mysql]# mysql_secure_installation #按提示完成 mysql 安全设置,生产环境推荐使用
二、Php 安装
1.解决安装所需依赖性
下载包
php-5.6.20.tar.bz2
安装依赖性
[root@server1 ~]# yum install libjpeg-turbo-devel-1.2.1-1.el6.x86_64
[root@server1 php-5.6.20]# yum install -y libxml2-devel
[root@server1 php-5.6.20]# yum install -y openssl-devel
[root@server1 php-5.6.20]# yum install -y curl-devel
[root@server1 ~]# yum install -y gd-devel-2.0.35-11.el6.x86_64.rpm
[root@server1 ~]# yum install -y gmp-devel
[root@server1 ~]# yum install libmcrypt-devel-2.5.8-9.el6.x86_64.rpm libmcrypt-2.5.8-9.el6.x86_64.rpm -y
[root@server1 ~]# yum install -y net-snmp-devel
[root@server1 ~]# yum install re2c-0.13.5-1.el6.x86_64.rpm -y
2.编译安装
[root@server1 ~]# tar jxf php-5.6.20.tar.bz2 解包
[root@server1 php-5.6.20]# ./configure --help 寻找帮助
--with-openssl 指定驱动 加密
--with-gd 图
--with-zlib php网页压缩(防盗链)
--with-pear 功能模块的组件(安装)
执行
[root@server1 php-5.6.20]# ./configure --prefix=/usr/local/lnmp/php --with-config-file-path=/usr/local/lnmp/php/etc --enable-mysqlnd --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-pear --with-gettext --with-gmp --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
输出的信息
Generating files
configure: creating ./config.status
creating main/internal_functions.c
creating main/internal_functions_cli.c
+--------------------------------------------------------------------+
| License: |
| This software is subject to the PHP License, available in this |
| distribution in the file LICENSE. By continuing this installation |
| process, you are bound by the terms of this license agreement. |
| If you do not agree with the terms of this license, you must abort |
| the installation process at this point. |
+--------------------------------------------------------------------+
Thank you for using PHP.
[root@server1 php-5.6.20]# make && make install
3.配置php解析文件/配置php-fpm配置文件
[root@server1 etc]# cp php-fpm.conf.default php-fpm.conf
[root@server1 etc]# ls
pear.conf php-fpm.conf php-fpm.conf.default
[root@server1 etc]# pwd
/usr/local/lnmp/php/etc
[root@server1 php-5.6.20]# cp php.ini-production /usr/local/lnmp/php/etc/php.ini
[root@server1 fpm]# pwd
/root/php-5.6.20/sapi/fpm
[root@server1 fpm]# cp init.d.php-fpm /etc/init.d/php-fpm 启动脚本
[root@server1 fpm]# chmod +x /etc/init.d/php-fpm 加执行权限
4.修改php配置文件 [pid][timezone]
[root@server1 etc]# vim php-fpm.conf
[root@server1 etc]# vim php.ini
添加php配置文件中指定的用户 并启动php
[root@server1 etc]# useradd -u 800 -M -d /usr/local/lnmp/nginx nginx
[root@server1 etc]# /etc/init.d/php-fpm start
三、Nginx 安装
1.安装依赖性并编译
[root@server1 ~]# tar zxf nginx-1.10.1.tar.gz
[root@server1 ~]# cd nginx-1.10.1
[root@server1 core]# pwd
/root/nginx-1.10.1/src/core
[root@server1 core]# vim nginx.h
#define NGINX_VER "nginx" (修改此行, 去掉后面的 “ NGINX_VERSION”,为了安全,这样编译后外界无法获取程序的版本号)
[root@server1 cc]# pwd
/root/nginx-1.10.1/auto/cc
[root@server1 cc]# vim gcc
#CFLAGS=”$CFLAGS -g” (注释掉这行,去掉 debug 模式编译,编译以后程序只有几百 k)
安装依赖
[root@server1 nginx-1.10.1]# yum install -y pcre-devel
编译
./configure --prefix=/usr/local/lnmp/nginx --with-http_ssl_module --with-http_stub_status_module --with-file-aio --with-threads --user=nginx --group=nginx
安装
[root@server1 nginx-1.10.1]# make && make install
做软链接
[root@server1 sbin]# ln -s /usr/local/lnmp/nginx/sbin/nginx /usr/local/sbin/
[root@server1 sbin]# nginx -t 检测语法
四、解决nginx和php的依赖关系
编辑nginx配置文件 修改tcp zip php
[root@server1 conf]# pwd
/usr/local/lnmp/nginx/conf
[root@server1 conf]# vim nginx.conf
[root@server1 conf]# nginx -t 检测语法
nginx: the configuration file /usr/local/lnmp/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/lnmp/nginx/conf/nginx.conf test is successful
[root@server1 conf]# nginx -s reload 重新加载
创建nginx访问php主页的页面
[root@server1 html]# pwd
/usr/local/lnmp/nginx/html
[root@server1 html]# vim index.php
[root@server1 html]# cat index.php
phpinfo()
?>
设置index.php为访问ip时默认访问的网页
[root@server1 conf]# vim nginx.conf
[root@server1 conf]# nginx -t
[root@server1 conf]# nginx -s reload
浏览器访问
五、解决php和mysql的依赖关系
[root@server1 etc]# pwd
/usr/local/lnmp/php/etc
[root@server1 etc]# vim php.ini
[root@server1 etc]# /etc/init.d/php-fpm reload 平滑加载
六、搭建基于lnmp的论坛
下载 Discuz_X3.2_SC_UTF8.zip
[root@server1 ~]# yum install -y unzip
[root@server1 ~]# unzip Discuz_X3.2_SC_UTF8.zip 解压
修改解压出的目录名字及位置
[root@server1 ~]# mv upload/ /bbs
ngnx设置虚拟主机 实现基于域名访问nginx
[root@server1 conf]# vim nginx.conf
[root@server1 conf]# nginx -s reload
注意:浏览器访问主机做好解析,/etc/hosts
访问:bbs.cara.org/install
根据提示 改权限
[root@server1 bbs]# chmod 777 config/ data
[root@server1 bbs]# chmod 777 config/ data -R
[root@server1 bbs]# chmod 777 uc_client/ uc_server/ -R
[root@server1 mysql]# chmod 755 data
[root@server1 ~]# /etc/init.d/mysqld restart
如下,已经完成!
查看数据库:
七、memcache 基于php的cache
1.安装memcache
修改环境变量
[root@server1 bin]# vim ~/.bash_profile
[root@server1 bin]# source ~/.bash_profile
[root@server1 ~]# tar zxf memcache-2.2.5.tgz
编译安装memcache
[root@server1 memcache-2.2.5]# ./configure --prefix=/usr/local/lnmp/php/memcache
[root@server1 memcache-2.2.5]# make && make install
[root@server1 etc]# pwd
/usr/local/lnmp/php/etc
[root@server1 etc]# vim php.ini
[root@server1 etc]# /etc/init.d/php-fpm reload 重新加载
拷贝文件
[root@server1 memcache-2.2.5]# cp example.php /usr/local/lnmp/nginx/html/
[root@server1 memcache-2.2.5]# cp memcache.php /usr/local/lnmp/nginx/html/
2.搭建一个memcache服务器
[root@server2 ~]# yum install -y memcached
[root@server2 ~]# /etc/init.d/memcached start 开启服务
[root@server2 ~]# yum install -y telnet
telnet命令用于登录远程主机,对远程主机进行管理。telnet采用明文传送报文,安全性不好;
[root@server1 html]# vim example.php
[root@server1 html]# vim memcache.php
(client -> nginx -> php-fpm -> php -> memcached -> mysql)