使用Stripes,Guice管理数据库连接
|
我想知道用于在带有Guice的Stripes中管理数据库连接的最佳实践。
理想情况下,我希望执行以下操作:
每个线程/ http请求使用一个数据库连接(可能是guice用ServletScope.REQUEST范围将连接绑定到提供程序)
所有查询都在一个事务中执行,然后在最后提交或回滚。
我的问题是:应该如何创建/关闭数据库连接?
使用Stripes Interceptor打开和关闭连接不是一个好主意吗?
我与Manager类有很大的联系,它们都对数据库中的各个表执行自定义SQL查询。当前,所有这些Manager类都具有如下方法:
public abstract class MyManagerBase implements IMyManager {
@Inject
public void setConnection(Connection conn) {
this.conn = conn;
}
}
管理者自己将其子类化,并且不创建或关闭连接。
我有这样的动作豆:
public class MyActionBean implements ActionBean {
@Inject IMyManager myManager;
@DefaultHandler
public Resolution save() {
myManager.doStuff(...);
}
...
}
我有一个这样的guice配置:
public class MyConfigModule extends AbstractModule {
@Override
protected void configure() {
install(new ServletModule());
bind(IMyManager.class).to(MyManagerImpl.class);
bind(Connection.class).toProvider(MyConnectionProvider.class).in(ServletScopes.REQUEST);
}
到目前为止,我在想的是使用拦截器注入管理器,同时将同一连接连接到该http请求的所有管理器中。
到目前为止,我的拦截器尝试看起来像这样:
@Override
public Resolution intercept(ExecutionContext executionContext) throws Exception {
Connection conn = null;
switch( executionContext.getLifecycleStage() ) {
case ActionBeanResolution:
log.debug(\"Intercepting: ActionBeanResolution\");
// Inject dependencies into ActionBeans
injector.injectMembers( executionContext.getActionBeanContext() );
Resolution resolution = executionContext.proceed();
injector.injectMembers( executionContext.getActionBean() );
return resolution;
case RequestComplete:
log.debug(\"Intercepting: RequestComplete\");
executionContext.getActionBean();
Connection conn = injector.getInstance(Connection.class);
conn.commit();
conn.close();
}
}
}
没有找到相关结果
已邀请:
2 个回复
瞥同忙接
参数配置自己的Action Bean工厂的方法。当工厂实际实例化Action Bean时,它也可以注入构造函数参数。自己实现不是很困难。 但是您不必自己实现这一点,它有一个出色的Stripes插件,可以处理注入动作Bean,动作Bean上下文和拦截器:Stripes Guice。使用起来非常简单,请参阅:操作方法:guice托管动作bean
购藏盗码韦
。为此,我们使用了条纹导向器,对我们来说效果很好。