- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 erlang 应用程序,目前在四个节点上运行,并带有一个复制的 mnesia 数据库,该数据库存储有关连接客户端的最少数据。 mnesia 复制过去一直在无缝工作(据我所知),但最近一位客户注意到其中一个节点缺少与他的应用程序相关的一些 id。
我不太确定这是怎么发生的。我们的网络当时可能出现了问题。也许?但是,目前更紧迫的是让所有节点的数据都处于良好状态。有没有办法告诉 mnesia 从已知良好的节点复制?
最佳答案
Mnesia 在这个问题上很有传奇色彩。这是一个巨大的皮塔饼。
从 CAP 定理的角度来看,大多数使用 Mnesia 构建的系统最终都是 C-A(无分区容错的一致性可用性)系统。在大多数情况下,您拥有(并严重依赖)它的硬一致性。然后发生网络分区...
它仍然可用于写入,但这些写入破坏了一致性。后来,Mnesia 没有自动数据修复的机制。
每个在集群中使用 Mnesia 的人都应该熟悉这些权衡。你的问题清楚地表明使用 Mnesia 是一个糟糕的选择。如果此数据对您至关重要,请加倍。
我也以这种方式使用 Mnesia(有时我们都需要速度,你知道)。但我确保只使用它来存储我可以轻松重建的数据。一般来说,如果你需要将它存储在磁盘上,Mnesia 是没有用的,除了玩具项目。
我确保手头有这个功能:
reinit_mnesia_cluster() ->
rpc:multicall(mnesia, stop, []),
AllNodes = [node() | nodes()],
mnesia:delete_schema(AllNodes),
mnesia:create_schema(AllNodes),
rpc:multicall(mnesia, start, []).
关于erlang - 一个复制的 mnesia 表变得不同步,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19945609/
我在 android 代码中使用 asmack XMPP。我可以正常登录 XMPP 服务器,但是当我尝试创建新用户时出现问题。我想要实现的是: 以管理员身份登录。 创建一个新用户。 从管理员注销。 以
这是我的标记页面,其中有一个按钮可以从数据库中搜索数据并显示在网格中 这是我背后的代码 if (!IsPostBack) { LblInfo.Text = "Page Load
当我多次将相同的 float 值插入到我的集合中时,本应花费恒定时间的 x in s 检查变得非常慢。为什么? 时序x in s的输出: 0.06 microseconds 0.09 mi
我有一个小型聊天客户端,可以将所有历史记录存储在 sqlite 数据库中。当用户单击我的应用程序中的 history 选项卡时,我的应用程序会获取所有相关历史记录并将其显示在 QWebView 中。我
我是一名优秀的程序员,十分优秀!