- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
正如我们过去所做的那样,我想为每个转向负载平衡的人收集有用的信息,因为您的代码必须注意一些问题。
我们从一台 apache 服务器转移到 squid 作为反向代理/负载均衡器,后面有三台 apache 服务器。
我们使用的是 PHP/MySQL,所以问题可能有所不同。
我们必须解决的问题:
session
我们从“默认”php session (文件)转移到分布式 memcached session 。简单的解决方案,必须完成。这样,您的负载均衡器上也不需要“粘性 session ”。
缓存
对于每个 Web 服务器的非分布式 apc 缓存,我们添加了另一个用于分布式对象缓存的 memcached 层,并用它替换了所有旧的/过时的文件缓存系统。
上传
上传到共享 (nfs) 文件夹。
我们针对速度进行了优化:
静态文件
我们的主要 NFS 运行 lighttpd,提供(也是用户上传的)图像。 Squid 意识到这一点,并且从不查询我们的 apache 节点以获取图像,这极大地提升了性能。 Squid 还配置为将这些文件缓存在 ram 中。
你做了什么让你的代码/项目为负载平衡做好准备,考虑这一举动的人们还有其他问题,以及你使用的是哪种平台/语言?
最佳答案
这样做时:
对于 http 节点,我大力插入单个系统镜像(ocfs2 对此很有用),并根据场景使用 pound 或 crossroads 作为负载平衡器。节点应该有一个小的本地磁盘用于交换并避免大多数(但不是全部)CDSL 的麻烦。
然后我将 Xen 加入其中。如果您在 Xenbus 上放置少量临时信息(即 Linux 实际 promise 为每个 VM 处理的虚拟内存,又名 Committed_AS),您可以快速检测到大脑死负载平衡器并对其进行调整。 Oracle 也意识到了这一点……现在正在努力改进 Linux 中的气球驱动程序。
之后,我查看了在 sqlite3 和应用程序 native 想要的任何数据库之间拆分任何给定应用程序的数据库使用情况的成本,同时意识到我需要拆分数据库以便 posix_fadvise() 可以完成其工作并且不会不必要地污染内核缓冲区。由于大多数 DBMS 服务都希望自己进行缓冲,因此您还必须让它们进行自己的集群。这确实决定了我使用的数据库集群类型以及我对气球驱动程序所做的事情。
Memcache 服务器然后从一个瘦小的 initrd 启动,同时特权域会监视它们的内存和 CPU 使用情况,以便知道何时启动更多。
心跳/接管的选择实际上取决于给定的网络和集群的预期使用情况。很难概括这一点。
最终结果通常是 5 或 6 个物理节点,具有相当多的内存来引导虚拟机监视器 + guest ,同时连接到镜像存储。
存储也很难用一般术语来描述。有时我使用集群 LVM,有时不使用。当 LVM2 最终脱离其当前基于字符串的 API 时,not 将发生变化。
最后,所有这些协调都会产生类似 Augeas 的结果。根据通过 Xenbus 通信的事件动态更新配置。这包括 ocfs2 本身,或任何其他配置不能驻留在单个系统镜像上的服务。
这真的是一个特定于应用程序的问题..你能举个例子吗?我喜欢 memcache,但不是每个人都能从使用它中受益,例如。我们是在审查您的配置还是在谈论一般的最佳实践?
编辑:
抱歉,我如此以 Linux 为中心……它通常是我在设计集群时使用的。
关于language-agnostic - 如何让您的代码为负载平衡做好准备,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/605596/
我一直在试图找出为什么这会给我一个错误: PREPARE test FROM 'SELECT t.blah FROM (SELECT ? AS blah) t;'; ERROR 1054 (42S22
我想了解 Go 中的 channel 。我读过默认情况下发送和接收 block ,直到发送方和接收方都准备好。但是我们如何确定发送方和接收方的准备情况。 例如在下面的代码中 package main
大部分的pytorch入门教程,都是使用torchvision里面的数据进行训练和测试。如果我们是自己的图片数据,又该怎么做呢? 1、我的数据 我在学习的时候,使用的是fashion-mnis
在我的 Storyboard中,controller1 有 natigationController 和 segues 到 controller 2。奇怪的是 Segue 工作正常但是 overrid
我正在尝试使用Openshift在线从我的仓库中放入一些代码。 我的构建编译正常,但是部署失败: error: update acceptor rejected nodejs-mongo-persis
已结束。此问题不符合 Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是无关紧要的,
我有一个每晚运行的存储过程。 它从链接服务器中提取一些数据并将其插入到运行 sql 代理作业的服务器上的表中。在运行 INSERT 语句之前,该过程检查链接服务器上的数据库是否联机 (STATE =
我对 PDO 准备好的语句比较陌生。 我忍不住觉得必须有一种更简单、更整洁的方法来执行以下操作:我无论如何都将所有内容加载到一个数组中,然后必须将整个内容重写为一组 ':blah '=>$found[
我正在准备一个 pandas 数据框,用于在 R 的 ggplot2 中绘制带有误差条的图,这需要计算列的统计数据。误差条需要最小值(平均值 - 标准偏差)和最大值(平均值+标准差)。我使用 grou
我的 prepareForSegue 方法没有将数据传递到目标 View Controller 。 var buttonsDictionary = [Int: UIButton]() func cre
需要帮助来完成这个简单的任务。该 sp 应该提供一个结果集,并将从 MS-Access-Database 报告目的中调用。 表名可变,但以数字 (lsid) 结尾。使用串联。max_prepared_
我正在为我工作的小型企业创建销售订单表单。我有一个表单连接到数据库以获取下拉菜单,然后连接到文本框以在需要时添加新数据。如果前面的部分中的所有数据框均已填写,还会出现另外四个部分。 链接到数据库的
以下代码: class Database { (...) public function query($query){ $this->stmt = $this->dbh
我正在开展一个学校项目,涉及一个具有数据库集成的网站。目前正致力于通过它向网站添加新内容(文本、标题、图像)。我已经可以通过网站向数据库添加新用户,但由于某种原因,相同的代码和逻辑不适用于内容。 我注
我如何mysqli::stmt->bind_param在mysql中被视为NULL的东西? 我目前正在使用 $stmt->bind_param('s', 'NULL'); 最佳答案 bind_para
我在此处运行准备 stmt 时遇到语法错误。我尝试手动执行 @c 中的查询并且它有效。不知道为什么 stmt 会给出这个错误。这是我正在使用的代码。 SET @i=24; SET @Bill_mont
已关闭。这个问题是 not reproducible or was caused by typos 。目前不接受答案。 这个问题是由拼写错误或无法再重现的问题引起的。虽然类似的问题可能是 on-top
我想知道准备好的查询是否与未准备的查询一样安全。下面是两个示例,一个用于 SELECT,一个用于 UPDATE。第一行是未准备的查询,第二行是准备好的查询。 选择示例: $userDetails =
我是 ios 开发的新手,在我尝试做的事情上遇到了障碍。 我的方法中有这段代码,旨在将特定的 NSObject 从这个 View 传递到下一个 View ,但是它总是让我的应用程序崩溃。 -(void
自上次调用 segue 以来,我的 UIButton 类的 statValue 属性已更新,但 segue 仍发送旧的原始值。有没有办法刷新 prepare 函数(如下),以便它发送新值? overr
我是一名优秀的程序员,十分优秀!