码迷,mamicode.com
首页 > 数据库 > 详细

部署社交网站(SVN+PHP+NGINX+MYSQL+MFS)

时间:2018-10-04 11:05:27      阅读:179      评论:0      收藏:0      [点我收藏+]

标签:image   export   .com   mysql主从   mysql   sys   bundle   映射   sql数据库   

案例需求:社交网站采用PHP语言开发,为了管理开发代码,搭建SVN服务器进行版本控制,社交网站的第一个版本部署在LNMP平台上,前端为nginx服务器,通过fastcgi协议访问后端的PHP服务器。这里实现动静分离,动态页面交给PHP服务器来处理,静态页面交给nginx服务器来处理。为了保证数据安全,要求搭建Mysql数据库主从集群。

社交网站项目包含用户的相册功能,允许用户上传照片,上传照片需要使用共享存储来存放,针对共享存储采用MFS分布式文件系统来实现,并将MFS挂载在PHP服务器的相关目录下。

本案例拓扑图如图所示:
技术分享图片
案例实施
?部署SVN服务器,为PHP程序员创建repo目录的访问帐户,通知程序员可以导入代码
?部署Nginx服务器
?部署PHP服务器
?部署Mysql主从服务器,根据PHP程序员的要求创建数据库与表
?部署MFS,将MFS文件系统挂载在前端PHP服务器的相关目录下

案例部署环境:

主机 IP地址 操作系统 主要软件包
SVN 172.20.10.4 CentOS7
Nginx 172.20.10.9 CentOS7 nginx-1.12.0.tar.gz
PHP 172.20.10.10 CentOS7 php-5.6.11.tar.bz2,mfs-1.6.27-5.tar.gz,fuse-2.9.2.tar.gz, ZendGuardLoader-php-5.3-linux-glibc23-i386.tar.gz
Mysql1 172.20.10.11 CentOS7 mysql-5.5.24.tar.gz
Mysql2 172.20.10.12 CentOS7 mysql-5.5.24.tar.gz
MFS master 172.20.10.13 CentOS7 mfs-1.6.27-5.tar.gz
metalogger 172.20.10.14 CentOS7 mfs-1.6.27-5.tar.gz
MFS chunk1 172.20.10.2 CentOS7 mfs-1.6.27-5.tar.gz
MFS chunk2 172.20.10.3 CentOS7 mfs-1.6.27-5.tar.gz

首先关闭所有主机的防火墙,selinux功能

systemctl stop firewalld.service
setenforce 0

