lis分析之一一批处理(任务)如何连接数据库的
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分析之一一批处理(任务)如何连接数据库的的更多相关文章
- POJ 3903 Stock Exchange (E - LIS 最长上升子序列)
POJ 3903 Stock Exchange (E - LIS 最长上升子序列) 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action ...
- HDU - 3564 Another LIS(LIS+线段树)
http://acm.hdu.edu.cn/showproblem.php?pid=3564 题意 给出1~n的插入顺序,要求每次插入之后的LIS 分析 首先用线段树还原出最终序列.因为插入的顺序是按 ...
- LIS(变形) HDOJ 5489 Removed Interval
题目传送门 题意:求删掉连续L长度后的LIS 分析:记rdp[i]表示以a[i]为开始的LIS长度,用nlogn的办法,二分查找-a[i].dp[i]表示以a[i]为结尾并且删去[i-L-1, i-1 ...
- Lock wait timeout分析
ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction分析 1.4个用户连接数据库(A和D是本地回环登陆, ...
- 关于goneaway及499
关于上面现象的分析如下 问题描述: 接口偶发性出现接口耗时过长的情况 根源: “sockets的快速回收”机制被启动 简单代码+数据分析: 1. 经简单分析,耗时主要出现在连接数据库的方法: ...
- JavaEE JDBC 怎么加载驱动
JDBC怎么加载驱动 @author ixenos 分析 1.JDBC是一套连接数据库的接口(放在java.util.sql.Driver类中),不同的数据库依此接口各自实现Java连接到数据库的操作 ...
- 8月清北学堂培训 Day1
今天是赵和旭老师的讲授~ 动态规划 动态规划的基本思想 利用最优化原理把多阶段过程转化为一系列单阶段问题,利用各阶段之间的关系,逐个求解. 更具体的,假设我们可以计算出小问题的最优解,那么我们凭借此可 ...
- myBatis源码解析-日志篇(1)
上半年在进行知识储备,下半年争取写一点好的博客来记录自己源码之路.在学习源码的路上也掌握了一些设计模式,可所谓一举两得.本次打算写Mybatis的源码解读. 准备工作 1. 下载mybatis源码 下 ...
- R绘图(7): 把散点图的点换成扇形
前几天分析了一批单细胞TCR的数据,需要画这样一个图: 行是不同的样本,列是不同的T细胞类型,每一个位置点的大小表示T细胞的数目多少,并且还需要根据T细胞所属的克隆型类型涂色.这个图用来描述TCR是我 ...
随机推荐
- Django(66)admin后台管理注册用户
前言 我们使用django创建用户可以使用注册接口的方式,也可以使用django自带的后台管理系统,这里就介绍使用后台管理系统创建用户 admin后台管理系统 在使用之前我们可以使用第三方的插件,来美 ...
- 【题解】PIZZA 贪心
题目描述 Michael请N个朋友吃馅饼,但是每个朋友吃且仅吃一个馅饼的1/4.1/2或3/4.请你编程求出Michael至少需要买多少个馅饼. 输入输出格式 输入格式: 输入文件的第一行是整数N:接 ...
- 『无为则无心』Python基础 — 8、Python中的数据类型(数值、布尔、字符串)
目录 1.数据类型介绍 2.数值型(Number) 3.布尔型(bool) 4.None(空值) 5.常量 6.字符串(String) 1.数据类型介绍 (1)什么是数据类型 在生活中,我们日常使用的 ...
- 通过浏览器运行cmd命令、启动steam
我们先来看看实现起来的效果,我们在浏览器中输入ping so.com 试试打开计算器.启动steam 要实现这个效果其实用到了浏览器自定义协议,我们可以通过自定义协议打开wechat.扣扣.emali ...
- 『心善渊』Selenium3.0基础 — 16、Selenium对iframe表单的操作
目录 1.什么是iframe表单 2.iframe表单操作流程 3.iframe表单操作常用方法 (1)进入表单 (2)多表单切换 4.表单操作示例 1.什么是iframe表单 实际上就是HTML页面 ...
- Nexus安装配置和使用
Nexus安装配置和使用 第一步安装jdk yum install java-1.8.0-openjdk-devel 第二步下载nexus-3.12.1-01-unix.tar.gzjdk 下载地址: ...
- vue cli3 使用elemet-plus
原文章: https://blog.csdn.net/qq_44827865/article/details/115457445 element-plus官方网站:https://element-pl ...
- AcWing 1252. 搭配购买
#include<bits/stdc++.h> #define N 10010 using namespace std; int fa[N],v[N],pr[N]; int vv[N],p ...
- CentOS-Docker安装MySQL(单点)
下载镜像 $ docker pull mysql 创建相关目录和文件 $ mkdir -p /usr/mysql/conf /usr/mysql/data $ chmod -R 755 /usr/my ...
- WebSocket实现实时聊天系统
WebSocket实现实时聊天系统 等闲变却故人心,却道故人心易变. 简介:前几天看了WebSocket,今天体验下它的实时聊天. 一.项目介绍 WebSocket 实时聊天系统自己一个一码的搞出来还 ...