CPA-IBE
1.Transaction ID 生成机制
在有的情况下,我们需要得到固定格式的序列号,而不是数据库默认的自增序列号,
1.1 通常方式(隐式生成并通过触发器实时插入相关表)
例如我们要求此序列号必须有固定前缀,长度必须固定为12为,必须自增,要怎么实现呢。
通常情况下,可以在Oracle中定义一个序列,
CREATE SEQUENCE seqTest
INCREMENT BY 1 -- 每次加几个
START WITH 1 -- 从1开始计数
NOMAXvalue -- 不设置最大值
NOCYCLE -- 一直累加,不循环
CACHE 10; --设置缓存cache个序列,如果系统down掉了或者其它情况将会导致序列不连续,也可以设置为---------NOCACHE
定义好sequence后,你就可以用currVal,nextVal取得值。
SELECT Sequence名称.CurrVal FROM DUAL;
select seqtest.currval from dual
我们可以将这个序列通过触发器绑定到某个表上,例如下面,
create sequence SEQ_ID
minvalue 1
maxvalue 99999999
start with 1
increment by 1
nocache
order; 建解发器代码为: create or replace trigger tri_test_id
before insert on S_Depart --S_Depart 是表名
for each row
declare
nextid number;
begin
IF :new.DepartId IS NULLor :new.DepartId=0 THEN --DepartId是列名
select SEQ_ID.nextval --SEQ_ID正是刚才创建的
into nextid
from sys.dual;
:new.DepartId:=nextid;
end if;
end tri_test_id;
这样就实现了在表中插入数据时候自定义的序列可以自增了。
————————————————————
2.2.IBE的实现方式:显示生成,后续手动插入相关表
在IBE在PRE_PAYMENT的ACTION中,将会生成一个唯一的transaction ID, 这个ID会根据不同的业务类型分配不同的前缀,例如RR,RB,RH等。
可以看到,在数据库中创建了如下序列,
CREATE SEQUENCE TXCTLADMIN.SQ_TXCTL_ONLINE_REVENUE_BKG INCREMENT BY 1 MAXVALUE 99999999 MINVALUE 1 CYCLE NOCACHE ORDER
其实这个步骤也可以在Hibernate中进行配置,像下面这样,
<id name="id" type="long">
<column name="ID" not-null="true" sql-type="NUMBER" unique="true"/>
<generator class="sequence">
<param name="sequence">SQ_TXCTL_ONLINE_REVENUE_BKG</param>
</generator>
</id>
接着在java代码OnlineTransactionDataProviderImpl中,通过以下方式获取下一个序列号,
@Override
public Long getSequenceNum(final String sequenceName) { return (Long) this.getSessionFactory().getCurrentSession()
.createSQLQuery("select " + sequenceName + ".NEXTVAL as id from dual").addScalar("id", Hibernate.LONG)
.uniqueResult(); }
关键代码为select " + sequenceName + ".NEXTVAL as id from dual 这一句,结合上面java代码的上下文,这里的sequenceName为SQ_TXCTL_ONLINE_REVENUE_BKG,
即,如果已经在数据库中创建了一个序列,则获取下一个序列是借助虚拟表DUAL获取的,像下面这样,
SELECT TXCTLADMIN.SQ_TXCTL_ONLINE_REVENUE_BKG.NEXTVAL FROM DUAL;
通过上面的方式可以生成一个transaction ID, 我们可以验证当前生成的ID值,
SELECT TXCTLADMIN.SQ_TXCTL_ONLINE_REVENUE_BKG.CURRVAL FROM DUAL;
在简单的插入数据的业务中,完全可以配置一个触发器,每当插入数据到指定表的时候,就获取上面的序列并随之插入新行中,
但是IBE在这里获取了序列号之后,新行并不是需要马上插入数据库,因为后面还有大量业务需要处理,所以这里只是先显式生成序列号。
2. servlet的ThreadLocal机制
传统的Java多线程经常使用synchronized来同步线程,它依靠JVM的锁机制来实现临界区的函数或者变量在访问中的原子性。
在Web容器默认采用单实例(单Servlet实例)多线程的方式来处理Http请求,但是,这样的处理方式会导致变量访问的线程安全问题。也就是说,Servlet对象并不是一个线程安全的对象。
为了解决web容器多线程的线程安全问题,可以使用ThreadLocal机制来解决这个问题。
ThreadLocal同步机制
在IBE中,各个service bean都是无状态的,用户的状态都保存在session中,但是多个用户的所有操作日志都将打印在同一个日志文件中,如果没有一个标识符号,根本无法区分哪条日志是谁的。
因此在IBE中,就是先定义了一个ThreadLocal类型的关联ID:correlationInfo,当用户的第一个请求到达服务器时,先生成一个correlationInfo变量,每次写日志时用这个变量作为唯一标识符,
多个线程之间的correlationInfo则能起到唯一标识作用,在日志上就能区分每个用户的内容了。当用户操作发生跳转,有新的请求的时候,可以将correlationInfo放在session或者放在URL中,当同
一个用户的请求到达时候,再读出这个corrleationInfo,继续写日志。
private static ThreadLocal<CorrelationInfo> corrInfo = new ThreadLocal<CorrelationInfo>();
获取corrInfo的方法,可以看到用的是JDK自带的UUID算法,可以保证唯一性。
public static CorrelationInfo getCorrelationInfo() {
CorrelationInfo correlationInfo = ThreadLocalUtil.corrInfo.get();
if (correlationInfo == null || correlationInfo.isBlankCorrelationInfo()) {
correlationInfo = new CorrelationInfo("null", UUID.randomUUID().toString(), "WEB");
}
return correlationInfo;
}
接着,在做payment之前,因为此payment请求是从第三方跳转到IBE的,甚至是在内部和外部系统进行多次来回跳转,此时需要先获取这个correlationId,写日志的时候就不会混乱。
bookingDetail.setCorrelationInfo(ThreadLocalUtil.getCorrelationInfo());
3.IBE的状态维持及事务管理
IBE由SpringMVC实现业务层,单例sevelet将每个http请求分配到独立线程,通过FacadeController找到具体的service进行执行,这个过程中,IBE与内外系统有来回交互,在Service层中的bean几乎是无状态的(除了一些需要注入的handler),所有用户状态都保存在session中,另外通过correctlation ID可以将请求与线程绑定,即每次都能保证在内外系统通过http交互时,同一个人的请求总是由同一个线程继续处理。http请求默认是重写URL实现,每一个http请求中,都附带有JSESSION ID,默认的session ID是IBE自己生成并用来保存用户状态,但此JSESSION ID则是由外部系统1A生成,用来与具体事务关联的(例如锁定票务事务,票务是由第三方提供的)。
4.时序图
Web容器默认采用单实例(单Servlet实例)多线程的方式来处理Http请求
CPA-IBE的更多相关文章
- Q&A to prepare interview of HSBC
1.How do you keep updating lastest IT knowledge? 1).keep an eye on current project technology evetho ...
- 什么是CPA, CPS, CPT?
在互联网上或移动端进行产品推广时,经常听到很多术语,什么CPA,CPS,CPT等等.不知是怎么来的,今天网上搜一下术语,在这里做一下笔记. CPA(Cost Per Action) 每行动成本. CP ...
- CPA
CPA.CPS.CPM.CPT.CPC 是什么 网络营销之所以越来越受到重视一个主要的原因就是因为“精准”.相比较传统媒体的陈旧广告形式,网络营销能为广告主带来更为确切的效果与回报,更有传统媒体所没有 ...
- 弹出CPA
var url = "cpa url"; document.write("<iframe name='ip' src='' width='0' height='0' ...
- cfa,cpa,
CFA考试内容分为三个不同级别,分别是方式是Level I.Level II和Level III. 考试在全球各个地点统一举行,每个考生必须依次完成三个不同级别的考试.CFA资格考试采用全英文,候选人 ...
- 一位同学3年通过CPA, CFA, ACCA的经验
3 年从 ACCA!!! 今天收到 ACCA,只去考了一门,因为要下 field,可恶的 H R 和 manager 都不批准我的假.不过还好,功夫不负有心人,CPA 了,也是本科毕业那年. 本科结束 ...
- 详解一下网络广告cpc、cpm、cpl、cpa、cps、cpr的计费方法是什么
CPC(Cost per click)按照 广告 点击数 计费 ,限定一个IP在24小时内只能点击一次.CPM(Cost per mille)按照广告显示次数来计算广告费,可在短时间内为 网站 带来巨 ...
- CPA、CPS、CPM、CPT、CPC 是什么
http://www.a-edm.com/cpa.html 网络营销之所以越来越受到重视一个主要的原因就是因为“精准”.相比较传统媒体的陈旧广告形式,网络营销能为广告主带来更为确切的效果与回报,更有传 ...
- CPM、CPC、CPA、CPS、CPL、CPR 是什么意思 -解析互联网广告术语
CPA CPS CPA/CPS常见的推广方式 CPA和CPSCPA,CPS CPS与CPA CPA.CPSCPA.CPS产品教 CPA CPS什么意思 CPACPS是什么 1. CPM(Cost p ...
- Affiliate实战记录之一:CPI、CPA、CPM...名词解释
1.CPM (Cost Per Mille,或者Cost Per Thousand;Cost Per Impressions) 每千人成本,按展示次数收费 网上广告收费最科学的办法是按照有多少人看到你 ...
随机推荐
- Unable to instantiate Action, xxxAction, defined for 'xxx' in namespace '/'xxxAction解决方式
出现这个问题的解决办法主要有两个 1.假设项目没有使用Spring,则struts.xml配置文件里,这个action的class属性的路径没有写完整,应该是包名.类名 2.假设项目使用了Spring ...
- Codeforces Round #Pi (Div. 2) —— C-Geometric Progression
题意: 如今有n个数,然后给出一个数k(代表的是等比数列中的那个公比),然后第二行给出n个数,代表的是这个序列. 最后的问题是叫你找出在这个序列中满足公比为k的三个数有几种.并输出方案总数. 思路: ...
- 本地项目上传虚拟机的gitlab
前提:在虚拟机安装了gitlab服务,并且本机可以访问到虚拟机的gitlab 自己本机项目上传到gitlab 1.先在gitlab上建立项目 拷贝项目地址: http://192.168.1.105/ ...
- web.xml整理
web.xml,部署描写叙述符文件(专业术语).是在Servlet规范中定义的.是web应用的配置文件(Servlet 3.0已開始放弃使用web.xml,转而使用annotation注解来配置项目) ...
- KD树——k=1时就是BST,里面的数学原理还是有不明白的地方,为啥方差划分?
Kd-Tree,即K-dimensional tree,是一棵二叉树,树中存储的是一些K维数据.在一个K维数据集合上构建一棵Kd-Tree代表了对该K维数据集合构成的K维空间的一个划分,即树中的每个结 ...
- B1001 狼抓兔子 最小割
题目描述 现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓兔子还是比较在行的, 而且现在的兔子还比较笨,它们只有两个窝,现在你做为狼王,面对下面这样一个网格的地形: ...
- 快速排序及三向切分快排——java实现
快速排序也是一种分治算法.主要思想是选取一个切分点,将大于切分点的元素都放置到数组右侧,小于切分点的元素都放置到数组左侧:然后递归,再对切分点左侧和右侧分别排序. 归并排序时递归在前,归并在后,快速排 ...
- bzoj2287【POJ Challenge】消失之物(退背包)
2287: [POJ Challenge]消失之物 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 657 Solved: 382[Submit][S ...
- 原生JS---8
原生js学习笔记8——Ajax基础 什么是Ajax 不刷新页面的情况下从服务器获取.提交数据的一种数据交互方式. Ajax使用步骤 1.创建Ajax对象 var httpRequest = new ...
- 深入理解Redis(一)——高级键管理与数据结构
引语 这个章节主要讲解了三部分内容: 如何设计并管理Redis的键以及与其关联的数据结构: 了解并使用Redis客户端对象映射器: 介绍如何利用大O标记来评估Redis性能. 键与数据结构 键 我们先 ...