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. 5000字长文,kurryluo 的自学编程之路

    我是程序员.大众口中非科班的那种,带着高中时期对二进制的恐惧,在大学参加科研比赛后保研,再到和校友一起创业,现在在某大型互联网公司做前端开发,一路走来都是靠自己学习. 前端框架 VUE 的作者尤大说过 ...

  2. Golang编写Windows动态链接库(DLL)及C调用范例

    一.准备. 1.GoLang在1.10版本之后开始支持编译windows动态链接库,可以打开命令行工具使用go version 查看自己的go版本. 2.你的电脑上需要gcc,如果没有的话[点击这里] ...

  3. ClickHouse源码笔记6:探究列式存储系统的排序

    分析完成了聚合以及向量化过滤,向量化的函数计算之后.本篇,笔者将分析数据库的一个重要算子:排序.让我们从源码的角度来剖析ClickHouse作为列式存储系统是如何实现排序的. 本系列文章的源码分析基于 ...

  4. zabbix_manage的使用

    实验环境: zabbix server 172.16.1.121 访问端 172.16.1.122 55.1 说明 zabbix_manager是zabbix终端管理工具,可以在linux终端实现管理 ...

  5. CRM系统不仅给企业带来更多收益而且提升销售效率

    将客户信息记录在CRM系统的数据库中,同时共享沟通数据给售前.售后.SDR等上下游,客户资源还能够按照分配规则分配给适合的销售人员,帮助更快成单.全面使用CRM系统会给企业带来更多业绩. 1.全方位客 ...

  6. Leetcode No.121 Best Time to Buy and Sell Stock(c++实现)

    1. 题目 1.1 英文题目 You are given an array prices where prices[i] is the price of a given stock on the it ...

  7. Windows环境mysql自动备份

    1.编写bat文件备份mysql 1 rem ******MySQL backup start****** 2 @echo off 3 4 ::删除一周前的备份数据 5 forfiles /p &qu ...

  8. 个人博客开发之blog-api项目统一结果集api封装

    前言 由于返回json api 格式接口,所以我们需要通过java bean封装一个统一数据返回格式,便于和前端约定交互, 状态码枚举ResultCode package cn.soboys.core ...

  9. Flask(12)- 操作 Session

    前言 Session 详解:https://www.cnblogs.com/poloyy/p/12513247.html 这一节来瞧一瞧如何用 Flask 操作 Session 功能 list 提供操 ...

  10. WIN10 GMSSL编译

    从git上拉取GMSSL代码 从http://gmssl.org/上可以拉取,或者直接从git上https://github.com/guanzhi/GmSSL拉也行. 我是在git上下的,文件为gm ...