spring boot 集成蚂蚁sofa zdal

说明:

       本文主要用于记录当时自己项目中集成的步骤,zdal 使用单库单表,多库多表等后续更新

一、sofa zdal依赖,排除了一些不用的选项

 <dependency>
			<groupId>com.alipay.boot</groupId>
			<artifactId>zdal4-jdbc-spring-boot-starter</artifactId>
			<version>1.1.0</version>
			<exclusions>
				<exclusion>
					<groupId>com.alipay.kmi</groupId>
					<artifactId>*</artifactId>
				</exclusion>
				<exclusion>
					<groupId>org.slf4j</groupId>
					<artifactId>slf4j-log4j12</artifactId>
				</exclusion>
				<exclusion>
					<groupId>org.springframework</groupId>
					<artifactId>spring</artifactId>
				</exclusion>
				<exclusion>
					<groupId>com.alipay.common</groupId>
					<artifactId>tracer-biz</artifactId>
				</exclusion>
				<exclusion>
					<groupId>com.alipay.common</groupId>
					<artifactId>tracer</artifactId>
				</exclusion>
				<exclusion>
					<groupId>com.alipay.drm</groupId>
					<artifactId>drm-client</artifactId>
				</exclusion>
				<exclusion>
					<groupId>com.taobao.configserver</groupId>
					<artifactId>*</artifactId>
				</exclusion>
				<exclusion>
					<groupId>com.alipay.configserver</groupId>
					<artifactId>*</artifactId>
				</exclusion>
				<exclusion>
					<groupId>com.taobao.logstat</groupId>
					<artifactId>*</artifactId>
				</exclusion>
				<exclusion>
					<groupId>com.alipay.sofa</groupId>
					<artifactId>*</artifactId>
				</exclusion>
				<exclusion>
					<groupId>com.alipay.sofa.common.log</groupId>
					<artifactId>sofa-middleware-log</artifactId>
				</exclusion>
			</exclusions>
		</dependency>
		<dependency>
			<groupId>org.slf4j</groupId>
			<artifactId>log4j-over-slf4j</artifactId>
			<scope>provided</scope>
		</dependency>

二、集成配置

 

   1. 在项目resources下新建文件 zdal/config/db/cxinscn-doc-dev-ds.xml数据源配置xml具体内容如下

   注意:该文件的命名规范为 {appname}-{environmentId}-ds.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
       classpath:/org/springframework/beans/factory/xml/spring-beans-3.0.xsd"
       default-autowire="byName">

    <bean id="cxinscn-doc" class="com.alipay.zdal.client.config.bean.ZdalAppBean">
        <property name="appName" value="cxinscn-doc"/>
        <property name="dbmode" value="dev"/>
        <property name="appDataSourceList">
            <list>
                <ref bean="appDataSource"/>
            </list>
        </property>
    </bean>

    <!-- 单证单库数据源 -->
    <bean id="appDataSource"  primary="true" class="com.alipay.zdal.client.config.bean.AppDataSourceBean">
        <property name="appDataSourceName" value="appDataSource"/>
        <property name="dataBaseType" value="MYSQL"/>
        <property name="physicalDataSourceSet">
            <set>
                <ref bean="physicalDataSource"/>
            </set>
        </property>
        <property name="groupDataSourceRuleMap">
            <map>
                <entry key="singleG_0" value="singleM_0:r10w10" />
            </map>
        </property>
    </bean>
    <bean id="physicalDataSource" class="com.alipay.zdal.client.config.bean.PhysicalDataSourceBean">
        <property name="name" value="physicalDataSource"/>
        <property name="type" value="MYSQL"/>
        <property name="driverClass" value="com.mysql.jdbc.Driver"/>
        <property name="jdbcUrl" value="jdbc:mysql://127.0.0.1:3306/xx?allowMultiQueries=true"/>
        <property name="userName" value="数据库账号"/>
        <property name="password" value="数据库密码"/>
        <property name="minConn" value="1"/>
        <property name="maxConn" value="100"/>
        <property name="blockingTimeoutMillis" value="60000"/>
        <property name="idleTimeoutMinutes" value="1"/>
        <property name="preparedStatementCacheSize" value="0"/>
        <property name="queryTimeout" value="0"/>
        <!--<property name="prefill" value="true"/>-->
        <property name="maxReadThreshold" value="100"/>
        <property name="maxWriteThreshold" value="100"/>
        <property name="logicDbNameSet">
            <set>
                <value>singleM_0</value>
            </set>
        </property>
        <property name="connectionProperties">
            <map>
                <entry key="connectTimeout" value="10000"/>
                <entry key="socketTimeout" value="10000"/>
            </map>
        </property>
    </bean> 
