iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >mongoDB 4.0中怎么实现事务回滚
  • 505
分享到

mongoDB 4.0中怎么实现事务回滚

2024-04-02 19:04:59 505人浏览 泡泡鱼
摘要

本篇文章为大家展示了mongoDB 4.0中怎么实现事务回滚,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1.准备工作升级monGodb至4.0.0$ b

本篇文章为大家展示了mongoDB 4.0中怎么实现事务回滚,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

1.准备工作

升级monGodb至4.0.0

$ brew upgrade mongodb

升级或安装mongodb.js v3.1.0 以上

$ npm i mongodb --save-dev


升级完上述后,db.js里连接mongo时,

会警告,让你在connect的option里加一个字段

useNewUrlParser:true

这时如果有用户验证,还需要在connect的option里再加一个字段

authSource:用户所在的db,一般为admin

否则会报验证失败,找不到用户的错误,比如

 const mongoClient = await MongoClient.connect(mongoClientUrl, {
  auth: {
  user: config.dbUserName,
  passWord: config.dbUserPassword,
  },
  authSource:'admin',
  useNewUrlParser:true,
 });

2.将已有的数据库改造成复制集

目前事务回滚只能在复制集上操作,单独的mongodb server是不能操作事务的

关掉所有的mongod

在平时启动mongod的命令后添加--replSet rs0,比如

$ mongod -dbpath ./db --port 27017 --replSet rs0

再开个shell,创一个不同端口的mongo实例,比如

$ mongod -dbpath ./db_repl --port 27018 --replSet rs0

连接27017的mongo实例,并设置

$ mongo
$ rs.initiate()
$ rs.add('localhost:27018');

完成

3.写回滚代码

在db.js里新增了一个方法

 export const getSession = async function() {
  return await state.mongoClient.startSession();
 };

每次在需要回滚的mongo代码前调用这个方法拿到session,开始回滚的标记

 const session = await db.getSession();
 session.startTransaction({
  readConcern: {level: 'snapshot'},
  writeConcern: {w: 'majority'},
 });

在每次调用mongodb.js的方法操作数据库时,都要带上session,比如

 db
 .collection(this.collecitonName)
 .insertOne(doc,{session});

在你处理错误并觉得需要回滚了,执行

await session.abortTransaction();

在你觉得没问题,一起正常结束时,执行

await session.commitTransaction();

我的代码里可能有一些封装的代码没有放上去,导致不一定能理解。我只是举个栗子去实现,具体的代码实现可以看参考链接1

4.总结

useNewUrlParser这个属性会在url里识别验证用户所需的db,未升级前是不需要指定的,升级到一定要指定,不管是在url后面,还是用authSource

事务回滚只能在复制集上操作,我猜测实现的原理可能是这样:先记录主节点的session,然后回滚的话,通过这个session查找副节点的数据快照,然后将这快照再应用到主节点上,实现回滚。当然,实际情况应该相当复杂,不然mongoDB也不会用3年时间来实现这个操作。

上述内容就是mongoDB 4.0中怎么实现事务回滚,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网数据库频道。

您可能感兴趣的文档:

--结束END--

本文标题: mongoDB 4.0中怎么实现事务回滚

