db01、web02、nfs

拆分数据库至独立服务器

| 为什么要进行数据库的拆分 |

由于单台服务器运行LNMP架构会导致网站访问缓慢,当内存被占满时,很容易导致系统出现oom从而kill屌MySQL数据库,所以要将web和数据库进行独立部署。


| 数据库拆分后解决了什么问题 |

1.缓解web网站的压力
2.增强数据库读写性能
3.提高用户访问速度


| 数据库拆分架构演变过程,如下图所示 |


| 数据库拆分 |

主机名称 应用环境 外网地址 内网地址
web01 nginx+php 10.0.0.7 172.16.1.7
db01 mysql 10.0.0.51 172.16.1.51

| 数据库拆分 |

1.web01网站服务器操作如下

1)备份web01上的数据库,lzy123.com是数据库密码

[root@web01 ~]# mysqldump -uroot -p'lzy123.com' -A > mysql-all.sql

2)将web01上备份的数据库拷贝至db01服务器上

[root@web01 ~]# scp mysql-all.sql  [email protected]:/tmp

2.db01数据库服务器操作如下

1)将web01服务器上推送的数据库备份文件恢复至db01服务器新数据库中

[root@db01 ~]# yum install mariadb mariadb-server -y
[root@db01 ~]# systemctl start mariadb
[root@db01 ~]# systemctl enable mariadb
[root@db01 ~]# mysql -uroot -p'lzy123.com' < /tmp/mysql-all.sql

2)数据库导入完成后,重启数据库,使用新密码进行登录,并检查数据库已被导入成功

[root@db01 ~]# systemctl restart mariadb
[root@db01 ~]# mysql -uroot -plzy123.com
mysql> show databases;

3)在新数据库上授权,允许所有网段,通过all账户连接并操作该数据库

#授权所有权限   grant all
#授权所有库所有表 *.* 
#将授权赋予给哪个用户,这个用户只能通过哪个网段过来(%所有) 'all'@'%'
#授权该用户登录的密码 identified by

mysql> grant all on  *.* to lzy@'%' identified by 'lzy123.com';
Query OK, 0 rows affected (0.00 sec)

mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

3.web01修改代码连接新数据库环境

1)修改Wordpress产品代码连接数据库的配置文件

[root@web01 ~]# vim /code/wordpress/wp-config.php
# 数据库名称
define('DB_NAME', 'wordpress');
# 数据库用户
define('DB_USER', 'lzy');
# 数据库密码
define('DB_PASSWORD', 'lzy123.com');
# 数据库地址
define('DB_HOST', '172.16.1.51');

2)修改wecenter产品代码连接数据库的配置文件

[root@web01 zh]#  grep -iR "lzy123.com"|grep -v cache
system/config/database.php:  'password' => 'lzy123.com',
[root@web01 zh]# vim /code/zh/system/config/database.php
'host' => '172.16.1.51',
'username' => 'lzy',
'password' => 'lzy123.com',
'dbname' => 'zh',

3)最后访问网站,成功打开,至此拆分数据库完成

扩展多台相同的Web服务器

| 为什么要扩展多台web节点 |

单台web服务器能抗住的访问量是有限的,配置多台web服务器能提升更高的访问速度。


| 扩展多台web解决了什么问题 |

1.单台web节点如果故障,会导致业务down机

2.多台web节点能保证业务的持续稳定,扩展性高

3.多台web节点能有效的提升用户访问网站的速度

3.多台web节点技术架构组成,如下图所示

[图片上传失败...(image-16c1d9-1616497425791)]

| 扩展web环境 |

主机名称 应用环境 外网地址 内网地址
web01 nginx+php 10.0.0.7 172.16.1.7
web02 nginx+php 10.0.0.8 172.16.1.8
db01 mysql 10.0.0.51 172.16.1.51

| 快速扩展一台web节点详细步骤 |

通过web01现有环境快速的扩展一台web02的服务器,数据库统一使用db01

1)创建www用户

[root@web02 ~]# groupadd -g666 www
[root@web02 ~]# useradd -u666 -g666 www

2)安装LNP

[root@web02 ~]# scp -rp [email protected]:/etc/yum.repos.d/* /etc/yum.repos.d/
[root@web02 ~]# scp -rp [email protected]:/etc/pki/rpm-gpg/* /etc/pki/rpm-gpg/

