tapestry mysql_tapestry5.3 框架中使用系统环境变量配置hibernate 数据库连接参数

问题描述

写了个tapestry+spring+hibernate+mysql的demo应用,代码放在coding 想部署在daocloud 和tenxcloud 两个docker 云服务平台上但是数据库服务参数各不相同。

官方给出的网上搜到的hibernate配置都是默认的那种即使用hibernate.cfg.xml 文件,系统自动加载。

我想要的是默认加载hibernate.cfg.xml 同时判断环境变量中是否有数据库连接字符串、用户名和密码对应的参数如果有的话覆盖默认配置。

经过认真阅读tapestr的文档加上多次实验终于弄明白了 tapestry5.3 中是如何加载hibernate 相关配置的。

解决问题

先说结论:

AppModule.java 中加入以下代码

javapublic static void bind(ServiceBinder binder)

{

binder.bind(HibernateConfigurer.class, EnvMysqlHibernateConfigurer.class).withSimpleId();

}

public static void contributeHibernateSessionSource(OrderedConfiguration config)

{

//通过环节变量进行 hibernate 相关设置

config.addInstance("Env", EnvMysqlHibernateConfigurer.class);

}

新增EnvMysqlHibernateConfigurer.java 位置是

src/main/java/org/apache/tapestry5/internal/hibernate/

代码如下:

javapackage org.apache.tapestry5.internal.hibernate;

import java.io.File;

import org.apache.tapestry5.hibernate.HibernateConfigurer;

import org.hibernate.cfg.Configuration;

import org.hibernate.cfg.Environment;

import com.mysql.jdbc.StringUtils;

/**

* Simply calls configure() to do the default Hibernate configuration. This will set the properties from system env.

*
目前关键是: mysql_url, mysql_username,mysql_password

*/

public final class EnvMysqlHibernateConfigurer implements HibernateConfigurer

{

public EnvMysqlHibernateConfigurer()

{

}

public void configure(Configuration configuration)

{

//数据库链接地址、用户名、密码

String url=System.getenv("mysql_url");

String username=System.getenv("mysql_username");

String password=System.getenv("mysql_password");

if(configuration==null){

File file = new File("hibernate.cfg.xml");

configuration= new Configuration();

configuration.configure(file);

}

if(!StringUtils.isNullOrEmpty(url)){

configuration.setProperty(Environment.URL, url);

System.out.println("set "+Environment.URL+":"+"url");

}

if(!StringUtils.isNullOrEmpty(username)){

configuration.setProperty(Environment.USER, username);

System.out.println("set "+Environment.USER+":"+"username");

}

if(!StringUtils.isNullOrEmpty(password)){

configuration.setProperty(Environment.PASS, password);

System.out.println("set "+Environment.PASS+":"+password);

}

}

}

再说原理

tapestry中service的配置

tapestry通过AppModule 或其他Module 类处理service 的bind 和configure配置,配置的方法入口即:contribute+服务名,数据库配置的方法就是:contributeHibernateSessionSource 。

tapestry管理的hibernate 配置

HibernateConfigurer接口默认有两个实现,一个是加载默认设置即hibernate.cfg.xml另一个是根据entity包配置加载配置,所以需要新建 EnvMysqlHibernateConfigurer类 实现 HibernateConfigurer接口。在EnvMysqlHibernateConfigurer的configure方法中处理环境变量跟hibernate 参数设置的逻辑,具体参看代码。

环境变量设置

然后以后本机就用默认的hibernate.cfg.xml 配置的本地数据库,部署到云上的时候将数据库服务的连接参数配成环境变量即可。具体设置环境变量的操作各云环境不一样但都有此功能。

以及其他情况

如果使用spring 管理hibernate,那么可以在spring 的xml文件中声明一个bean 用bean的属性来设置hibernate的参数,而bean 里面可以方便的获取系统环境变量

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值