【运维知识进阶篇】集群架构-Nginx实现基础web架构(Linux+Nginx+PHP+Mysql)(二)

简介: 【运维知识进阶篇】集群架构-Nginx实现基础web架构(Linux+Nginx+PHP+Mysql)(二)

拆分数据库至独立服务器

为什么要拆分数据库

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

 

注意:这种的功能是一个整体,属于集群,不属于微服务。

拆分服务器可以解决如下问题:

1.缓解web网站的压力

2.增强数据库读写性能

3.提高用户访问速度

实现流程

1、克隆一台服务器51

2、安装mariadb-server

【省略,上面有流程】

3、导出10.0.0.7上面的所有库文件,并关闭MySQL服务(如果一开始使用的51就省略该步骤了)

1. [root@Web01 ~]# mysqldump -uroot -p666666 -A > all.sql  
2. [root@Web01 ~]# ll
3. total 2508
4. -rw-r--r--  1 root root 2563044 Apr  6 09:06 all.sql
5. -rw-------. 1 root root    1519 Mar 29 18:41 anaconda-ks.cfg
6. [root@Web01 ~]# scp all.sql 10.0.0.51:/root/        #将all.sql发送到10.0.0.51的root下
7. The authenticity of host '10.0.0.51 (10.0.0.51)' can't be established.
8. ECDSA key fingerprint is SHA256:zQvI/tCFYssR7l6cr90EtaIA93FXJp8FmUhGtkZshlA.
9. ECDSA key fingerprint is MD5:0b:a1:ee:d2:75:92:1a:62:05:63:5e:d1:e8:42:13:84.
10. Are you sure you want to continue connecting (yes/no)? yes    
11. Warning: Permanently added '10.0.0.51' (ECDSA) to the list of known hosts.
12. root@10.0.0.51's password: 
13. all.sql               100% 2503KB  35.0MB/s   00:00
14. [root@Web01 ~]# systemctl stop mariadb
15. [root@Web01 ~]# systemctl disable mariadb
16. Removed symlink /etc/systemd/system/multi-user.target.wants/mariadb.service.

4、导入到10.0.0.51新数据、检查数据库是否导入成功

1. [root@MySQL ~]# mysql -uroot -p666666 < all.sql 
2. [root@MySQL ~]# mysql -uroot -p666666 -e "show databases"
3. +--------------------+
4. | Database           |
5. +--------------------+
6. | information_schema |
7. | mysql              |
8. | performance_schema |
9. | phpshe             |
10. | test               |
11. | wecenter           |
12. | wordpress          |
13. +--------------------+
14. [root@MySQL ~]#

5、修改代码中连接数据库的信息(服务需要挨个修改)

浏览器访问网址

1. #授权普通用户,允许远程连接51
2. 
3. [root@MySQL ~]# mysql -uroot -p666666
4. Welcome to the MariaDB monitor.  Commands end with ; or \g.
5. Your MariaDB connection id is 10
6. Server version: 5.5.68-MariaDB MariaDB Server
7. 
8. Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.
9. 
10. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
11. 
12. MariaDB [(none)]> grant all on  *.* to koten@'%' identified by '666666';
13. Query OK, 0 rows affected (0.00 sec)
14. 
15. MariaDB [(none)]> quit
16. Bye
17. 
18. 
19. [root@Web01 ~]# vim /code/wordpress/wp-config.php
20. /** The name of the database for WordPress */
21. define( 'DB_NAME', 'wordpress' );        #数据库名称
22. define( 'DB_USER', 'koten' );            #数据库用户
23. 
24. /** Database password */
25. define( 'DB_PASSWORD', '666666' );    #数据库密码
26. 
27. /** Database hostname */
28. define( 'DB_HOST', '10.0.0.51' );        #修改远程连接IP地址

修改后刷新浏览器,发现恢复(其他服务同理)

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

1、安装NFS

[root@NFS ~]# yum -y install nfs-utils

2、创建匿名压缩用户www

1. [root@NFS ~]# groupadd -g666 www
2. [root@NFS ~]# useradd -u666 -g666 -M -s /sbin/nologin www

3、修改配置文件

1. [root@NFS ~]# cat /etc/exports
2. /data/wordpress 172.16.1.0/24(rw,sync,all_squash,anonuid=666,anongid=666)
3. /data/wecenter 172.16.1.0/24(rw,sync,all_squash,anonuid=666,anongid=666)

4、创建必要数据文件

1. [root@NFS ~]# mkdir -p /data/wordpress
2. [root@NFS ~]# mkdir -p /data/wecenter
3. [root@NFS ~]# chown www.www /data/*
4. [root@NFS ~]# ll /data/
5. total 0
6. drwxr-xr-x 2 www www 6 Apr  6 10:08 wecenter
7. drwxr-xr-x 2 www www 6 Apr  6 10:08 wordpress

