Spring+iBatis+Atomikos实现JTA事务

Spring+iBatis+Atomikos实现JTA事务

Atomikos TransactionsEssentials 是一个可靠的库,可以加入到您的Java应用程序,也就是说为了使用这个产品,您必须添加一些jar文件(包括在dist和lib文件夹下)到您的应用程序或者应用程序服务器。  起因:  
小项目,没有用分布式,但要操作两个数据库。本以为随便用spring配置两个数据源就搞定,查询是没问题,问题是有一个数据库老是插不进数据。Google狂搜之后,大概了解到是事务控制的问题。我用的是spring的声明式事务管理(<tx:annotation-driven/>)。用一般的数据源配置,只有一个数据源的事务生效,其它数据源只能读不能写。  

有帖子说,要支持多数据源的事务,只能用JTA事务管理(没用过 -_-||),而且应用服务器还不能是Tomcat(一直在用tomcat,不想换-_-!!),头疼了。幸亏后面还有说,有第三方的实现支持JTA事务管理,一是JOTM,一是Atomikos。只要用了其中一个,还能继续用Tomcat。因为名字短,先考虑用JOTM。到官网一看,最后更新日期是2010年。。呃。。转向Atomikos。在Atomikos的官网看看文档,看看例子,边做边调试,一个下午下来,总算有点成果,高兴之余做个记录。其中会涉及到一些概念,比如分布式事务、JTA、XA,我都有搜来了解一下,因理解肤浅没法做记录。下面只是记录

Atomikos TransactionsEssentials 是一个为Java平台提供增值服务的并且开源类事务管理器,以下是包括在这个开源版本中的一些功能:

l  全面崩溃 / 重启恢复

l  兼容标准的SUN公司JTA API

l  嵌套事务

l  为XA和非XA提供内置的JDBC适配器

注释:XA:XA协议由Tuxedo首先提出的,并交给X/Open组织,作为资源管理器(数据库)与事务管理器的接口标准。目前,Oracle、Informix、DB2和Sybase等各大数据库厂家都提供对XA的支持。XA协议采用两阶段提交方式来管理分布式事务。XA接口提供资源管理器与事务管理器之间进行通信的标准接口。XA协议包括两套函数,以xa_开头的及以ax_开头的。

以下的函数使事务管理器可以对资源管理器进行的操作:

1)xa_open,xa_close:建立和关闭与资源管理器的连接。

2)xa_start,xa_end:开始和结束一个本地事务。

3)xa_prepare,xa_commit,xa_rollback:预提交、提交和回滚一个本地事务。

4)xa_recover:回滚一个已进行预提交的事务。

5)ax_开头的函数使资源管理器可以动态地在事务管理器中进行注册,并可以对XID(TRANSACTION IDS)进行操作。

6)ax_reg,ax_unreg;允许一个资源管理器在一个TMS(TRANSACTION MANAGER SERVER)中动态注册或撤消注册。

l  内置的JMS适配器XA-capable JMS队列连接器

注释:JMS:jms即(Java Message Service)接口是一个中关于面向(MOM)的API,用于在两个应用程序之间,或中发送消息,进行异步通信。Java消息服务是一个与具体平台无关的API,绝大多数MOM提供对JMS提供支持。

l  通过XA API兼容第三方适配器

l  更好的整合您的项目

l  集成Hibernate   atomikos配合spring的使用方法:  