</beans>

 

 2.在 Spring 配置中添加 zdal 数据源与mybits集成,在项目resources下新建 resource/META-INF/spring/spring-mybatis.xml,命名随意

<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:sofa="http://schema.alipay.com/sofa/schema/slite"
       xmlns:mvc="http://www.springframework.org/schema/mvc"
       xmlns:aop="http://www.springframework.org/schema/aop"
	   xmlns:tx="http://www.springframework.org/schema/tx"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd
        http://schema.alipay.com/sofa/schema/slite http://schema.alipay.com/sofa/slite.xsd
        http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd
        http://www.springframework.org/schema/tx 
        http://www.springframework.org/schema/tx/spring-tx.xsd 
        http://www.springframework.org/schema/aop 
        http://www.springframework.org/schema/aop/spring-aop.xsd" default-autowire="byName">


 <!-- DDS DataSource -->
    <sofa:zdal-jdbc id="dataSource">
        <sofa:appDataSourceName value="appDataSource"/>
    </sofa:zdal-jdbc>
   
    
    <!-- 事务管理器 -->
    <bean id="transactionManager"
          class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource"/>
    </bean>
 	
    <tx:annotation-driven transaction-manager="transactionManager"/>
    
    <!-- mybatis 配置 -->
    <bean id="sqlSessionFactoryMybatis" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="configLocation" value="classpath:META-INF/mybatis/mybatis-configuration.xml"/>
        <property name="mapperLocations" value="classpath:META-INF/mybatis/mapper/*Mapper.xml"/>
        <property name="dataSource" ref="dataSource"/>
    </bean>
  
    <!--menbership数据库-->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <property name="basePackage" value="com.cathay.dao.documents"/>
        <property name="sqlSessionFactoryBeanName" value="sqlSessionFactoryMybatis"/>
    </bean>
   
</beans>

   

3.在 application-dev.properties 添加sofa一些配置

zdal.jdbc.dbmode=dev  设置开发环境运行

4.在spring boot 启动类(Application) 中通过@ImportResource 读取数据源配置xml。

package com.cathay;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration;
import org.springframework.boot.autoconfigure.jdbc.DataSourceTransactionManagerAutoConfiguration;
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.ImportResource;

@ImportResource({"classpath*:META-INF/spring/*.xml","classpath*:META-INF/cxinscn-doc/*.xml","classpath*:config/*.xml"})
@SpringBootApplication
@EnableAutoConfiguration(exclude = {DataSourceAutoConfiguration.class,
		DataSourceTransactionManagerAutoConfiguration.class})
public class DocApplication {
	// init the logger
    private static final Logger logger = LoggerFactory.getLogger(DocApplication.class);

    public static void main(String[] args){

    	System.setProperty("spring.profiles.active","dev");
        SpringApplication springApplication = new SpringApplication(DocApplication.class);
        ApplicationContext applicationContext = springApplication.run(args);
 
        if (logger.isInfoEnabled()){
            logger.info("application start");
        }

    }
}

 

 

转载于:https://my.oschina.net/u/3647421/blog/2934637

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值