5、启动NFS

1. [root@NFS ~]# systemctl start nfs
2. [root@NFS ~]# systemctl enable nfs
3. Created symlink from /etc/systemd/system/multi-user.target.wants/nfs-server.service to /usr/lib/systemd/system/nfs-server.service.

6、找出业务上传图片的目录并挂载

右键复制图片连接地址:找到上传目录uploads

http://blog.koten.com/wp-content/uploads/2023/04/1.jpg

 

1)将2023目录拷贝到31的/data/wordpress/

1. [root@Web01 ~]# scp -r /code/wordpress/wp-content/uploads/* 172.16.1.31:/data/wordpress/
2. The authenticity of host '172.16.1.31 (172.16.1.31)' can't be established.
3. ECDSA key fingerprint is SHA256:zQvI/tCFYssR7l6cr90EtaIA93FXJp8FmUhGtkZshlA.
4. ECDSA key fingerprint is MD5:0b:a1:ee:d2:75:92:1a:62:05:63:5e:d1:e8:42:13:84.
5. Are you sure you want to continue connecting (yes/no)? yes
6. Warning: Permanently added '172.16.1.31' (ECDSA) to the list of known hosts.
7. root@172.16.1.31's password: 
8. music-music-1.6.2.zip 100%   67KB   6.5MB/s   00:00
9. HTML5中国象棋.zip 100% 1571KB  30.9MB/s   00:00
10. 小霸王-FC怀旧游 100% 7718KB  48.9MB/s   00:00
11. [root@Web01 ~]#

NFS重新授权下面的目录权限

1. [root@NFS wordpress]# chown -R www.www /data/wordpress/
2. [root@NFS wordpress]# ll /data/wordpress/
3. total 0
4. drwxr-xr-x 3 www www 16 Apr  6 15:22 2023

2)将31/data/wordpress挂载到uploads目录

1. web1安装nfs-utils
2. [root@Web01 ~]# yum -y install nfs-utils
3. 
4. 查看共享目录
5. [root@Web01 ~]# showmount -e 172.16.1.31
6. Export list for 172.16.1.31:
7. /data/wecenter  172.16.1.0/24
8. /data/wordpress 172.16.1.0/24
9. 
10. 挂载NFS共享目录/data/wordpress并查看挂载信息
11. [root@Web01 ~]# mount -t nfs 172.16.1.31:/data/wordpress /code/wordpress/wp-content/uploads
12. [root@Web01 ~]# df -h
13. Filesystem                   Size  Used Avail Use% Mounted on
14. devtmpfs                     476M     0  476M   0% /dev
15. tmpfs                        487M     0  487M   0% /dev/shm
16. tmpfs                        487M  7.7M  479M   2% /run
17. tmpfs                        487M     0  487M   0% /sys/fs/cgroup
18. /dev/sda3                     19G  2.4G   17G  13% /
19. /dev/sda1                    197M  110M   88M  56% /boot
20. tmpfs                         98M     0   98M   0% /run/user/0
21. 172.16.1.31:/data/wordpress   19G  2.0G   17G  11% /code/wordpress/wp-content/uploads

 

扩展一个web节点(web2服务器)

可以直接克隆,也可以创建新服务器自己安装配置服务,同步文件

1、安装Nginx+PHP+NFS

1. Nginx
2. 
3. [root@Web02 ~]# scp 172.16.1.7:/etc/yum.repos.d/nginx.repo /etc/yum.repos.d/
4. The authenticity of host '172.16.1.7 (172.16.1.7)' can't be established.
5. ECDSA key fingerprint is SHA256:zQvI/tCFYssR7l6cr90EtaIA93FXJp8FmUhGtkZshlA.
6. ECDSA key fingerprint is MD5:0b:a1:ee:d2:75:92:1a:62:05:63:5e:d1:e8:42:13:84.
7. Are you sure you want to continue connecting (yes/no)? yes
8. Warning: Permanently added '172.16.1.7' (ECDSA) to the list of known hosts.
9. root@172.16.1.7's password: 
10. nginx.repo            100%  192   110.1KB/s   00:00
11. [root@Web02 ~]# yum -y install nginx
12. 
13. 
14. PHP
15. 安装PHP软件【文末可以下载】
16. [root@Web02 ~]# rz -E
17. rz waiting to receive.
18. [root@Web02 ~]# ls
19. anaconda-ks.cfg  php71.tar.gz
20. [root@Web02 ~]# tar xf php71.tar.gz 
21. [root@Web02 ~]# yum -y localinstall *.rpm
22. 
23. 
24. 扩展:批量删除PHP软件
25. [root@Web02 ~]# rpm -qa|grep php|xargs yum -y remove
26. 
27. 
28. NFS
29. 安装nfs-utils,但不用启动
30. [root@Web02 ~]# yum -y install nfs-utils
31.

