当前位置: 首页 > news >正文

本是同根生-双数据库集群keepalived virtual_route_id冲突导致连接故障

项目场景:

一企业近期陆续开始升级办公与大数据系统,新的承包商。原有的数据库是某国内大品牌A,现在新的功能准备陆续迁移到大品牌B上。系统部署后,A依旧承担比较轻松的财务、仓库管理,B承担实时的线上业务。项目验收阶段,测试工程师发现A\B的数据录入后端日志有大量的IO超时错误,且效率低下。

先后把A厂运维、B厂运维喊过来解决,均无功而返。完全相同的配置和环境,在各自的厂内测试都是好的,搬过来就废了。


问题描述

数据传输过程中,TCP长连接终端频繁报错:

SocketTimeOutException: Read timed out
An I/O error occurred while sending to the backend.

原因分析:

此问题是在 keepalived 的 virtual_router_id 冲突导致的。 但局域网中是不同的数据库啊,怎么会冲突呢?查看后发现,A数据库、B数据库竟然底层都是 postgresql的分支,且发行版的 keepalived.conf中,virtual_router_id 都是默认值。

这个ID同一个集群要一致,集群之间要不同。否则,局域网网段内就会发生冲突。


解决方案:

临时方案:使用NAT代理,把数据库A映射到另一个网段。
永久方案:数据库A/B运维修改virtual_router_id。

http://www.lryc.cn/news/156544.html

相关文章:

  • 『力扣每日一题06』字符串中的第一个唯一字符
  • selenium鼠标操作方法
  • 医者无疆 | AI赋能大医精诚,医疗制药的进阶与突破
  • 使用 Hue 玩转 Amazon EMR(SparkSQL, Phoenix) 和 Amazon Redshift
  • Unity中神秘的Transform和transform(小写)的关系
  • 【LeetCode-中等题】78. 子集
  • 学习设计模式之代理模式,但是宝可梦
  • 自学Python01-创建文件写入内容
  • Qt —UDP通信QUdpSocket 简介 +案例
  • 五大类注解和方法注解详解
  • 机器人中的数值优化(十)——线性共轭梯度法
  • 数据结构与算法之贪心动态规划
  • 【网络编程】网络基础概念
  • 连接虚拟机报错 Could not connect to ‘192.168.xxx.xxx‘ (port 22): Connection failed.
  • 数学建模--Topsis评价方法的Python实现
  • 超越时间与人力的软件开发智慧:《人月神话》
  • Java Stream 流对象(实用技巧)
  • 【用unity实现100个游戏之8】用Unity制作一个炸弹人游戏
  • 简易版人脸识别qt opencv
  • 如何系统地学习 JavaScript?
  • 对称二叉树(Leetcode 101)
  • 动手学深度学习(2)-3.5 图像分类数据集
  • C标准输入与标准输出——stdin,stdout
  • 如何将home目录空间扩充到根目录下
  • Ceph PG Peering数据修复
  • 服务器上使用screen和linux的基本操作
  • Kafka3.0.0版本——文件存储机制
  • Linux如何安装MySQL
  • 确保网络的安全技术介绍
  • 机器学习练习