部署SVN服务器:
?安装SVN服务
yum install -y subversion #安装SVN
svnserve --version #查看版本
技术分享图片
为PHP程序员创建仓库目录repo
mkdir -p /opt/svn/repo
//创建目录
svnadmin create /opt/svn/repo/
//创建一个新的仓库
技术分享图片
调整SVN参数
vim /opt/svn/repo/conf/svnserve.conf
anon-access = none
//匿名用户没有任何权限
auth-access = write
//认证用户具有写权限
password-db = /opt/svn/repo/conf/passwd //用户的密码文件
authz-db = /opt/svn/repo/conf/authz //用户信息文件,主要是权限内容
技术分享图片
启动SVN服务
svnserve -d -r /opt/svn/repo/
netstat -tunpl|grep svnserve
技术分享图片
为PHP程序员创建账户并赋权
vim /opt/svn/repo/conf/passwd
[users]
zhangsan = abc123
sysadmin = abc123
技术分享图片
vim /opt/svn/repo/conf/authz
[/]
zhangsan = r //根目录即/opt/svn/repo目录下,sysadmin具有读的权限
sysadmin = r //zhangsan用户对根目录有读的权限
[/webphp]
zhangsan = rw //zhangsan用户对此目录有读写的权限,用户导入PHP代码
sysadmin = r //运维工程师具有读的权限,用于部署
技术分享图片
初始化php程序员目录库
mkdir /opt/svn/repo/webphp
svn import webphp/ file:///opt/svn/repo/webphp -m "初始化svn目录"
技术分享图片
SVN服务器部署完成,PHP程序员可以将写好的代码导入webphp项目中。
部署Nginx服务
?事先将需要的软件包放到家目录下,进行部署;
yum -y install pcre-devel zlib-devel gcc gcc-c++ make
useradd -M -s /sbin/nologin nginx
tar xzvf nginx-1.12.0.tar.gz -C /opt
cd /opt/nginx-1.12.0/
./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_stub_status_module
make && make install
ln -s /usr/local/nginx/sbin/* /usr/local/sbin/
nginx
netstat -antp | grep nginx
技术分享图片

配置nginx支持php解析
(1)在nginx的主配置文件中的server{}配置段,将php的网页请求转给PHP服务器的fpm模块处理
vi /usr/local/nginx/conf/nginx.conf
location ~ .php$ {
root /var/www/html/webphp; #php文件所在目录
fastcgi_pass 172.20.10.10:9000; #php文件转发给php-fpm模块
fastcgi_index index.php; #默认文件是index.php
include fastcgi.conf; #包含fastcgi的配置文件
}
技术分享图片
技术分享图片
(2)重启nginx服务

killall -1 nginx

部署PHP服务器
?事先将需要的软件包放到家目录下,进行部署;
(1)安装php
yum -y install gd libxml2-devel libjpeg-devel libpng-devel zlib-devel fontconfig-devel openssl-devel bzip2-devel
cd ~/
tar xjvf php-5.6.11.tar.bz2
cd php-5.6.11/
./configure --prefix=/usr/local/php5 --with-gd --with-zlib -with-config-file-path=/usr/local/php5 --enable-mbstring --with-jpeg-dir=/usr/lib --with-openssl --disable-ipv6 --enable-fpm
make && make install
cp php.ini-development /usr/local/php5/php.ini
ln -s /usr/local/php5/bin/ /usr/local/bin/
ln -s /usr/local/php5/sbin/
/usr/local/sbin/

(2)配置安装php加速器

cd ~/
tar xzvf ZendGuardLoader-php-5.3-linux-glibc23-i386.tar.gz
cd ZendGuardLoader-php-5.3-linux-glibc23-i386/php-5.3.x
cp ZendGuardLoader.so /usr/local/php5/lib/php
vim /usr/local/php5/php.ini

在php.ini文件末尾加入以下参数,开启ZendGuardLoader模块

技术分享图片
(3)配置php-fpm进程

cd /usr/local/php5/etc/
cp php-fpm.conf.default php-fpm.conf
useradd -M -s /sbin/nologin php
vim php-fpm.conf
//找到这些内容,然后修改
pid = run/php-fpm.pid
user = php
group = php
listen = 0.0.0.0:9000
pm.max_children = 50
pm.start_servers = 20
pm.min_spare_servers = 5
pm.max_spare_servers = 35
技术分享图片
技术分享图片
技术分享图片
技术分享图片
(4)启动php-fpm进程
/usr/local/sbin/php-fpm
netstat -tnal | grep 9000
技术分享图片
部署MySQL数据库,部署主从复制
?事先将需要的软件包放到家目录下,进行部署;

yum -y install ncurses-devel cmake gcc gcc-c++ ncurses bison libaio-devel
cd ~/
tar xzvf mysql-5.5.24.tar.gz
cd mysql-5.5.24/
cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_EXTRA_CHARSETS=all -DSYSCONFDIR=/etc -DMYSQL_DATADIR=/home/mysql/ -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_ARCHIVE_STORAGE_ENGINE=1 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 -DENABLED_LOCAL_INFILE=1 -DWITH_SSL=system -DMYSQL_TCP_PORT=3306 -DENABLE_DOWNLOADS=1 -DWITH_SSL=bundled
make && make install

优化调整

在mysql源码目录中的support-files文件夹下,根据实际需求建立mysql系统的配置文件my.cnf

将mysql服务的启动脚本mysql.server添加为系统服务,并设置为开机自启项
\cp support-files/my-medium.cnf /etc/my.cnf
cp support-files/mysql.server /etc/init.d/mysqld
chmod +x /etc/init.d/mysqld
chkconfig --add mysqld
chkconfig --level 35 mysqld on

设置环境变量

为了方便在任何目录下使用mysql命令,需要在/etc/profile设置环境变量
echo "PATH=$PATH:/usr/local/mysql/bin/" >> /etc/profile
source /etc/profile

初始化数据库

为了能够正常使用mysql数据库系统,应以运行用户mysql的身份执行初始化
useradd -s /sbin/nologin mysql
chown -R mysql.mysql /usr/local/mysql
/usr/local/mysql/scripts/mysql_install_db --user=mysql --ldata=/var/lib/mysql --basedir=/usr/local/mysql --datadir=/home/mysql

vim /etc/init.d/mysqld

...........

basedir=/usr/local/mysql

datadir=/home/mysql #修改服务启动脚本,指定数据存放位置

............

启动mysql服务
service mysqld start
netstat -anpt | grep 3306

配置主从复制;
?修改mysql master主服务器的配置文件,在配置文件中修改或增加以下选项

vim /etc/my.cnf

server-id = 1 //修改id
log-bin=master-bin //增加主服务器日志文件//
log-slave-updates=true //增加从服务器更新二进制日志//
技术分享图片
重启服务

service mysqld restart
技术分享图片
登录mysql程序,给mysql slave从服务器授权
技术分享图片
mysql slave从服务器配置

?在配置文件中修改或增加以下选项

vim /etc/my.cnf

[mysqld]

server-id = 2 #与主服务器id不一样

relay-log=relay-log-bin //从主服务器上同步日志文件记录到本地//

relay-log-index=slave-relay-bin.index //定义relay-log的位置和名称//
技术分享图片
service mysqld restart
技术分享图片
登录mysql配置同步

按主服务器结果更改下面命令中的master_log_file和master_log_pos的参数
技术分享图片
在mysql master上给PHP服务器帐户授权,并同时验证主从同步;
技术分享图片
在mysql slave上查看同步过来的数据库daima;
技术分享图片
映射SVN仓库webphp服务目录到Nginx和PHP服务器上;

在Nginx服务器上;
技术分享图片
编辑nginx首页文档index.html,并在浏览器上进行测试
技术分享图片
技术分享图片

在PHP服务器上

mkdir -p /var/www/html/
技术分享图片
在网站根目录下编写一个“.php”格式的测试页面文件,使用PHP内建的“phpinfo()”函数显示服务器的PHP环境信息,PHP代码应包括在“<?php....?>”标记之间。
技术分享图片
在网页 测试“http://172.20.10.9/index.php”,若能够看到PHP程序的版本号,配置命令,运行变量等相关信息,则表示web服务器已经能够正常显示PHP网页
技术分享图片
测试PHP网页能否访问Mysql数据库

?再编写一个测试网页文件mysql.php,添加简单的数据库操作命令,用于验证与Mysql服务器的连接,查询等操作。其中“mysql_connect()”函数用于连接Mysql数据库,需要指定目标主机地址,以及授权访问的用户名,密码。
技术分享图片
通过浏览器访问测试网页,“http://172.20.10.9/mysql.php”,若能看到成功连接的提示信息,则表示能够通过PHP页面访问Mysql数据库
技术分享图片

部署MFS分布式文件系统

具体部署过程可参考另一篇文章《MFS分布式文件系统原理及环境搭建》

?搭建Master Server
yum install -y zlib-devel gcc gcc-c++
useradd mfs -s /sbin/nologin

tar xvf mfs-1.6.27-5.tar.gz
cd mfs-1.6.27/
./configure \
--prefix=/usr/local/mfs \
--with-default-user=mfs \
--with-default-group=mfs \
--disable-mfschunkserver \
--disable-mfsmount

make && make install

复制配置文件

在Master上需要用到的配置文件有两个:mfsmaster.cfg(主配置文件)和mfsexports.cfg(被挂载目录及权限配置文件)

cd /usr/local/mfs/etc/mfs/
cp mfsexports.cfg.dist mfsexports.cfg
cp mfsmaster.cfg.dist mfsmaster.cfg
cp mfsmetalogger.cfg.dist mfsmetalogger.cfg

cd /usr/local/mfs/var/mfs/
cp metadata.mfs.empty metadata.mfs

/usr/local/mfs/sbin/mfsmaster start #开启服务
?搭建MetaLogger server

yum install gcc gcc-c++ zlib-devel -y
useradd -s /sbin/nologin mfs

tar zxvf mfs-1.6.27-5.tar.gz
cd mfs-1.6.27

./configure \
--prefix=/usr/local/mfs \
--with-default-user=mfs \
--with-default-group=mfs \
--disable-mfschunkserver \
--disable-mfsmount

make && make install

cd /usr/local/mfs/etc/mfs/
cp mfsmetalogger.cfg.dist mfsmetalogger.cfg

修改配置文件
vi mfsmetalogger.cfg
MATER_HOST = 172.20.10.13 #指向master
技术分享图片

/usr/local/mfs/sbin/mfsmetalogger start #开启服务

?搭建chunk Server(两台节点服务配置一样)

yum install -y zlib-devel gcc gcc-c++
useradd -s /sbin/nologin mfs
tar zxvf mfs-1.6.27-5.tar.gz
cd mfs-1.6.27
./configure \
--prefix=/usr/local/mfs \
--with-default-user=mfs \
--with-default-group=mfs \
--disable-mfsmaster \
--disable-mfsmount

make && make install

cd /usr/local/mfs/etc/mfs/
cp mfschunkserver.cfg.dist mfschunkserver.cfg
cp mfshdd.cfg.dist mfshdd.cfg

修改配置文件

vi mfschunkserver.cfg
MASTER_HOST = 172.20.10.13
技术分享图片
指定 MFS共享文件存储目录,
vi mfshdd.cfg
/data
技术分享图片

mkdir /data
chown -R mfs:mfs /data

/usr/local/mfs/sbin/mfschunkserver start #启动服务
?在PHP服务器上配置MFS客户端。并挂载使用;

安装fuse插件

yum install -y zlib-devel gcc gcc-c++

tar xzvf fuse-2.9.2.tar.gz
cd fuse-2.9.2

./configure
make && make install

vi /etc/profile
export PKG_CONFIG_PATH=/usr/local/lib/pkgconfig:$PKG_CONFIG_PATH
source /etc/profile

安装MFS

useradd mfs -s /sbin/nologin

tar zxvf mfs-1.6.27-5.tar.gz
cd mfs-1.6.27

./configure \
--prefix=/usr/local/mfs \
--with-default-user=mfs \
--with-default-group=mfs \
--disable-mfsmaster \
--disable-mfschunkserver \
--enable-mfsmount

make && make install

将mfs文件系统挂载在PHP服务器的/var/www/html/webphp/uploads/photos目录下
mkdir -p /var/www/html/webphp/uploads/photos

modprobe fuse //加载fuse模块到内核//
/usr/local/mfs/bin/mfsmount /var/www/html/webphp/uploads/photos -H 172.20.10.13
df –hT
技术分享图片

优化客户端

echo "export PATH=/usr/local/mfs/bin:$PATH" >>/etc/profile

source /etc/profile
技术分享图片
mfssetgoal -r 2 /var/www/html/webphp/uploads/photos/ #设置文件被复制两份
?在MASTER-server上启动监控服务,通过浏览器可以监控MFS系统

/usr/local/mfs/sbin/mfscgiserv
技术分享图片
下一篇《SVN客户端配置及PHP程序员代码导入》将讲解在windows部署SVN客户端及PHP程序员如何将代码导入webphp项目中。

部署社交网站(SVN+PHP+NGINX+MYSQL+MFS)

标签:image   export   .com   mysql主从   mysql   sys   bundle   映射   sql数据库   

原文地址:http://blog.51cto.com/13728740/2292334

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!