2、创建虚拟用户www

1. [root@Web02 ~]# groupadd -g666 www
2. [root@Web02 ~]# useradd -u666 -g666 -M -s /sbin/nologin www

3、同步配置文件和WEB01相同(/etc/nginx/,/etc/php-fpm.d/www.conf)

1. #同步Nginx配置
2. [root@Web02 ~]# rsync -avz --delete 172.16.1.7:/etc/nginx/ /etc/nginx
3. root@172.16.1.7's password: 
4. receiving incremental file list
5. ./
6. nginx.conf
7. conf.d/
8. conf.d/default.conf
9. conf.d/phpshe.conf
10. conf.d/wecenter.conf
11. conf.d/wordpress.conf
12. 
13. sent 155 bytes  received 1,701 bytes  1,237.33 bytes/sec
14. total size is 9,775  speedup is 5.27
15. 
16. #同步PHP配置
17. [root@Web02 conf.d]# rsync -avz --delete 172.16.1.7:/etc/php-fpm.d/www.conf /etc/php-fpm.d/www.conf 
18. root@172.16.1.7's password: 
19. receiving incremental file list
20. www.conf
21. 
22. sent 199 bytes  received 425 bytes  113.45 bytes/sec
23. total size is 17,962  speedup is 28.79

4、同步代码文件到WEB02

打包code然后拷贝到web02,进行解压到/目录

1. [root@Web01 04]# tar zcvf code.tar.gz /code/
2. 
3. [root@Web02 ~]# scp 172.16.1.7:/code/wordpress/wp-content/uploads/2023/04/code.tar.gz /
4. root@172.16.1.7's password: 
5. code.tar.gz           100%  168MB  40.6MB/s   00:04    
6. [root@Web02 /]# tar xf code.tar.gz 
7. [root@Web02 /]# ll /code
8. total 8
9. drwxr-xr-x  8 www www  300 Apr  6 09:56 phpshe
10. drwxr-xr-x 14 www www 4096 Apr  4 17:13 wecenter
11. drwxr-xr-x  5 www www 4096 Apr  6 09:21 wordpress

5、启动服务、挂载NFS到本地上传目录

1. #启动服务
2. [root@Web02 code]# systemctl start nginx php-fpm
3. [root@Web02 code]# systemctl enable nginx php-fpm
4. Created symlink from /etc/systemd/system/multi-user.target.wants/nginx.service to /usr/lib/systemd/system/nginx.service.
5. Created symlink from /etc/systemd/system/multi-user.target.wants/php-fpm.service to /usr/lib/systemd/system/php-fpm.service.
6. 
7. #挂载NFS到本地上传目录
8. [root@Web02 code]# mount -t nfs 172.16.1.31:/data/wordpress /code/wordpress/wp-content/uploads/
9. [root@Web02 code]# df -h
10. Filesystem                   Size  Used Avail Use% Mounted on
11. devtmpfs                     476M     0  476M   0% /dev
12. tmpfs                        487M     0  487M   0% /dev/shm
13. tmpfs                        487M  7.7M  479M   2% /run
14. tmpfs                        487M     0  487M   0% /sys/fs/cgroup
15. /dev/sda3                     19G  2.4G   17G  13% /
16. /dev/sda1                    197M  110M   88M  56% /boot
17. tmpfs                         98M     0   98M   0% /run/user/0
18. 172.16.1.31:/data/wordpress   19G  2.2G   17G  12% /code/wordpress/wp-content/uploads

Linux系统PHP软件下载链接:https://pan.baidu.com/s/1E9QfpakeZA1zkA3B7-urjw?pwd=r843 

