public class ZFBCheckAccountTask extends TaskThread {
}

这个类运行时候自动加载了数据库连接,不明白是如何提前加载的,开始用static { } 去全局搜索,未果(现在觉得思路就不对,因为只加载了自己的类,所以只可能加载自己这个类的static{}方法;用提示语全局搜索未果,因为连接方法在依赖的jar包中;接着想到了他的父类TaskThread ,对父类进行断点跟踪, 在构造方法中

public TaskThread() {
LDTaskParamDB tLDTaskParamDB = new LDTaskParamDB();
tLDTaskParamDB.setTaskCode("000000");
tLDTaskParamDB.setTaskPlanCode("000000");
tLDTaskParamDB.setParamName("ServerType");
if (tLDTaskParamDB.getInfo()) {

接着进入

tLDTaskParamDB.getInfo()
    public boolean getInfo() {
PreparedStatement pstmt = null;
ResultSet rs = null;
if (!this.mflag) {
this.con = DBConnPool.getConnection();
}

在DBConnPool类中有静态方法

 static {
for(int nIndex = 0; nIndex < 63; ++nIndex) {
dbConns[nIndex] = new DBConn();
} }

接着进入DBConn类中,构造方法

    protected DBConn() {
this.m_pw = new PrintWriter(this.m_buf, true);
this.mGlobalPools = GlobalPools.getInstance();
this.JUrl = new JdbcUrl();
this.bNotInUse = true;
}

在进入jdbcURl类中

 static {
InputStream stream = JdbcUrl.class.getClassLoader().getResourceAsStream("jdbc.properties");
Properties properties = new Properties(); try {
logger.info("【数据连接】开始加载数据库连接配置");
properties.load(stream);
JDBC_DB_TYPE = (String)properties.get("jdbc.DBType");
JDBC_DB_NAME = (String)properties.get("jdbc.DBName");
logger.info("【数据连接】对转码的数据库信息进行进行解码");
JDBC_IP = ConfigSecret.decode((String)properties.get("jdbc.IP"));
JDBC_PORT = ConfigSecret.decode((String)properties.get("jdbc.Port"));
JDBC_USERNAME = ConfigSecret.decode((String)properties.get("jdbc.UserName"));
JDBC_PASSWORD = ConfigSecret.decode((String)properties.get("jdbc.PassWord"));
JDBC_DEFAULT_CONN = (String)properties.get("jdbc.DefaultConn");
String fileConfigFlagStr = (String)properties.get("jdbc.fileConfigFlag");
fileConfigFlag = Boolean.getBoolean(fileConfigFlagStr);
logger.info("【数据连接】读取数据库连接完成,数据库连接地址" + JDBC_IP + ",数据库用户名:" + JDBC_USERNAME);
logger.info("【数据连接】开始初始化数据库连接");
initMultPool();
logger.info("【数据连接】初始化数据库连接完成");
} catch (Exception var11) {

这里就是的static 代码块读取了jdbc.prperties的属性

一文理解class.getClassLoader().getResourceAsStream(file)和ass.getResourceAsStream(file)区别

lis分析之一一批处理(任务)如何连接数据库的的更多相关文章

  1. POJ 3903 Stock Exchange (E - LIS 最长上升子序列)

    POJ 3903    Stock Exchange  (E - LIS 最长上升子序列) 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action ...

  2. HDU - 3564 Another LIS(LIS+线段树)

    http://acm.hdu.edu.cn/showproblem.php?pid=3564 题意 给出1~n的插入顺序,要求每次插入之后的LIS 分析 首先用线段树还原出最终序列.因为插入的顺序是按 ...

  3. LIS(变形) HDOJ 5489 Removed Interval

    题目传送门 题意:求删掉连续L长度后的LIS 分析:记rdp[i]表示以a[i]为开始的LIS长度,用nlogn的办法,二分查找-a[i].dp[i]表示以a[i]为结尾并且删去[i-L-1, i-1 ...

  4. Lock wait timeout分析

    ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction分析 1.4个用户连接数据库(A和D是本地回环登陆, ...

  5. 关于goneaway及499

    关于上面现象的分析如下 问题描述: 接口偶发性出现接口耗时过长的情况 根源: “sockets的快速回收”机制被启动 简单代码+数据分析: 1.      经简单分析,耗时主要出现在连接数据库的方法: ...

  6. JavaEE JDBC 怎么加载驱动

    JDBC怎么加载驱动 @author ixenos 分析 1.JDBC是一套连接数据库的接口(放在java.util.sql.Driver类中),不同的数据库依此接口各自实现Java连接到数据库的操作 ...

  7. 8月清北学堂培训 Day1

    今天是赵和旭老师的讲授~ 动态规划 动态规划的基本思想 利用最优化原理把多阶段过程转化为一系列单阶段问题,利用各阶段之间的关系,逐个求解. 更具体的,假设我们可以计算出小问题的最优解,那么我们凭借此可 ...

  8. myBatis源码解析-日志篇(1)

    上半年在进行知识储备,下半年争取写一点好的博客来记录自己源码之路.在学习源码的路上也掌握了一些设计模式,可所谓一举两得.本次打算写Mybatis的源码解读. 准备工作 1. 下载mybatis源码 下 ...

  9. R绘图(7): 把散点图的点换成扇形

    前几天分析了一批单细胞TCR的数据,需要画这样一个图: 行是不同的样本,列是不同的T细胞类型,每一个位置点的大小表示T细胞的数目多少,并且还需要根据T细胞所属的克隆型类型涂色.这个图用来描述TCR是我 ...

随机推荐

  1. PTA题目集总结

    PTA题目集1-3总结 一:前言 我认为题目集一的有八个题目,题量可能稍微有点多,但是题型较为简单,基本为入门题:题集二有五道题,题量适度,难度也适中:题集三虽然只有三道题,但是难度却骤然提升,前两题 ...

  2. Spring Boot WebFlux-02——WebFlux Web CRUD 实践

    第02课:WebFlux Web CRUD 实践 上一篇基于功能性端点去创建一个简单服务,实现了 Hello.这一篇用 Spring Boot WebFlux 的注解控制层技术创建一个 CRUD We ...

  3. [INS-32033] Central Inventory location is not writable

    这个是因为之前安装过一次图形界面,已经创建过Inventory,所以会报错. 解决:删除oraInventory这个目录.

  4. 限流神器Sentinel,不了解一下吗?

    概述 书接上回:你来说说什么是限流? ,限流的整体概述中,描述了 限流是什么,限流方式和限流的实现.在文章尾部的 分布式限流,没有做过多的介绍,选择了放到这篇文章中.给大伙细细讲解一下 Sentine ...

  5. 15 自动发布Java项目(Tomcat)

    #!/bin/bash export PAHT=/usr/local/maven/bin:/usr/local/jdk/bin:/usr/local/sbin:/usr/local/bin:/usr/ ...

  6. .net获取项目根目录方法集合

    这篇文章是别的博客复下来,收藏的: 编写程序的时候,经常需要用的项目根目录.自己总结如下 1.取得控制台应用程序的根目录方法     方法1.Environment.CurrentDirectory ...

  7. Docker Swarm介绍

    1 什么是swarmSwarm是Docker公司推出的docker集群管理平台,它将一群Docker主机变成了一台单一的虚拟Docker主机.Swarm使用标准的Docker API接口,因此,任何支 ...

  8. Spring data Jpa 提供的validator验证

  9. PDO之MySql持久化自动重连导致内存溢出

    前言 最近项目需要一个常驻内存的脚本来执行队列程序,脚本完成后发现Mysql自动重连部分存在内存溢出,导致运行一段时间后,会超出PHP内存限制退出 排查 发现脚本存在内存溢出后排查了一遍代码,基本确认 ...

  10. python 两种排序方法 sort() sorted()

    python中有两种排序方法,list内置sort()方法或者python内置的全局sorted()方法 区别为: sort()方法对list排序会修改list本身,不会返回新list.sort()只 ...