- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
快照隔离功能帮助我们解决了高容量站点上读者锁定作者的问题。它通过在 SqlServer 中使用 tempdb 对行进行版本控制来实现这一点。
我的问题是如何正确实现此快照隔离功能,是否只需在我的 SqlServer 上执行以下操作即可
ALTER DATABASE MyDatabase
SET ALLOW_SNAPSHOT_ISOLATION ON
ALTER DATABASE MyDatabase
SET READ_COMMITTED_SNAPSHOT ON
我是否还必须编写包含 TransactionScope 的代码,例如
using (new TransactionScope(TransactionScopeOption.Required,
new TransactionOptions { IsolationLevel = IsolationLevel.SnapShot}))
最后,布伦特在 this post 中指出了他的担忧在“并发的隐藏成本”部分中,他提到当您对 tempdb 中的行进行版本控制时,tempdb 可能会耗尽空间,并且可能会出现性能问题,因为它必须查找版本控制的行。所以我的问题是我知道这个网站使用快照隔离,其他人在大型网站上使用此功能,您对性能有何看法?
谢谢,雷。
最佳答案
这“只是执行以下操作的问题”,如 https://msdn.microsoft.com/en-us/library/tcbchxcb(v=vs.110).aspx 中所述。 ,“如果 READ_COMMITTED_SNAPSHOT 选项设置为 OFF,则必须显式设置每个 session 的快照隔离级别才能访问版本控制的行。”您的第二个 ALTER DATABASE 命令将 READ_COMMITTED_SNAPSHOT 设置为 ON,因此代码不需要指定该 TransactionScope。
每当人们寻求关于性能“足够”与“不足”的意见时,性能硬币有两个方面:要么“供应”平淡,要么“需求”压倒性......对于这篇文章,“供应” “”可以指 tempdb 使用的性能和空间,而“需求”可能涉及对 tempdb 进行写入的速率。在供应方面,可以使用各种硬件(从单轴 5400 RPM 磁盘到 SSD 阵列)。在需求方面,这不是 SQL Server 问题(尽管未能正确规范化数据库设计可能是一个因素),而是客户端代码问题。
My SQL Server 看到客户端同时要求大约 50 次写入/分钟和 2000 批/分钟,其中写入通常在 OTLP/短边。我的每个 SQL Server 有 1 TB 的数据库和 30 GB 的 tempdb。所有数据库通常都标准化为第三范式。所有数据库都在 SSD 上运行。我不担心 tempdb 磁盘的 IO 吞吐量会被超出。因此,我并不担心在我的系统上启用快照隔离。但是,我见过其他系统尝试启用快照隔离,但很快就放弃了。
您的系统的体验可能与任何其他受访者的系统存在几个数量级的差异。您应该寻求分析/可靠地重放系统的写入,以及重放 tempdb 的其他使用(包括排序),以便为您自己的系统得出您自己的结论(对于具有足够空间用于系统结果的各种硬件)临时数据库大小)。负载测试不应该是事后的想法:)。您还应该对 tempdb 磁盘的 IO 吞吐量进行基准测试 - 请参阅 https://technet.microsoft.com/library/Cc966412 ,如果IO吞吐能力不够,就要做好花更多钱的准备。
关于sql-server - 如何正确实现快照隔离和tempdb问题?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/652378/
Maven – 快照 大型软件应用程序通常由多个模块组成,这是多个团队工作于同一应用程序的不同模块的常见场景。例如一个团队工作负责应用程序的前端应用用户接口工程(app-ui.jar:1.0)),同
我的 ES 快照不起作用或看起来是空的。 首先,我在我的 Ubuntu 服务器上做了这个: 1.创建备份目录 mkdir /home/admin/dumps/elasticsearch 2. 将此目录
您好,我想将折线图保存为预定义尺寸 (x, y) 的图像。有没有简单的方法来做到这一点?我找不到任何合适的 Snapshot 参数。 WritableImage image = lineCha
我将 Genymotion 与 Oracle VirtualBox 一起使用,但是我有 250 GB 的 SSD,并且我遇到了(快照)问题 我在这里搜索并搜索,我找不到任何可能的方法来禁用自动快照,因
我们想使用 Grafana 来显示测量数据。现在,我们的测量设置创建了大量数据并保存在文件中。我们按原样保留文件,并直接使用 Spark(“数据湖”方法)对其进行后处理。 我们现在想要创建一些可视化,
我不知道如何制作节点组的快照。也就是说,我想制作一个覆盖有数字的 PNG 图标图像(例如未读消息)。 我的代码: int totalNumberOfUnreadMessages = 1; ImageV
我们想使用 Grafana 来显示测量数据。现在,我们的测量设置创建了大量数据并保存在文件中。我们按原样保留文件,并直接使用 Spark(“数据湖”方法)对其进行后处理。 我们现在想要创建一些可视化,
这个问题在这里已经有了答案: How do I return the response from an asynchronous call? (41 个回答) 关闭 4 年前。 function i
我试图在运行我的程序时保存所有内容。我想保存每个游戏对象及其脚本和变量。我知道可以序列化所有内容并将其保存为 XML(以及其他方式/格式,如 JSON)。这将需要大量的工作和时间。该程序将来可能会发生
我正在玩 Screeps ( http://screeps.com/ ) 模拟房间模式。我已经测试了一些东西,我不想失去我的进步。 我可以在模拟房间模式下拍摄快照并保存我的房间状态,这样我就不必从头开
我的应用程序的测试人员报告:“最近的应用程序列表中的应用程序缩略图根本没有调整。在我看来,它要么像主屏幕壁纸(tolikdru:可能,只是透明的矩形),要么像应用程序屏幕的绿色背景,但从来没有真正的应
这个问题在这里已经有了答案: JavaFX I want to save Chart-Image completely (1 个回答) 关闭 3 年前。 我正在尝试获取“Java 弹出窗口”的快照。
我正在使用 pymongo 从 MongoDB 中插入和检索数据。这两个操作可以同时执行。问题是我什么时候做 rows = db..find()在pymongo中,每次rows.count()返回不同
如何获取通过 选择的视频文件的快照在视频中的特定时间在后台静默(即没有可见元素、闪烁、声音等)? 最佳答案 主要有四个步骤: 创建 和 元素。 加载src URL.createObjectURL 生
您好,我正在使用 JavaFx WebView 创建 HTML 页面的屏幕截图,它工作正常,但我想知道是否可以在不在图形窗口中启动应用程序的情况下执行此操作!!我的意思是没有比这更轻量级的方法来获取屏
所以我有一个 horizontalscrollview,我想尝试添加一个对齐效果,它基本上使元素居中。到目前为止,我基本上都是用 XML 完成的。 然后我在里面有一个 LinearLayout。
调用 URL http:///gitweb.cgi?p=;a=tree;f=;hb=HEAD将显示 的树从 开始. 调用 URL http:///gitweb.cgi?p=;a=snapshot;
我们知道,Maven 项目第一次构建时,会自动从远程仓库搜索依赖项,并将其下载到本地仓库中。当项目再进行构建时,会直接从本地仓库搜索依赖项并引用,而不会再次向远程仓库获取。这样的设计能够避免项目每次构
这个问题在这里已经有了答案: Freeze screen in chrome debugger / DevTools panel for popover inspection? (9 个回答) 关闭
我正在开发一个向 DVR 和 IP 摄像机请求快照的应用程序。我正在开发的设备只提供 RTSP 请求。然后我实现了必要的 RTSP 方法来开始接收流数据包,然后通过建立的 UDP 连接开始接收。我的疑
我是一名优秀的程序员,十分优秀!