TDDL DataSource

TDDL DataSource 分为 AtomDataSource GroupDatasourcemysql

他们二者没有依赖关系, 都实现了 JDBC 规范, 能够做为独立的 datasource 单独使用sql

AtomDataSource

AtomDataSource 负责 diamond 动态配置, 它能够经过 diamond 动态改变 ds 的 ip port 帐号密码等app

AtomDataSource diamond 配置分为三部分atom

1. global config加密

global config 主要配置 database 信息, 主要包括以下配置spa

dataId:com.taobao.tddl.atom.global.qatest_normal_0

group:DEFAULT_GROUP

content:

ip=127.0.0.1

port=3306

dbName=qatest_normal_0

dbType=mysql

dbStatus=RW

2. app config线程

app config 主要包括应用配置, 例如线程池等, 以下code

dataId:com.taobao.tddl.atom.app.tddl_sample.qatest_normal_0

group:DEFAULT_GROUP

content:

userName=tddl

minPoolSize=1

maxPoolSize=2

idleTimeout=10

blockingTimeout=5

preparedStatementCacheSize=15

connectionProperties=characterEncoding=gbk

3. user configorm

dataId:com.taobao.tddl.atom.passwd.qatest_normal_0.mysql.tddl

group:DEFAULT_GROUP

content:

encPasswd=xxxxxxx(密文,请用tddl-atom-datasource工程下的JbossPasswordDecode加密下明文密码)

 

Diamond 动态配置代码结构blog

 

GroupDatasource

GroupDatasource 负责组合多个 datasource, 主要负责双机热备, 读写分离, 其中使用了 DatasourceWrapper 包装 ds, DataSourceWrapper 有一个 Weight 属性, 能够设置单个 ds 的可读可写属性, 以及读写优先级. 最后将多个 ds 组合成读写分离 ds, 实例代码

        List<DataSourceWrapper> dataSourceWrappers = new ArrayList<DataSourceWrapper>();
        dataSourceWrappers.add(new DataSourceWrapper("127.0.0.1:3306:db_1", "rpwp", getMySQLDataSource(1), DBType.MYSQL));
        dataSourceWrappers.add(new DataSourceWrapper("127.0.0.1:3306:db_2", "rpw0p0", getMySQLDataSource(2), DBType.MYSQL));

        TGroupDataSource ds = new TGroupDataSource();
        ds.init(dataSourceWrappers);
相关文章
相关标签/搜索