在客户端请求的数据量比较大的时候,使用线程池可以节约大量的系统资源,节约了大量的CPU和内存。而数据库的连接池的使用将大大的提高程序运行的效率,
线程池的原理:
线程池的原理,类似于操作系统中的缓存区,先创建若干数量的线程,让这些线程处于休眠状态,当客户有请求,就唤醒线程池中的一个线程,处理请求。在高并发的情况下,如果采用使用一个创建一个线程会极大的消耗内存资源,直接采用线程池的减少系统不断的创建和销毁线程。
数据库连接池
数据库的连接数是非常珍贵的资源,所以在程序启动的时候创建足够多的数据库连接,并把这些连接组成一个连接池(在一个池中放了很多半成品的数据库连接对象),由应用程序动态地对池中的连接进行申请、使用和释放。对于多于连接池中连接数的并发请求,应该在请求队列中排队等待。并且应用程序可以根据池中连接的使用率,动态增加或减少池中的连接数。

连接池技术尽可能多地重用了消耗内存地资源,大大节省了内存,提高了服务器地服务效率,能够支持更多的客户服务。通过使用连接池,将大大提高程序运行效率,同时,我们可以通过其自身的管理机制来监视数据库连接的数量、使用情况等。

1)最小连接数是连接池一直保持的数据库连接,所以如果应用程序对数据库连接的使用量不大,将会有大量的数据库连接资源被浪费;

2)最大连接数是连接池能申请的最大连接数,如果数据库连接请求超过此数,后面的数据库连接请求将被加入到等待队列中,这会影响之后的数据库操作。

MySQL连接池有Tomcat、Jboss、c3p0、Druid