1、依赖包  
Atomikos的:  
transactions-jdbc  
transactions-jta  
transactions-api  
transactions  
atomikos-utils  
还有一个不要忘了,是jta的包。  
用maven要简单一点,只需要加入两个依赖:  
      Xml代码

  1. <dependency>
  2. <groupId>com.atomikos</groupId>
  3. <artifactId>transactions-jdbc</artifactId>
  4. <version>3.7.0</version>
  5. </dependency>
  6. <dependency>
  7. <groupId>javax.transaction</groupId>
  8. <artifactId>jta</artifactId>
  9. <version>1.1</version>
  10. </dependency>    

    2、配置数据源  
        这一步是比较重要的。要用AtomikosDataSourceBean,而不是以前用的连接池如dbcp。最好也用XA(这东西我还不太懂),注意jdbc的链接地址和登陆账号与普通连接池的配置的格式不一样。下面是一个mysql数据库的配置举例:  
          Xml代码
  11. <bean id="dataSource1" class="com.atomikos.jdbc.AtomikosDataSourceBean" init-method="init" destroy-method="close">
  12. <property name="uniqueResourceName" value="ds1"/>
  13. <property name="xaDataSourceClassName" value="com.mysql.jdbc.jdbc2.optional.MysqlXADataSource"/>
  14. <property name="xaProperties">
  15. <props>
  16. <prop key="url">jdbc:mysql://localhost/test</prop>
  17. <prop key="user">test</prop>
  18. <prop key="password">test</prop>
  19. </props>
  20. </property>
  21. <property name="minPoolSize" value="10" />
  22. <property name="maxPoolSize" value="100" />
  23. <property name="borrowConnectionTimeout" value="30" />
  24. <property name="testQuery" value="select 1" />
  25. <property name="maintenanceInterval" value="60" />
  26. </bean>    
    再来一个sybase的配置举例:  
          Xml代码
  27. <bean id="dataSource2" class="com.atomikos.jdbc.AtomikosDataSourceBean" init-method="init" destroy-method="close">
  28. <property name="uniqueResourceName" value="ds2"/>
  29. <property name="xaDataSourceClassName" value="com.sybase.jdbc3.jdbc.SybXADataSource"/>
  30. <property name="xaProperties">
  31. <props>
  32. <prop key="serverName">192.168.1.10</prop>
  33. <prop key="portNumber">2638</prop>
  34. <prop key="databaseName">test</prop>
  35. <prop key="user">test</prop>
  36. <prop key="password">test</prop>
  37. </props>
  38. </property>
  39. <property name="minPoolSize" value="10" />
  40. <property name="maxPoolSize" value="100" />
  41. <property name="borrowConnectionTimeout" value="30" />
  42. <property name="testQuery" value="select 1" />
  43. <property name="maintenanceInterval" value="60" />
  44. </bean>    

    3、使用数据源  
        这一步与平时好像没什么不一样。我做例子的时候是用mybatis,配置如下:  
          Xml代码
  45. <bean id="sqlSessionFactory1" class="org.mybatis.spring.SqlSessionFactoryBean">
  46. <property name="dataSource" ref="dataSource1"/>
  47. </bean>
  48. <bean id="sqlSessionFactory2" class="org.mybatis.spring.SqlSessionFactoryBean">
  49. <property name="dataSource" ref="dataSource2"/>
  50. </bean>    
    当然,mybatis还要配置一下映射文件的自动扫描,这里与atomikos无关:  
          Xml代码
  51. <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
  52. <property name="basePackage" value="xx.xx;" />
  53. <property name="sqlSessionFactory" ref="sqlSessionFactory1"/>
  54. </bean>
  55. <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
  56. <property name="basePackage" value="yy.yy;" />
  57. <property name="sqlSessionFactory" ref="sqlSessionFactory2"/>
  58. </bean>    
    用spring JdbcTemplate应该与普通使用没什么不同,用hibernate可能会有点不一样,没测试过。  

    4、配置jta事务管理  
        这是很关键的一步。原理我不太懂,例子如下:  
          Xml代码
  59. <bean id="transactionManager" class="org.springframework.transaction.jta.JtaTransactionManager">
  60. <property name="transactionManager">
  61. <bean class="com.atomikos.icatch.jta.UserTransactionManager" init-method="init" destroy-method="close">
  62. <property name="forceShutdown" value="true"/>
  63. </bean>
  64. </property>
  65. <property name="userTransaction">
  66. <bean class="com.atomikos.icatch.jta.UserTransactionImp"/>
  67. </property>
  68. </bean>    
    当然,用spring的声明式事务配置,再加上一行:  
          Xml代码
  69. <tx:annotation-driven/>    
    (注意,本来要配置transaction-manager属性,如:<tx:annotation-driven  transaction-manager="transactionManager" />。这里没有配置是因为它的默认值是transactionManager)  

    5、atomikos的配置文件jta.properties  
        这个文件一般放在根路径吧,与log4j.properties类似。jta.properties也可命名为transactions.properties。如果不配置这个文件,项目也能启动,因为几乎所有配置项都有默认值。最好还是配置了,详细配置信息请查看:http://www.atomikos.com/Documentation/JtaProperties。  

    6、不管是用JdbcTemplate、mybatis还是hibernate,应该都可以写代码来测试了。。。

Read more

60个“特征工程”计算函数(Python代码)

60个“特征工程”计算函数(Python代码)

