冗余和负载平衡
在 CAMServer 的终极计划中、在内部部署环境中非常简单可以进行Web服务器和视频服务器的冗余和负载平衡。这样,即使一台服务器宕机,服务也能继续,即使有大量用户使用,也可以在不降低性能的情况下分散处理并提供服务。
分布式配置 CAMServer
但实时通信是可能的。例如CAMServer1
客户已连接到CAMServer2
您可以与连接到 的另一个客户端聊天或召开网络会议。视频服务器负载平衡是根据活动会议数量和参与用户数量执行的。
同时举行的网络会议的数量很简单CAMServer
这不能通过简单地增加节点数量来实现。还需要考虑网络配置,以便所有会议不会通过同一 VPN 或中心路由器进行中继。
冗余和负载平衡配置
您可以根据您公司的要求级别和成本配置最佳环境。
小型启动配置
- 贮存:将 DB/File 放置在 CAMServer1 端,并从 CAMServer2 引用它。即使在这种情况下,所有用户都可以实时共享数据。
- 备份:每天需要将DB/File数据备份到CAMServer2上。
- 负荷分配:通过将访问的CAMServer按部门划分(或使其成为备用系统),可以进行负载分配。
- 可用性:当发生故障时,网络应用程序版本 如果你使用
cam.clusterHosts.
检测和自动故障转移。如果磁盘出现故障备份已完成保证数据截至前一天。 - 成本: 最便宜的配置。您可以从单个设备配置开始,然后根据负载进行扩展。
外部存储 (NAS) 配置
- 存储:将数据库/文件放置在 RAID 配置中的高度耐用的外部存储 NAS 上,并引用 CAMServer1 和 CAMServer2。
- 备份:即使使用 RAID 配置,也需要每天备份 DB/文件数据,以应对电源/外壳故障和人为故障。
- 负荷分配:与小启动配置相同。
- 可用性:与小启动配置相同。
- 成本:相对便宜的配置。
冗余外部存储配置
- 存储:通过使用冗余文件共享服务器(Windows Server 故障转移集群 +SAN、AWS S3 等)强调针对磁盘故障的高可用性的配置。
- 备份:数据会自动复制,因此根据策略不需要备份。但是,如果您考虑人为故障(例如手动擦除磁盘),您仍然需要备份。
- 负荷分配:与小启动配置相同。
- 可用性:web服务器与小启动配置相同。即使由于磁盘或外壳故障而发生故障,也可以进行自动切换。
- 成本: 引进成本高。 AWS S3 可以以低成本构建,但如果您的重点是本地,那么它不是一个选择。
负载平衡器配置
- 存储:小型启动配置/NAS/SAN可选。
- 备份:与小型启动配置/NAS/SAN 相同。
- 负荷分配:通过将负载均衡器放置在CAMServer之前,可以实现冗余和负载分配。附注(补充信息) 文号 负载均衡器配置要求详细信息还请检查。
- 可用性:与冗余外部存储配置结合使用时,所有层都可以进行自动故障转移。
- 成本: 引进成本高。
冗余和负载平衡设置
每个分布式服务器上的通用设置
为使 CAMServer 冗余和负载平衡,请在每个分布式服务器上安装一个 CAMServer、CAMServer/cam.ini
在文件中添加以下条目。
cam.clusterHosts=camserver1;camserver2
cam.clusterHostsDesc=camserver1 がメインサーバ、camserver2 は待機系サーバです。
cam.serverDatePath=\\disk\CAMServer\data
cam.enabledSingleProcessingHost=camserver1
cam.clusterHosts.
cam.clusterHosts.
是每个分布式服务器的主机名。 ;
主机名以"...... "分隔并枚举。可以在客户端使用 https://ホスト名/
它必须可以通过以下方式访问
cam.clusterHosts=camserver1;camserver2
如果您想为每个部门单独设置 CAMServer,请在每个 CAMServer 的 ini 文件的开头写入主机名。启动时选择初始连接服务器和视频服务器时,枚举顺序会受到影响。还网络应用程序版本 通过使用 ,在发生故障时可以进行故障转移连接。
cam.clusterHostsDesc.
cam.clusterHostsDesc.
可以更改分布式服务器描述字段中的注释。
cam.serverDatePath.
cam.serverDatePath.
指定数据库,即存储上传附件的位置。指定可从分布式服务器访问的共享磁盘(如 NAS)。
如果没有共享磁盘,子 CAMServer 可用作主 CAMServer 的 CAMServer/config
还可以通过指定文件夹共享存储空间。
cam.enabledSingleProcessingHost
cam.enabledSingleProcessingHost
指定在 cam.clusterHosts 中枚举的第一台服务器的主机名。对于只能在单个主机上运行的进程(如批处理),在执行前应先设置此项以确定主机是否已在 cam.enabledSingleProcessingHost 中定义。
只配置子服务器。
cam.disableLANNetwork=true
以禁用局域网的 TCP/UDP 连接;第二个及以后的子 CAMServer 也应如此配置。
cam.disableLANNetwork=true
负载均衡器要求详细信息
我们将详细描述负载均衡器配置所需的要求。
1. SSL 终止
- 在负载均衡器上安装 SSL 证书并执行 SSL/TLS 解密。
- 使用 HTTPS 接受来自客户端的通信,从负载均衡器到后端使用 HTTP。
2.负载均衡算法
- 使用循环法进行负载平衡
- 需要基于cookie的会话维护(会话亲和性),并且需要确认其具有将同一Client的访问分发到同一节点的功能。
3. 标头和附加处理传输到后端服务器(8080)
X-转发-原型
LB转发到后端服务器时将请求标识为https的标头项
X-转发-For
LB转发给后端服务器时标识客户端IP地址的头项。
处理 WebSocket 升级标头
分析HTTP请求并检测Upgrade标头,触发TCP切换
4. 与后端服务器通信
从负载均衡器到每个 CAMServer 的通信是使用以下协议和端口执行的。
- 协议:HTTP
- 端口号:8080
- 连接示例:http://HOSTNAME:8080/
5. 健康检查
- 负载均衡器定期请求以下 URL,如果满足条件,则确定其“正常”。
- 健康检查网址:http://HOSTNAME:8080/CAMServer/healthcheck
- 健康检查条件: HTTP 状态码:200 响应正文:{“status”:200}
6、服务器间数据同步的通信权限
- 实时数据更新(用户状态、消息、聊天室等)在 CAMServer 之间同步,因此需要使用防火墙等允许服务器之间的通信。
- 服务器到服务器的连接 URL 在 ini 文件的 cam.clusterHosts 中定义。
- 示例)cam.clusterHosts=camserver1:8080;camserver2:8080;camserver3:8080
*如果camserver1上的用户信息已更新,请连接到以下URL并同步数据。
http://camserver2:8080/CAMServer/syncWebSocketData
http://camserver3:8080/CAMServer/syncWebSocketData