[root@web02 ~]# yum install nginx -y
[root@web02 ~]# yum -y install php71w php71w-cli php71w-common php71w-devel php71w-embedded php71w-gd php71w-mcrypt php71w-mbstring php71w-pdo php71w-xml php71w-fpm php71w-mysqlnd php71w-opcache php71w-pecl-memcached php71w-pecl-redis php71w-pecl-mongodb

3)将web01的nginx配置文件导入到web02

[root@web02 ~]# scp -rp [email protected]:/etc/nginx /etc/

4)将web01的php配置文件导入到web02

[root@web02 ~]# scp -rp [email protected]:/etc/php-fpm.d /etc/

5)将web01的产品代码打包传输到web02服务器上,在web01上线进行打包操作

[root@web01 ~]# tar czf code.tar.gz /code
[root@web01 ~]# scp code.tar.gz [email protected]:/tmp

#在web02服务器上进行解压
[root@web02 ~]# tar xf /tmp/code.tar.gz -C /

6)最后启动nginx与php-fpm,并加入开机自启

[root@web02 ~]# systemctl start nginx php-fpm 
[root@web02 ~]# systemctl enable nginx php-fpm

拆分静态资源至独立服务器

| 为什么拆分静态资源至独立存储服务器 |

当后端的web节点出现多台时,会导致用户上传的图片、视频附件等内容仅上传至一台web服务器,那么其他的web服务器则无法访问到该图片。


| 新增一台nfs存储解决了什么问题 |

1.保证了多台web节点静态资源一致。

2.有效节省多台web节点的存储空间。

3.统一管理静态资源,便于后期推送至CDN进行静态资源加速


| 多台web节点技术架构组成,如下图所示 |

| 环境准备 |

主机名称 应用环境 外网地址 内网地址
web01 nginx+php 10.0.0.7 172.16.1.7
web02 nginx+php 10.0.0.8 172.16.1.8
nfs nfs 10.0.0.31 172.16.1.31
db01 mysql 10.0.0.51 172.16.1.51

| nfs服务端,操作步骤如下 |

1) 安装并配置nfs

[root@nfs ~]# yum install nfs-utils -y
[root@nfs ~]# cat /etc/exports
/data/blog 172.16.1.0/24(rw,sync,all_squash,anonuid=666,anongid=666)
/data/zh 172.16.1.0/24(rw,sync,all_squash,anonuid=666,anongid=666)

2) 创建共享目录,并进行授权

[root@nfs01 ~]# mkdir /data/{blog,zh} -p
[root@nfs01 ~]# chown -R www.www /data/

3) 启动nfs服务,并加入开机自启

[root@nfs01 ~]# systemctl restart nfs-server

| web01端操作步骤如下 |

1) web01节点安装nfs,然后使用showmount查看服务端共享的资源

[root@web01 ~]# yum install nfs-utils -y
[root@web01 ~]# showmount -e 172.16.1.31
Export list for 172.16.1.31:
/data/zh   172.16.1.0/24
/data/blog 172.16.1.0/24

2) 如何查找Wordpress静态资源存放的位置

浏览器->右键->检查->Network->选择左上角的Select按钮->点击对应的图片,然后能获取到对应的url地址,如下
# http://blog.oldboy.com/wp-content/uploads/2018/11/timg.gif

3) 备份web01服务器上Wordpress的静态资源,因为该服务器上的资源资源最全

[root@web01 ~]# cd /code/wordpress/wp-content
[root@web01 wp-content]# cp uploads/ uploads_bak/

4) web01客户端执行挂载操作

[root@web01 wp-content]# mount -t nfs 172.16.1.31:/data/blog /code/wordpress/wp-content/uploads/

#恢复对应的数据
[root@web01 wp-content]# cp -rp uploads_bak/* uploads/

5) 将挂载信息加入开机自启

[root@web01 wp-content]# tail -1 /etc/fstab 
172.16.1.31:/data/blog  /code/wordpress/wp-content/uploads nfs defaults 0 0
[root@web01 wp-content]# mount -a

| web02端操作步骤如下 |

1) web02客户端直接挂载nfs即可

[root@web02 ~]# mount -t nfs 172.16.1.31:/data/blog /code/wordpress/wp-content/uploads/

2) 将挂载信息加入开机自启

[root@web02 ~]# tail -1 /etc/fstab 
172.16.1.31:/data/blog  /code/wordpress/wp-content/uploads nfs defaults 0 0
[root@web02 ~]# mount –a

你可能感兴趣的:(db01、web02、nfs)