<servlet-name>DataSyn</servlet-name>
<servlet-class>com.datasyn.DataSyn</servlet-class>
<init-param>
<param-name>interval</param-name>
<param-value>5000</param-value>
</init-param>
<load-on-startup>1</load-on-startup> //项目启动就执行这个servlet
</servlet>
<servlet-mapping>
<servlet-name>DataSyn</servlet-name>
<url-pattern>/servlet/DataSyn</url-pattern>
</servlet-mapping>
servlet类中的的init和destroy方法:
public class DataSyn extends HttpServlet {
private static Logger log = Logger.getLogger(DataSyn.class.getName());
private Thread t = null;
private boolean istop = false;
/**
* Constructor of the object.
*/
public DataSyn() {
super();
}
/**
* Initialization of the servlet. <br>
*
* @throws ServletException if an error occurs
*/
public void init() throws ServletException {
System.out.println("DataSyn init 准备启动");
Runnable r = new Runnable() { //匿名内部类
Resouce resource = new Resouce();
OpDb oD = new OpDb();
public void run() { //实现runnable接口的run方法
while(!istop)
{
try {
Thread.sleep(Integer.parseInt(DataSyn.this.getInitParameter("interval"))); //此线程每隔段时间休眠
} catch (NumberFormatException e) {
e.printStackTrace();
} catch (InterruptedException e) {
e.printStackTrace();
}
resource.work(); //具体的数据库操作写在这方法里
}
}
};
t = new Thread(r);
t.start(); //开始执行此线程的方法run
}
/**
* Destruction of the servlet. <br>
*/
public void destroy() {
super.destroy(); // Just puts "destroy" string in log
// Put your code here
istop = true;
try {
t.join();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println("destroy");
}
}
分享到:
相关推荐
在描述中提到的"扫描csv文件的数据到数据库中 java源代码",意味着代码将逐行读取CSV文件,解析每一行,然后将这些数据作为新记录添加到数据库中。实现这一功能的Java代码会包含上述提到的各个步骤。 通过标签"csv...
执行器将优化后的计划转化为具体的数据库操作,如表扫描、索引查找等。 源码中的`H2Test`文件可能是一个测试模块,用于验证数据库的各种功能和性能。在阅读源码时,这些测试用例能帮助我们更好地理解H2的实现逻辑。...
数据库连接通常通过API(应用程序接口)实现,比如在Java中使用JDBC(Java Database Connectivity),在Python中使用DB-API或ORM(对象关系映射)如SQLAlchemy。这些API提供了一套标准的接口,使得开发者能够与各种...
【万能急速扫描器】可能采用了多线程或并发扫描技术,提高了扫描速度,能在短时间内覆盖大量IP地址。 该扫描器可能包含以下特性: 1. 自定义扫描范围:用户可以设置扫描的起始和结束IP,或者选择特定的IP段进行扫描...
“并发扫描”项 - 设置并发扫描的主机和并发线程数,也可以单独为每个主机的各个插件设置最 大线程数。 “网络设置”项 - 设置适合的网络适配器,若找不到网络适配器,请重新安装WinPCap 3.1 beta4 以上版本驱动...
由于多线程/进程会竞争资源,对于扫描出来的一个题目,如果多个评测进程同时去评测,可能会造成死锁,为了防止这种现象,可以使用了生产者-消费者模式,也就是建立一个待评测题目的任务队列,这个队列的生产者作用...
本毕业设计项目旨在实现一个基于特征码监测的病毒扫描器,为用户提供安全的计算机环境。 一、病毒扫描器基础原理 1. 特征码检测:这是传统病毒扫描器最常用的方法,通过对已知病毒的特征码进行比对来识别病毒。...
在Spring Boot中,这通常通过`AbstractRoutingDataSource`实现,它可以基于某些条件(如线程绑定、请求上下文等)来决定使用哪个数据源。 5. **配置文件**: 项目中的配置文件(可能包含application.properties或...
# 然后主线程花些时间(尽管很短)检查连接并且启动一个新线程。back_log值指出在MySQL暂时停止回答新请求之前的短时间内多少个请求可以被存在堆栈中。 # 如果期望在一个短时间内有很多连接,你需要增加它。也就是说,...
- 通过不同的配置文件启动多个 MySQL 实例。 9. **如何加强 MySQL 安全** - 限制用户访问权限、加密传输数据、定期备份等。 10. **Delete 和 Truncate 的区别** - 见上文描述。 11. **MySQL Sleep 线程过多...
网站的应用逐步增多,更新较快,每隔一段时间应 做一次全面检测,若采用传统渗透测试方法,花费昂贵,且往往得不到真正意义上的风险报告。Safe3 Web Vul Scanner使用较为领先的智能化爬虫技术及SQL注入状态检测技术...
- **线程安全性**:`ConcurrentHashMap` 通过内部实现的分段锁机制保证了线程安全。 - **高性能**:通过将整个数据结构分为多个部分(称为“段”或“Segment”),不同的线程可以同时访问不同的段,从而提高并发性能...
适当调低•偏分析型负载或利用率较低的情况:适当调高可以在数据库级别设置覆盖(以上)可以在语句级别设置覆盖性能优化实例级参数(阻塞的监控阈值)超过这个时间长度(秒)的阻塞问题可以通过跟踪记录下来上默认值...
网站的应用逐步增多,更新较快,每隔一段时间应做一次全面检测,若采用传统渗透测试方法,花费昂贵,且往往得不到真正意义上的风险报告。Safe3 Web Vul Scanner使用较为领先的智能化爬虫技术及SQL注入状态检测技术,...
当线程数超过核心线程数时,多余的线程将在空闲一段时间后被销毁。 - **workQueue**:任务队列。用于存放等待执行的任务。根据不同的实现,可以选择无界队列、有界队列或是优先级队列。 - **threadFactory**:线程...
采用多线程方式对指定IP地址段(或单机)进行安全漏洞检测,支持插件功能,提供了图形界面和命令行两种操作方式,扫描内容包括:远程服务类型、操作系统类型及版本,各种弱口令漏洞、后门、应用服务漏洞、网络设备...
功能简介: <br> 采用多线程方式对指定IP地址段(或单机)进行安全漏洞检测,支持插件功能,提供了图形界面和命令行两种操作方式,扫描内容包括:远程服务类型、操作系统类型及版本,各种弱口令漏洞、后门、应用...
这份资源包含了Java基础、多线程、Spring框架、Spring Boot、MySQL数据库、Redis缓存以及消息队列MQ等多个核心知识点,每个部分都涵盖了经典且常见的面试问题。 1. **Java基础篇**: - 内存模型:了解JVM内存结构...
10. **处理新连接**:通过`handle_connections_methods`函数处理新的连接请求,并为每个连接创建一个新的线程进行处理。 #### MySQL会话监听 MySQL服务器通过监听特定端口(默认为3306),等待客户端发起连接请求...
SSM(Spring、SpringMVC、...通过以上步骤,你可以成功地在SSM项目中实现多数据源配置,以适应不同的数据库访问需求。这个过程涉及到Spring的DI、AOP,以及MyBatis的映射机制,对理解和掌握Spring框架有极大的帮助。