本文链接: https://www.lsjlt.com/news/56577.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • mongoDB 4.0中怎么实现事务回滚
    本篇文章为大家展示了mongoDB 4.0中怎么实现事务回滚,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1.准备工作升级mongodb至4.0.0$ b...
    99+
    2024-04-02
  • MongoDB 4.0 中怎么实现事务
    这篇文章给大家介绍MongoDB 4.0 中怎么实现事务,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。MongoDB 4.0 引入的事务功能,支持多文档ACID特性,例如使用 ...
    99+
    2024-04-02
  • php中mongodb事务回滚怎么实现
    在PHP中,MongoDB并不支持原生的事务处理。但是可以通过编写一些逻辑来模拟事务回滚的功能。以下是一个简单的示例: // 连接M...
    99+
    2024-04-12
    php mongodb
  • jdbc回滚事务怎么实现
    JDBC中回滚事务的实现可以通过以下步骤完成: 首先,确保数据库连接已经开启了事务。可以通过设置连接的自动提交属性为false来实...
    99+
    2023-10-26
    jdbc
  • mongodb事务回滚失败怎么解决
    当 MongoDB 的事务回滚失败时,可能有以下几种解决方法: 检查 MongoDB 版本:首先确保你使用的是 MongoDB ...
    99+
    2023-10-26
    mongodb
  • java手动回滚事务怎么实现
    在 Java 中,我们可以使用 JDBC 中的 Connection 对象来手动回滚事务。下面是一个简单的示例: Connectio...
    99+
    2024-03-07
    java
  • C#在EntityFramework中实现事务回滚
    在使用Entity Framework为主从表添加数据,当一个表添加数据成功,另一个表添加数据失败,这时候就需要用到事务回滚。 比如有以下关系的2张表。 客户端使用Transact...
    99+
    2024-04-02
  • mongodb回滚事务的原理是什么
    MongoDB回滚事务的原理是基于写操作的日志记录和持久化。当执行一个事务时,MongoDB会将所有的写操作记录到一个称为oplog...
    99+
    2023-10-26
    mongodb
  • 怎么在Spring中利用@Transactional实现事务回滚
    今天就跟大家聊聊有关怎么在Spring中利用@Transactional实现事务回滚,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。一、使用场景举例在了解@Transactional怎...
    99+
    2023-05-30
    spring transactional
  • Django事务回滚如何实现
    这篇文章主要介绍“Django事务回滚如何实现”,在日常操作中,相信很多人在Django事务回滚如何实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Django事务回滚如何实现”的疑惑有所帮助!接下来,请跟...
    99+
    2023-07-05
  • Django 事务回滚的具体实现
    目录一、事务的四大特性二、数据库事务2.1使用装饰器(整体回滚,不处理异常)2.2使用with语句(部分回滚,不处理异常)2.3使用with语句(部分回滚,可以处理异常)2.4使用保...
    99+
    2023-02-20
    Django 事务回滚
  • 实现mybatis事务回滚的方法
    今天就跟大家聊聊有关实现mybatis事务回滚的方法,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。解决方法:将DataSource配置改为AutoCommit(false)将conn...
    99+
    2023-06-06
  • spring如何实现事务异常回滚
    这篇文章将为大家详细讲解有关spring如何实现事务异常回滚,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。为了打印清楚日志,很多方法我都加tyrcatch,在catch中打印日志。但是这边情况来了,当这个...
    99+
    2023-05-30
  • 怎么在golang中实现mysql数据库事务的提交与回滚
    这期内容当中小编将会给大家带来有关怎么在golang中实现mysql数据库事务的提交与回滚,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。golang适合做什么golang可以做服务器端开发,但golang...
    99+
    2023-06-14
  • php事务回滚不了怎么办
    本教程操作环境:windows7系统、PHP8.1版、Dell G3电脑。php事务回滚不了怎么办?问题描述:关于php 事务未执行回滚mysqliphptransactions Transactions not doing the rol...
    99+
    2024-04-02
  • Spring事务回滚异常怎么解决
    当Spring事务回滚异常时,可以尝试以下解决方法: 检查代码逻辑:首先检查代码逻辑是否正确,是否在事务范围内执行了可能导致异常...
    99+
    2024-03-01
    Spring
  • SpringBoot数据层测试事务回滚如何实现
    本文小编为大家详细介绍“SpringBoot数据层测试事务回滚如何实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“SpringBoot数据层测试事务回滚如何实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。数...
    99+
    2023-07-04
  • 浅谈MySQL中是如何实现事务提交和回滚的
    目录什么是事务redo logundo log总结一下什么是事务 事务是由数据库中一系列的访问和更新组成的逻辑执行单元 事务的逻辑单元中可以是一条SQL语句,也可以是一段SQL逻辑,...
    99+
    2024-04-02
  • mysql实现事务的提交与回滚的实例详解
    最近要对数据库的数据进行一个定时迁移,为了防止在执行过程sql语句因为某些原因报错而导致数据转移混乱,因此要对我们的脚本加以事务进行控制。 首先我们建一张tran_test表 CREATE TABLE ...
    99+
    2024-04-02
  • SpringBoot数据层测试事务回滚的实现流程
    目录数据层测试事务回滚dao下pojo对象service测试用例数据设定数据层测试事务回滚 pom.xml导入对应的一些坐标,mysql,Mp,等 <dependency>...
    99+
    2022-11-13
    SpringBoot事务回滚 SpringBoot数据层测试事务回滚
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作