SpringDataMongoDB多文檔事務(wù)的實現(xiàn)
一、安裝MongoDB4.0.3(××)
1.1、官方安裝文檔
https://docs.mongodb.com/manual/tutorial/install-mongodb-on-red-hat/
1.2、tar.gz包下載地址
https://www.mongodb.com/download-center/community?jmp=docs
1.3、復(fù)制集官方配置
https://docs.mongodb.com/manual/administration/replica-set-member-configuration/
二、SpringProject版本依賴(×)
Spring:5.1.1.RELEASE 以上
SpringDataMongoDB:2.1.1.RELEASE 以上
三、配置MongoTransactionManager(SpringBoot使用方式)
SpringBoot 集成非常簡單,配置MongoTransastionManager,目前Spring-boot-starter-data-mongodb 版本較低不支持,因此暫未驗證,SpringBoot配置復(fù)制集參考SpringBoot相關(guān)文檔
@Configuration static class Config extends AbstractMongoConfiguration { @Bean MongoTransactionManager transactionManager(MongoDbFactory dbFactory) { return new MongoTransactionManager(dbFactory); } // ... }
四、配置MongoTransactionManager(普通Spring項目)
<context:property-placeholder location="classpath:mongo.properties" ignore-unresolvable="true" file-encoding="utf-8" /> <!-- 重點配置 1.安全配置:credentials="${mongo.user}:${mongo.password}@${mongo.database}" 2.單機配置:host="${mongo.host}" port="${mongo.port}" 3.副本集配置:replica-set="${mongo.replSet}" --> <mongo:mongo-client id="mongoClient" replica-set="${mongo.replSet}"> <mongo:client-options min-connections-per-host="${mongo.minConnectionsPerHost}" write-concern="SAFE" read-preference="NEAREST" threads-allowed-to-block-for-connection-multiplier="${mongo.threadsAllowedToBlockForConnectionMultiplier}" connect-timeout="${mongo.connectTimeout}" max-wait-time="${mongo.maxWaitTime}" socket-keep-alive="${mongo.socketKeepAlive}" socket-timeout="${mongo.socketTimeout}" max-connection-idle-time="${mongo.maxConnectionIdleTime}" max-connection-life-time="${mongo.maxConnectionLifeTime}" heartbeat-socket-timeout="${mongo.heartbeatSocketTimeout}" heartbeat-connect-timeout="${mongo.heartbeatConnectTimeout}" min-heartbeat-frequency="${mongo.minHeartbeatFrequency}" heartbeat-frequency="${mongo.heartbeatFrequency}" /> </mongo:mongo-client> <mongo:db-factory id="mongoDbFactory" dbname="${mongo.database}" mongo-ref="mongoClient" /> <bean id="mappingContext" class="org.springframework.data.mongodb.core.mapping.MongoMappingContext" /> <bean id="defaultMongoTypeMapper" class="org.springframework.data.mongodb.core.convert.DefaultMongoTypeMapper"> <constructor-arg name="typeKey"> <null /> </constructor-arg> </bean> <bean id="mappingMongoConverter" class="org.springframework.data.mongodb.core.convert.MappingMongoConverter"> <constructor-arg name="mongoDbFactory" ref="mongoDbFactory" /> <constructor-arg name="mappingContext" ref="mappingContext" /> <property name="typeMapper" ref="defaultMongoTypeMapper" /> </bean> <bean id="mongoTemplate" class="org.springframework.data.mongodb.core.MongoTemplate"> <constructor-arg name="mongoDbFactory" ref="mongoDbFactory" /> <constructor-arg name="mongoConverter" ref="mappingMongoConverter" /> </bean> <!-- 重點配置 --> <bean id="mongoTransactionManager" class="org.springframework.data.mongodb.MongoTransactionManager"> <constructor-arg name="dbFactory" ref="mongoDbFactory"/> </bean> <tx:annotation-driven transaction-manager="mongoTransactionManager" proxy-target-class="true"/>
五、使用事務(wù)(×)
@Service public class StateService { @Autowired private MongoTemplate teplate; @Transactional void someBusinessFunction(Step step) { template.insert(step); log.debug(1/0); }; });
六、Mongo.properties 配置
mongo.host=192.168.1.66 mongo.port=27017 mongo.replSet=192.168.1.66:2000,192.168.1.66:2001,192.168.1.66:2002 mongo.minConnectionsPerHost=10 mongo.threadsAllowedToBlockForConnectionMultiplier=4 mongo.connectTimeout=30000 mongo.maxWaitTime=3000 mongo.socketKeepAlive=false mongo.socketTimeout=30000 mongo.maxConnectionIdleTime=0 mongo.maxConnectionLifeTime=0 mongo.heartbeatSocketTimeout=20000 mongo.heartbeatConnectTimeout=10000 mongo.minHeartbeatFrequency=3000 mongo.heartbeatFrequency=5000 mongo.database=labsta
七、最后是重點(×××××)
7.1、必須使用復(fù)制集,單節(jié)點不支持,mongodb4.2 會支持分片集事務(wù),復(fù)制集安裝請自行研究
7.2、使用事務(wù)之前(@Transaction),數(shù)據(jù)庫和文檔必須提前創(chuàng)建,如何解決呢?且看下篇
7.3、Spring版本和SpringDataMongodb版本必須遵循 @SpringProject版本依賴
7.4、注意,此處的復(fù)制集不是4.0版本之前的主從復(fù)制集群,4.0之后已廢棄主從模式
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- SpringBoot?整合mongoDB并自定義連接池的示例代碼
- SpringBoot中使用MongoDB的連接池配置
- springboot配置mongodb連接池的方法步驟
- Spring Boot中使用MongoDB的連接池配置的方法
- java實現(xiàn)mongodb的數(shù)據(jù)庫連接池
- mongoDB 4.0事務(wù)回滾的辛酸歷程探究
- MongoDB中唯一索引(Unique)的那些事
- MongoDB索引使用詳解
- MongoDB的基礎(chǔ)查詢和索引操作方法總結(jié)
- pymongo給mongodb創(chuàng)建索引的簡單實現(xiàn)方法
- 深入理解MongoDB的復(fù)合索引
- MongoDB中連接池、索引、事務(wù)
相關(guān)文章
java 父類子類有同名方法時如何調(diào)用的實現(xiàn)
這篇文章主要介紹了java 父類子類有同名方法時如何調(diào)用的實現(xiàn),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09Quartz定時任務(wù)管理方式(動態(tài)添加、停止、恢復(fù)、刪除定時任務(wù))
這篇文章主要介紹了Quartz定時任務(wù)管理方式(動態(tài)添加、停止、恢復(fù)、刪除定時任務(wù)),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-12-12Struts2開發(fā) 基本配置與類型轉(zhuǎn)換
本篇文章,小編將為大家介紹關(guān)于Struts2開發(fā) 基本配置與類型轉(zhuǎn)換,有需要的朋友可以參考一下2013-04-04深入淺出理解Java Lambda表達式之四大核心函數(shù)式的用法與范例
Lambda 表達式,也可稱為閉包,它是推動 Java 8 發(fā)布的最重要新特性。Lambda 允許把函數(shù)作為一個方法的參數(shù)(函數(shù)作為參數(shù)傳遞進方法中)。使用 Lambda 表達式可以使代碼變的更加簡潔緊湊,今天小編帶你理解Lambda表達式之四大核心函數(shù)式的用法,感興趣的朋友快來看看吧2021-11-11spring?IOC容器管理必須知道的一些操作(基于XML方式)
Spring框架的核心是Spring容器,容器創(chuàng)建對象,將它們裝配在一起,配置它們并管理它們的完整生命周期,下面這篇文章主要給大家介紹了關(guān)于spring?IOC容器管理必須知道的一些操作,需要的朋友可以參考下2022-03-03Java獲取本機IP地址的方法代碼示例(內(nèi)網(wǎng)、公網(wǎng))
在IT領(lǐng)域獲取本機IP地址是一項基礎(chǔ)但重要的任務(wù),特別是在網(wǎng)絡(luò)編程、遠程協(xié)作和設(shè)備通信中,這篇文章主要給大家介紹了關(guān)于Java獲取本機IP地址的方法(內(nèi)網(wǎng)、公網(wǎng)),需要的朋友可以參考下2024-07-07