如何在多个服务器上安装WordPress分布式部署

news2024/11/28 14:38:59

许多网络主机现在保证其服务的正常运行时间为 99.9%,但这仍然每年最多有 8.7 小时的停机时间。

许多公司不能够承担这种风险。例如。在超级碗比赛中失败的体育新闻网站可能会失去忠实的追随者。

我们通过设置维护高可用性 WordPress分布式部署配置来帮助 WordPress 网站主防止此类灾难性故障。

今天我们将介绍我们的支持工程师如何设置 WordPress 多服务器。

目录  隐藏 

如何在多个服务器上设置 WordPress分布式部署?

步骤 1. WordPress 文件的高可用性

步骤 2. 数据库的高可用性

步骤 3. 设置负载均衡器

结论

如何在多个服务器上设置 WordPress分布式部署?

将 WordPress 移动到多个服务器通常会产生跨服务器数据不完整、会话文件损坏、网页加载缓慢等问题。

幸运的是,这些限制可以通过规划和使用 HAProxy、Percona XtraDB 等特殊工具来纠正。

在这些软件的帮助下,我们的支持工程师仅用 5 台服务器就成功地在多台服务器中实施了 WordPress。

让我们看看这个实现中的 3 个主要步骤。

步骤 1. WordPress 文件的高可用性

维持网站正常运行的第一步是确保 WordPress 文件始终可用。

为此,我们使用 3 台服务器并在每台服务器中维护一组相同的网站文件。

在一台服务器上完成的 WordPress 帖子添加、删除、媒体上传等任何操作都应立即在所有服务器上更新。否则访问者可能会发现网站异常。

由于文件变化太多,要在最短时间内更新所有服务器上的文件成为一个真正的挑战。

根据我们在管理服务器方面的专业知识,我们看到Unison是适用于 WordPress 文件的解决方案之一。

Unison 有助于更新所有服务器上的网站内容更改。

步骤 2. 数据库的高可用性

我们现在在所有 3 个服务器中都有相同的网站文件。

WordPress 将其所有帖子、评论等存储在数据库中。即使是 WordPress 中的一个小页面添加也涉及多个数据库操作。

因此,下一步是确保 WordPress 数据库始终正常工作。

为此,我们使用数据库服务器集群。为了任何集群的正常工作,我们需要一个至少包含 3 台服务器的服务器池。只有 2 个服务器的问题是,如果服务器之间的连接丢失,高可用性的整个想法就会失败。

可以在同一台服务器上运行多个服务,如 Web 服务器、数据库服务器等。

因此,我们使用与文件集群相同的 3 台服务器设置了一个数据库集群。

数据库集群中最大的挑战是即时复制所有服务器中的数据库更改。也就是说,当一个条目从数据库中删除时,它也必须从其他服务器中删除。

而且涉及到太多的读写操作。

我们已经看到像Percona XtraDB这样的工具确实有助于确保数据库的高可用性。

为了使数据库始终可用,我们的专门支持工程师在Percona XtraDB集群中进行配置更改,包括以下步骤:

  1. 避免数据库更新冲突
  2. 禁止外部访问
  3. 启用日志进行故障分析

步骤 3. 设置负载均衡器

现在我们已经设置了 WordPress 文件集群和数据库集群,下一步是设置一个系统来平均处理网站请求。

这是负载均衡器提供帮助的地方。它在服务器之间平均分配访问者,有助于避免单个服务器过载。

如果您的网站一次有 1000 个访问者,Load Balancer 会将这些访问者分配到 3 个服务器,每个服务器只需要处理大约 300 个访问者。

根据客户的具体要求,我们部署了负载均衡器,如HAProxy,即使对于流量大的网站,也被认为是高效的。

但是,如果负载均衡器本身出现故障怎么办?整个设置失败。

这就是为什么我们为 Load Balancer 实施一个保持激活的备份服务器。此备份服务器用作负载平衡器的故障转移选项。

因此,使用此设置,访问者将永远不会遇到任何网站运行缓慢或停机的情况。

结论

通过在多台服务器中正确设置 WordPress,可以消除网站因流量过大而宕机的风险。今天,我们看到了我们的支持工程师如何帮助客户实现 WordPress 网站 100% 的正常运行时间。

 点击阅读 如何在多个服务器上安装WordPress分布式部署 原文

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/533069.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

shell脚本之免交互

目录 一 . Here Document 免交互1.1 Here Document概述示例:支持变量替换 二. Expect基本命令: expect直接执行,需要使用 expect 命令去执行脚本嵌入执行模式,将 expect 过程融入 Shell 当中,方便执行和处理。 一 . Here Document…

camunda子流程(Subprocess)如何使用

在 Camunda 中,子流程(Subprocess)是一种可嵌入到主流程中的小型流程,可以用于处理复杂的业务逻辑,以提高流程的可读性和可维护性。使用子流程的好处包括: 1、分离复杂的业务逻辑:通过将复杂的…

一条查询语句在MySQL的处理过程

例如查询语句: select user_id、username from t_user where username "张三" and sex 1; 其在MySQL的执行流程如下: 客户端发起查询请求,与SQL 接口建立连接,SQL 接口确定用户是否有查询权限,没有权限…

TensorFlow详解4-RNN+LSTM(1)

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、背景和知识点深度学习三大模型:RNN的优势: 二、RNN的局限性三、LSTMLSTM三重门机制:LSTM解决梯度消失的主要原理&#x…

Linux--进程信号(pending, block, Handler)集