转自:coggle数据科学 近期一些朋友询问我关于如何做特征工程的问题,有没有什么适合初学者的有效操作。 特征工程的问题往往需要具体问题具体分析,当然也有一些暴力的策略,可以在竞赛初赛前期可以带来较大提升,而很多竞赛往往依赖这些信息就可以拿到非常好的效果,剩余的则需要结合业务逻辑以及很多其他的技巧,此处我们将平时用得最多的聚合操作罗列在下方。 最近刚好看到一篇文章汇总了非常多的聚合函数,就摘录在下方,供许多初入竞赛的朋友参考。 聚合特征汇总 pandas自带的聚合函数 * 其它重要聚合函数 其它重要聚合函数&分类分别如下。 def median(x):     return np.median(x) def variation_coefficient(x):     mean = np.mean(x)     if mean != 0:         return np.std(x) / mean     else:         return np.nan def variance(x):     return

By Ne0inhk
90w,确实可以封神了!

90w,确实可以封神了!

要说24年一定最热的技术,还得是AIGC! 前段时间阿里旗下的开源项目,登上GitHub热榜! AI大热,如今ChatGPT的优异表现,必然会出现各种细分场景应用的工具软件,和大量岗位项目! 山雨欲来风满楼,强人工智能的出现,所有科技公司已经开始巨量扩招此领域的人才。算法的岗位,近三个月已经增长68%!这件事在HR届也是相当震撼的。 目前各行各业都不景气的市场,人工智能岗位却一直保持常青!甚至同属AI边缘岗都比其他岗薪资高40%! 与此同时,AI算法岗上岸也不简单,竞争激烈,好公司核心岗位不用说,谁都想去。 所以事实就是,想要上岸,门槛也逐渐变高,项目经历、实习经历都很重要,越早明白这个道理就越能提前建立起自己的优势。 但我在b站逛知识区的时候,经常看到有些同学,因为一些客观原因导致无法参加实习,这种情况下,如果你想提升背景,增加项目经历的话,可以试试这个《CV/NLP 算法工程师培养计划》。 目前已经有上千位同学通过该计划拿到offer了,最新一期学员就业薪资最高能拿到78K!年薪94w! 优势就是有BAT大厂讲师带领,手把手带做AI真实企业项目(包含CV、NLP等

By Ne0inhk
再见nohup!试试这个神器,Python Supervisor!

再见nohup!试试这个神器,Python Supervisor!

👇我的小册 45章教程:() ,原价299,限时特价2杯咖啡,满100人涨10元。 作者丨Ais137 https://juejin.cn/post/7354406980784373798 1. 概述 Supervisor 是一个 C/S 架构的进程监控与管理工具,本文主要介绍其基本用法和部分高级特性,用于解决部署持久化进程的稳定性问题。 2. 问题场景 在实际的工作中,往往会有部署持久化进程的需求,比如接口服务进程,又或者是消费者进程等。这类进程通常是作为后台进程持久化运行的。 一般的部署方法是通过 nohup cmd & 命令来部署。但是这种方式有个弊端是在某些情况下无法保证目标进程的稳定性运行,有的时候 nohup 运行的后台任务会因为未知原因中断,从而导致服务或者消费中断,进而影响项目的正常运行。 为了解决上述问题,通过引入 Supervisor 来部署持久化进程,提高系统运行的稳定性。 3. Supervisor 简介 Supervisor is a client/

By Ne0inhk
第一本给程序员看的AI Agent图书上市了!

第一本给程序员看的AI Agent图书上市了!

AI Agent火爆到什么程度? OpenAI创始人奥特曼预测,未来各行各业,每一个人都可以拥有一个AI Agent;比尔·盖茨在2023年层预言:AI Agent将彻底改变人机交互方式,并颠覆整个软件行业;吴恩达教授在AI Ascent 2024演讲中高赞:AI Agent是一个令人兴奋的趋势,所有从事AI开发的人都应该关注。而国内的各科技巨头也纷纷布局AI Agent平台,如:钉钉的AI PaaS、百度智能云千帆大模型平台等等。 Agent 是未来最重要的智能化工具。对于程序员来说,是时候将目光转向大模型的应用开发了,率先抢占AI的下一个风口AI Agent。 小异带来一本新书《大模型应用开发 动手做 AI Agent》,这本书由《GPT图解》的作者黄佳老师创作,从0到1手把手教你做AI Agent。现在下单享受5折特惠! ▼点击下方,即可5折起购书 有这样一本秘籍在手,程序员们这下放心了吧,让我们先来揭开 Agent 的神秘面纱。 AI Agent 面面观

By Ne0inhk