草庐IT

事务处

全部标签

ruby - Ruby Gem 中的 NewRelic 事务跟踪

我正在开发一个Rubygem,我想在其中添加NewRelic监控。该gem在作为守护进程运行并由bluepill监控的脚本中使用。我按照“MonitoringRubybackgroundprocessesanddaemons”开始了。我确认gem正在与NewRelic建立连接,因为该应用程序显示在我的门户中,但是,没有事务跟踪或被调用代码的任何指标分割。这是我的gem的“入口”点,因为我试图围绕调用方法手动启动代理:require'fms/parser/version'require'fms/parser/core'require'fms/parser/env'require'mong

ruby-on-rails - 如何使用 ActiveRecord 连接设置事务隔离级别?

我需要以一种跨数据库(至少是SQLite、PostgreSQL、MySQL)可移植的方式在每个事务的基础上管理事务隔离级别。我知道我可以手动完成,就像那样:User.connection.execute('SETSESSIONTRANSACTIONISOLATIONLEVELSERIALIZABLE')...但我希望是这样的:User.isolation_level(:serializable)do#...end 最佳答案 此功能由ActiveRecord本身支持:MyRecord.transaction(isolation::re

ruby-on-rails - 如何测试某个函数是否使用 Rails 和 rspec 2 中的事务

我有一个模型函数,我想确保它使用事务。例如:classModeldefmethodModel.transactiondo#dostuffendendend我目前的方法是在block内存入一个方法调用以引发ActiveRecord::Rollback异常,然后检查数据库是否真的发生了变化。但这意味着如果由于某种原因block内的实现发生变化,那么测试就会中断。你会如何测试这个? 最佳答案 你应该换个角度看问题。从行为的角度来看,测试函数是否使用事务是没有用的。它不会为您提供有关函数是否按预期运行的任何信息。您应该测试的是行为,即预期结

ruby - 截断、事务和删除数据库策略之间的区别

使用Rspec时截断、事务和删除数据库策略有什么区别?我找不到任何资源来解释这一点。我阅读了DatabaseCleaner自述文件,但它没有解释它们各自的作用。为什么我们必须对capybara使用截断策略?我是否必须在测试时清理我的数据库,或者我可以禁用它。我不明白为什么我应该在每个测试用例之后清理我的数据库,这不会减慢测试速度吗? 最佳答案 数据库清理策略引用数据库术语。IE。这些术语来自(SQL)数据库世界,因此通常熟悉数据库术语的人会知道它们的含义。以下示例引用了SQL定义。DatabaseCleaner也支持其他非SQL类型

javascript - Firebase:异步/等待事务

我正在尝试对事务使用异步/等待。但是出现错误“参数“updateFunction”不是有效函数。”vardocRef=admin.firestore().collection("docs").doc(docId);lettransaction=admin.firestore().runTransaction();letdoc=awaittransaction.get(docRef);if(!doc.exists){throw("docnotfound");}varnewLikes=doc.data().likes+1;awaittransaction.update(docRef,{li

【微服务36】分布式事务Seata源码解析四:图解Seata Client 如何与Seata Server建立连接、通信【云原生】

文章目录一、前言二、概述三、TM事务管理器初始化1、TM初始化流程图2、TM初始化流程1)获取TmNettyRemotingClient实例1>TmNettyRemotingClient实例化2>AbstractNettyRemotingClient实例化2)初始化TmNettyRemotingClient1>注册一些请求处理组件2>初始化AbstractNettyRemotingClient(1)AbstractNettyRemoting初始化(2)启动netty客户端组件Abs

javascript - 在没有 transaction.get() 的情况下启动 firestore 事务

我想将文档从一个集合移动到另一个集合。因此,我想使用事务来1.创建新文档和2.删除旧文档。我可以执行以下操作:db.runTransaction((transaction)=>{returntransaction.get(docRef).then(()=>transaction.set(newDocRef.doc(docId),doc)).then(()=>transaction.delete(docRef));我如何重写此代码以从transaction.set()而不是transaction.get()开始,因为我已经有了这个上下文中的文档,所以它是多余的。区别在于transacti

javascript - 在 firebase 中,为什么事务不像在 admin api 中那样在云函数中工作?

我有现有的管理api代码,为了测试目的我已经将其简化为这个代码(这有效):admin.database().ref('/dropbox').on('child_added',function(childSnap){letitem,itemRef=childSnap.ref;console.log(`Item:${JSON.stringify(childSnap.val())}at${childSnap.key}`);console.log(`Itemref:${itemRef.toString()}`);itemRef.transaction(function(value){conso

javascript - 使用 async/await 提交/回滚 knex 事务

我正在试驾ES7async/awaitproposal使用thismodule模仿它。我正在尝试制作knex.js作为起点,交易与它们配合得很好。示例代码:asyncfunctiontransaction(){returnnewPromise(function(resolve,reject){knex.transaction(function(err,result){if(err){reject(err);}else{resolve(result);}});});}//Starttransactionfromthiscallinsert:async(function(db,data){

javascript - 如何使用 javascript aws-sdk 支持 dynamoDB 中的事务?

我们有一个用node.js编写的微服务,我们使用dynamoDB进行数据存储。值以json格式针对键存储。在更新服务调用中,我们获取一个键的值,更新json并保存它。最近,我们遇到了2个调用想要更新同一个键的值的情况。所以第一次调用读取值,然后第二次调用读取值,第一次调用更新并保存,然后第二次更新并保存值(竞争条件的通常情况),所以在这种情况下,第一次调用的更新没有反射(reflect)在数据库中。为了解决这个问题,我做了一些研究并了解了dynamoDB的事务库。但是好像还没有在node-jssdk中。此外,我搜索了版本控制和乐观锁定,但我再次没有在node-jssdk中找到对此的支持