信号在产生之后,到未被处理的这段时间内,是保存在进程的PCB结构体内的一张位图中的,位图的每个比特位的编号就代表着改信号是否产生,比特位为1表示该信号产生,0表示不存在。 本篇文章就来详细的解答信号在内核中具体的…

数字革命下的产品:百数十年变迁的启示与思考。

随着数字化时代的到来,软件开发成为各行各业不可或缺的一部分。然而,传统的软件开发方法需要长时间的开发周期,高昂的成本和大量的人力资源。因此,低代码开发平台应运而生。低代码开发平台通过简化开发人员的工作和加速软件开发流…

故障分析 | 一条本该记录到慢日志的 SQL 是如何被漏掉的

背景 生产环境中 select count(*) from table 语句执行很慢,已经远超 long_query_time 参数定义的慢查询时间值,但是却没有记录到慢日志中。在测试环境也很容易复现出该问题,慢查询日志确实没有记录 select count(*) 语句。 慢查询相关参数…

数据结构入门-排序

排序的概念及其英语 排序的概念 排序:所谓排序,就是使一串记录,按照其中的某个或某些关键字的大小,递增或递减的顺序排列起来的操作。稳定性:假定在待排序的记录序列中,存在多个具有相同的关键字的记录&a…

【网络】计算机中的网络

目录 🍁计算机网络 🍁计算机网络模型 🍁布线工程 🍁布线系统 🦐博客主页:大虾好吃吗的博客 🦐专栏地址:网络专栏 计算机网络 计算机网络的功能 数据通信、资源共享、增加可靠性、提…

Dubbo——SpringBoot集成Dubbo(@Autowired和@Reference的区别、Dubbo的服务治理)

Dubbo——原生API实现远程调用_Strine的博客-CSDN博客 在上一篇文章中我们讲了如何使用原生API发起远程调用,显然这种方式肯定是非常麻烦的,因此我们这里就讲如何使用SpringBoot去集成Dubbo将这些配置简化。 生产者服务 添加配置文件 dubbo:applicat…

如何安装Maven并在IDEA配置

下载 1.进入官网完成下载,下载好后解压到你喜欢的目录中去即可! Maven – Download Apache Maven 2.解压出来就能看到以下目录结构,我们关注conf目录即可 3.配置Maven的本地仓库,进入conf目录并打开settings.xml,往下…

8.3 综合案例2.0-扫码支付二维码生成

综合案例2.0-扫码支付二维码生成 扫码支付完整流程案例说明1.硬件2.连线图 搭建云平台环境1.添加设备2.创建设备类型3.功能定义(创建物模型) 代码1.更改MQTT信息2.测试 扫码支付完整流程 参考链接微信支付开发者文档 (1)商户后台…

数据分析09——Pandas中的索引设置/排序/数据统计(异常值处理)

1、Pandas中的索引设置: Series重置索引 重置索引:s2 s1.reindex([1, 2, 3, 4, 5]) # 这种情况即使列表中索引给多了也没事,会自动填充空值。重置索引:s3 s1.reindex([1, 2, 3, 4, 5], fill_value0) # 这种情况列表中索引给多了…

从0开始 莫比乌斯函数和反演 学习笔记

莫比乌斯 0 前言 建议先看这篇比较简略的文章(有大概了解) 莫比乌斯函数_为最后的荣光的博客-CSDN博客 再根据个人情况食用本篇博客 1 莫比乌斯函数 1 1 定义 首先对 n n n 唯一分解: 唯一分解: 唯一分解定理一篇就够了_求…

Springboot——根据需求创建后端接口

需求分析: 具体返回如下JSON格式数据 含有四个属性列:id 和 username 和photo 和followerCount 第一步: 首先按照下面文章创建一个模板项目 SpingBoot——SB整合MB的web项目模板_北岭山脚鼠鼠的博客-CSDN博客 第二步: 使用如下的建表语句在一个数据库中新建一个用户表 CREA…

【C++进阶之路】类和对象(下)

文章目录 一.再谈构造函数初始化对象的两种方式1.函数体内赋值2.初始化列表深入理解初始化列表 3.explicit隐式类型转换 二.static成员引言static成员static成员函数练习 三.友元引入友元函数友元类 四.内部类基本概念练习 五 .匿名对象引入匿名对象补充:编译器的优…

一百一十三、DBeaver——从hive同步数据到clickhouse

目标:把hive的DM层结果数据导出到clickhouse数据库,试了kettle、sqoop等多种方法都报错,尤其是kettle,搞了大半天发现还是不行。结果目前就只能用DBeaver同步数据。 准备工作:hive和clickhouse中都建好表 第一步&…

$nextTick与原生js先渲染dom再执行函数的方式

$nextTick与原生js先渲染dom再执行函数的方式 vue的$nextTick 简述 Vue.js 的 $nextTick 方法是用于在 DOM 更新后执行延迟回调的方法。 当 Vue.js 更新 DOM 后,有时候需要执行一些操作(如获取更新后的 DOM 元素的位置等),但是…

2023年美国大学生数学建模竞赛C题预测Wordle的结果解题全过程文档及程序

2023年美国大学生数学建模竞赛 C题 预测Wordle的结果 原题再现: 背景介绍   Wordle是纽约时报目前每天提供的一个流行谜题。玩家通过在六次或更短时间内猜出一个至五个字母的单词来解决这个谜题,每次猜测都会得到反馈。在这个版本中, 每个…

30Wqps+闲鱼优惠中台,如何架构的?

说在前面 在尼恩的(50)读者社群中,经常遇到一个 非常、非常高频的一个面试题,但是很不好回答,类似如下: 千万级数据,如何做系统架构?亿级数据,如何做做系统架构&#xf…