当前位置: 首页 > news >正文

网站建设属于什么领域阿里巴巴国际站买家入口

网站建设属于什么领域,阿里巴巴国际站买家入口,0基础学平面设计要多久,视频剪辑怎么自学数据库连接是个耗时操作.对数据库连接的高效管理影响应用程序的性能指标. 数据库连接池正是针对这个问题提出来的. 数据库连接池负责分配,管理和释放数据库连接.它允许应用程序重复使用一个现有的数据路连接,而不需要每次重新建立一个新的连接,利用数据库连接池将明显提升对数…数据库连接是个耗时操作.对数据库连接的高效管理影响应用程序的性能指标. 数据库连接池正是针对这个问题提出来的. 数据库连接池负责分配,管理和释放数据库连接.它允许应用程序重复使用一个现有的数据路连接,而不需要每次重新建立一个新的连接,利用数据库连接池将明显提升对数据库操作的性能. 数据库连接池技术方案: 1.C3P0 2.DBCP 3.Proxool 4.Tomcat jdbc Oppl 5.BoneCP 6.Druid 7.HikariCP 数据库连接池属于一种池化技术: 常见的有:http访问(httpclient),redis访问(redisPool),线程(线程池)等 新建个空项目 可能是版本原因idea创建空项目总要重启一下 设置下maven和encoding 新建模块 DataSource是JDK里的规范,用来专门放连接的.是一个连接工厂 自定义一个接口 里面需要实现的两个方法是:  其他的父接口的其他方式可以暂时不管 这样基础结构就有了 package com.pool;import java.sql.Connection; import java.sql.DriverManager; import java.sql.SQLException;/*** author hrui* date 2023/9/10 3:06*/ public class MyAbstractDataSource implements MyDataSourceInterface{private String url;private String driver;private String username;private String password;//最大的连接数量private int poolMaxActiveConnection10;//最大空闲连接数private int poolMaxIdIeConnection5;//当连接都在使用时候,最大检出时间(等待时间),毫秒private int poolTimeToWait20000;public int getPoolMaxActiveConnection() {return poolMaxActiveConnection;}public void setPoolMaxActiveConnection(int poolMaxActiveConnection) {this.poolMaxActiveConnection poolMaxActiveConnection;}public int getPoolMaxIdIeConnection() {return poolMaxIdIeConnection;}public void setPoolMaxIdIeConnection(int poolMaxIdIeConnection) {this.poolMaxIdIeConnection poolMaxIdIeConnection;}public int getPoolTimeToWait() {return poolTimeToWait;}public void setPoolTimeToWait(int poolTimeToWait) {this.poolTimeToWait poolTimeToWait;}public String getUrl() {return url;}public void setUrl(String url) {this.url url;}public String getDriver() {return driver;}public void setDriver(String driver) {this.driver driver;}public String getUsername() {return username;}public void setUsername(String username) {this.username username;}public String getPassword() {return password;}public void setPassword(String password) {this.password password;}Overridepublic Connection getConnection() throws SQLException {return getConnection(username,password);}Overridepublic Connection getConnection(String username, String password) throws SQLException {return doGetConnection(username,password);}private Connection doGetConnection(String username, String password) throws SQLException {Connection connection DriverManager.getConnection(url, username, password);return connection;} }上面三个方法,都是获得连接 下面用动态代理方式实现对数据库连接的代理 package com.pool;import java.lang.reflect.InvocationHandler; import java.lang.reflect.Method; import java.lang.reflect.Proxy; import java.sql.Connection;/*** 采用动态代理实现对数据库连接的代理* author hrui* date 2023/9/10 3:45*/ public class ConnectionProxy implements InvocationHandler {//真正连接private Connection realConnection;//代理连接private Connection proxyConnection;//数据源对象private MyDataSource myDataSource;public ConnectionProxy(Connection realConnection, MyDataSource myDataSource) {//初始化真实连接和数据源this.realConnection realConnection;this.myDataSource myDataSource;//初始化代理连接...需要一个代理对象 JDK动态代理this.proxyConnection (Connection)Proxy.newProxyInstance(Connection.class.getClassLoader(),new Class?[]{Connection.class},this);}public Connection getRealConnection() {return realConnection;}public void setRealConnection(Connection realConnection) {this.realConnection realConnection;}public Connection getProxyConnection() {return proxyConnection;}public void setProxyConnection(Connection proxyConnection) {this.proxyConnection proxyConnection;}public MyDataSource getMyDataSource() {return myDataSource;}public void setMyDataSource(MyDataSource myDataSource) {this.myDataSource myDataSource;}/*** 当调用Connection对象里面的任何方法时,该方法会进行拦截* 主要目的为了拦截Connection的close方法,当关闭时进行拦截,将Connection对象放入连接池中* 其他方法无需拦截* param proxy* param method* param args* return* throws Throwable*/Overridepublic Object invoke(Object proxy, Method method, Object[] args) throws Throwable {//获取当前调用了Connection对象的什么方法String methodNamemethod.getName();if(methodName.equals(close)){//TODO 把连接放入连接池return null;}else{//其他方法return method.invoke(realConnection, args);}} }} 下面写个类继承MyAbstractDataSource  在里面放入连接池 package com.pool;import java.sql.Connection; import java.sql.SQLException; import java.util.ArrayList; import java.util.List;/*** 数据源连接池* author hrui* date 2023/9/10 4:15*/ public class MyDataSource extends MyAbstractDataSource{//空闲连接private final ListConnectionProxy idleConnectionsnew ArrayList();//激活的连接池private final ListConnectionProxy activeConnectionsnew ArrayList();//下面三个可以抽取放到父类抽象类中,由用户配置 //最大的连接数量//private int poolMaxActiveConnection10;//最大空闲连接数//private int poolMaxIdIeConnection5;//当连接都在使用时候,最大检出时间(等待时间),毫秒//private int poolTimeToWait20000;//用于同步监视器对象private final Object monitornew Object();//用于同步监视器对象(关闭)//private final Object watchnew Object();/*** 重写:用于获取代理连接* return* throws SQLException*/Overridepublic Connection getConnection() throws SQLException {ConnectionProxy connectionProxygetConnectionProxy(super.getUsername(),super.getPassword());//返回代理连接return super.getConnection();}/*** 获取代理连接* param username* param password* return*/private ConnectionProxy getConnectionProxy(String username,String password) throws SQLException {//TODO//是否需要等待boolean waitfalse;ConnectionProxy connectionProxynull;//刚开始没有连接while(connectionProxynull){synchronized (monitor){//看连接池有没有空闲连接,如果不为空,直接获取连接if(!idleConnections.isEmpty()){connectionProxyidleConnections.remove(0);//如果是空的}else{//没有空闲连接,那么需要获取新的连接(创建连接)//这里先判断最大连接数是不是小于配置数量 10if(activeConnections.size()supper.getPoolMaxActiveConnection()){//创建新连接 需要传入真实连接connectionProxynew ConnectionProxy(super.getConnection(),this);}//否则需要等待20秒 上面定义了poolTimeToWait20000}}if(!wait){waittrue;}if(connectionProxynull){try {monitor.wait(supper.getPoolTimeToWait());} catch (InterruptedException e) {e.printStackTrace();//万一等待被线程打断,退出一下break;}}}if(connectionProxy!null){//连接对象不是空,说明已经拿到连接了,放入容器activeConnections.add(connectionProxy);}return connectionProxy;}//用于关连接//不是把连接关系,而是还给连接池public void closeConnection(ConnectionProxy connectionProxy){synchronized (monitor){//最大连接(激活连接)里删除activeConnections.remove(connectionProxy);//如果空闲连接定义的数量则放入空闲连接if(idleConnections.size()supper.getPoolMaxIdIeConnection()){idleConnections.add(connectionProxy);}//通知一下,唤醒上面哪个等待获取连接的线程monitor.notify();}} }那么代理对象中把连接还给连接池的方法也有了 就是当所有连接用完了,等待20秒的逻辑没写 下面测试自己写的连接池 新建模块  引入依赖 不想玩了
http://www.hkea.cn/news/14363171/

相关文章:

  • 网站连接跳转怎么做电子商务网站建设的认识
  • 秦皇岛金洋建设集团网站网站设计主题中文
  • asp.net 网站管理系统郑州做网站好
  • 扩展名网站架设一个网站
  • 沈阳专业做网站策划方案范文
  • 驻马店住房和城乡建设局网站能播放优酷视频的网站怎样做
  • 网站开发的外文翻译网络广告发布
  • 环保工程 技术支持 东莞网站建设wordpress需要ftp登录
  • 商务网站开发公司wordpress登录后搜索
  • 俄语在线网站制作google云平台 wordpress
  • 网站开发技术的发展流程网站建设阿里云
  • 网站设计需要需要用吴忠市住房和城乡建设局网站
  • 泗洪建设局网站关键词优化公司兴田德润优惠吗
  • 男男床做视频网站加强局网站建设
  • 如何关闭网站 备案磁力蜘蛛种子搜索
  • 局域网网站生活用品创新设计方案
  • 免费网站模板 百度一下心理咨询网站建设
  • 网站建设策划书模板深圳知名企业
  • 小型手机网站建设电子商务网站开发与实训答案
  • 选择佛山网站设计Sql 发wordpress
  • 软件免费下载的网站大全天河建网站的公司
  • 公司网站推广是做什么北京网首页
  • 少儿美术网站建设方案临平建设局网站
  • 如何做求职招聘网站河南省建设监理协会网站证书查询
  • 哈尔滨高端网站设计六安网站优化
  • 建设电影网站点击播放是乱页的个人网页制作完整教程
  • 自建网站推广方式久久建筑网账号
  • 柯林建站程序寒假网页设计培训珿
  • 燕郊 网站开发怎么做可以把网站图片保存下来吗
  • 备案不关闭网站为自己家秘方做网站