我是koten,10年运维经验,持续分享运维干货,感谢大家的阅读和关注!

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
打赏
0
0
0
0
41
分享
相关文章
数据库运维:mysql 数据库迁移方法-mysqldump
本文介绍了MySQL数据库迁移的方法与技巧,重点探讨了数据量大小对迁移方式的影响。对于10GB以下的小型数据库,推荐使用mysqldump进行逻辑导出和source导入;10GB以上可考虑mydumper与myloader工具;100GB以上则建议物理迁移。文中还提供了统计数据库及表空间大小的SQL语句,并讲解了如何使用mysqldump导出存储过程、函数和数据结构。通过结合实际应用场景选择合适的工具与方法,可实现高效的数据迁移。
101 1
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
本文聚焦 MySQL 集群架构中的负载均衡算法,阐述其重要性。详细介绍轮询、加权轮询、最少连接、加权最少连接、随机、源地址哈希等常用算法,分析各自优缺点及适用场景。并提供 Java 语言代码实现示例,助力直观理解。文章结构清晰,语言通俗易懂,对理解和应用负载均衡算法具有实用价值和参考价值。
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
大数据新视界--大数据大厂之MySQL数据库课程设计:MySQL集群架构负载均衡故障排除与解决方案
本文深入探讨 MySQL 集群架构负载均衡的常见故障及排除方法。涵盖请求分配不均、节点无法响应、负载均衡器故障等现象,介绍多种负载均衡算法及故障排除步骤,包括检查负载均衡器状态、调整算法、诊断修复节点故障等。还阐述了预防措施与确保系统稳定性的方法,如定期监控维护、备份恢复策略、团队协作与知识管理等。为确保 MySQL 数据库系统高可用性提供全面指导。
阿里面试:Redis 为啥那么快?怎么实现的100W并发?说出了6大架构,面试官跪地: 纯内存 + 尖端结构 + 无锁架构 + EDA架构 + 异步日志 + 集群架构
阿里面试:Redis 为啥那么快?怎么实现的100W并发?说出了6大架构,面试官跪地: 纯内存 + 尖端结构 + 无锁架构 + EDA架构 + 异步日志 + 集群架构
阿里面试:Redis 为啥那么快?怎么实现的100W并发?说出了6大架构,面试官跪地: 纯内存 + 尖端结构 +  无锁架构 +  EDA架构  + 异步日志 + 集群架构
融合AMD与NVIDIA GPU集群的MLOps:异构计算环境中的分布式训练架构实践
本文探讨了如何通过技术手段混合使用AMD与NVIDIA GPU集群以支持PyTorch分布式训练。面对CUDA与ROCm框架互操作性不足的问题,文章提出利用UCC和UCX等统一通信框架实现高效数据传输,并在异构Kubernetes集群中部署任务。通过解决轻度与强度异构环境下的挑战,如计算能力不平衡、内存容量差异及通信性能优化,文章展示了如何无需重构代码即可充分利用异构硬件资源。尽管存在RDMA验证不足、通信性能次优等局限性,但该方案为最大化GPU资源利用率、降低供应商锁定提供了可行路径。源代码已公开,供读者参考实践。
260 3
融合AMD与NVIDIA GPU集群的MLOps:异构计算环境中的分布式训练架构实践
IngressNightmare:Ingress Nginx 再曝5个安全漏洞,可接管你的 K8s 集群
是否还记得 2022 年 K8s Ingress Nginx 披露了的 3 个高危安全漏洞(CVE-2021-25745, CVE-2021-25746, CVE-2021-25748),并在那一年宣布停止接收新功能 PR,专注修复并提升稳定性。
中小医院云HIS系统源码,系统融合HIS与EMR功能,采用B/S架构与SaaS模式,快速交付并简化运维
这是一套专为中小医院和乡镇卫生院设计的云HIS系统源码,基于云端部署,采用B/S架构与SaaS模式,快速交付并简化运维。系统融合HIS与EMR功能,涵盖门诊挂号、预约管理、一体化电子病历、医生护士工作站、收费财务、药品进销存及统计分析等模块。技术栈包括前端Angular+Nginx,后端Java+Spring系列框架,数据库使用MySQL+MyCat。该系统实现患者管理、医嘱处理、费用结算、药品管控等核心业务全流程数字化,助力医疗机构提升效率和服务质量。
236 4
【赵渝强老师】达梦数据库MPP集群的架构
达梦数据库提供大规模并行处理(MPP)架构,以低成本实现高性能并行计算,满足海量数据存储和复杂查询需求。DM MPP采用完全对等无共享体系,消除主节点瓶颈,通过多节点并行执行提升性能。其执行流程包括主EP生成计划、分发任务、各EP并行处理及结果汇总返回。为确保高可用性,建议结合数据守护部署。
103 0
【手把手教你Linux环境下快速搭建Kafka集群】内含脚本分发教程,实现一键部署多个Kafka节点
本文介绍了Kafka集群的搭建过程,涵盖从虚拟机安装到集群测试的详细步骤。首先规划了集群架构,包括三台Kafka Broker节点,并说明了分布式环境下的服务进程配置。接着,通过VMware导入模板机并克隆出三台虚拟机(kafka-broker1、kafka-broker2、kafka-broker3),分别设置IP地址和主机名。随后,依次安装JDK、ZooKeeper和Kafka,并配置相应的环境变量与启动脚本,确保各组件能正常运行。最后,通过编写启停脚本简化集群的操作流程,并对集群进行测试,验证其功能完整性。整个过程强调了自动化脚本的应用,提高了部署效率。
1622 1
【手把手教你Linux环境下快速搭建Kafka集群】内含脚本分发教程,实现一键部署多个Kafka节点
卓越效能,极简运维,Serverless高可用架构
本文介绍了Serverless高可用架构方案,当企业面对日益增长的用户访问量和复杂的业务需求时如何实现更高的灵活性、更低的成本和更强的稳定性。
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等

登录插画

登录以查看您的控制台资源

管理云资源
状态一览
快捷访问