Tomcat6.0配置数据源(DBCP)和JNDI使用

[b]在网上搜来的文章,记录下来,方便查找使用【王瑞华-华仔】[/b]

终于把数据源的配置和JDNI 使用的示例给跑通了,于是就总结下,也希望给需要这方面的同事带来方便。
  JNDI : Java Naming and Directory Interface (JNDI)
  JNDI works in concert with other technologies in the Java Platform, Enterprise Edition (Java EE) to organize and locate components in a distributed computing environment.
  翻译:JNDI  在Java平台企业级开发的分布式计算环境以组织和查找组件方式与其他技术协调工作。

  Tomcat 6.0 的数据源配置

  1、在Tomcat中配置:
  tomcat 安装目录下的conf的context.xml 的
  <Context></Context>中
  添加代码如下:
  
<Resource  name="jdbc/tango"
  auth="Container"
  type="javax.sql.DataSource"
  maxActive="20"
  maxIdel="10"
  maxWait="1000"
  username="root"
  password="root"
  driverClassName="com.mysql.jdbc.Driver" 
  url="jdbc:mysql://localhost:3306/tango"
  >
  </Resource>


  其中:
  name 表示指定的jndi名称
  auth 表示认证方式,一般为Container
  type 表示数据源床型,使用标准的javax.sql.DataSource
  maxActive 表示连接池当中最大的数据库连接
  maxIdle 表示最大的空闲连接数
  maxWait 当池的数据库连接已经被占用的时候,最大等待时间
  username 表示数据库用户名
  password 表示数据库用户的密码
  driverClassName 表示JDBC DRIVER
  url 表示数据库URL地址
  示例代码:
  
Context initContext;
  try {
  Context context=new InitialContext();
  DataSource ds=(DataSource) context.lookup("java:/comp/env/jdbc/tango");
  // "java:/comp/env/"是固定写法,后面接的是
  //context.xml中的Resource中name属性的值
  Connection conn = ds.getConnection();
  Statement stmt = conn.createStatement();
  ResultSet set = stmt.executeQuery("SELECT id,name,age FROM user_lzy");
  while(set.next()){
  System.out.println(set.getString("name"));
  }
  //etc.
  } catch (NamingException e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
  } catch (SQLException e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
  }


  同时你需要把你使用的数据驱动jar包放到Tomcat的lib目录下。
  如果你使用其他数据源如DBCP数据源,需要在<Resouce> 标签多添加一个属性如:
factory="org.apache.commons.dbcp.BasicDataSourceFactory"当然你也要把DBCP相关jar包放在tomcat的lib目录下。
  这样的好处是,以后的项目需要这些jar包,可以共享适合于项目实施阶段。
  如果是个人开发阶段一个tomcat下部署多个项目,在启动时消耗时间,同时可能不同项目用到不用数据源带来麻烦。
所以有配置方法2。


  2、在项目的中配置:
  在WebRoot下面建文件夹META-INF,里面建一个文件context.xml,添加内容和 配置1一样同时加上<Resouce> 标签多添加一个属性如:
  factory="org.apache.commons.dbcp.BasicDataSourceFactory"
  示例代码也和配置1一样这样做的:
可以把配置需要jar包直接放在WEB-INF的lib里面 和服务器内容无关总后一点:提醒大家,有个同学可能说 tomacat的有DBCP的jar包,确实tomcat把它放了进去,你就认为不用添加DBCP数据源的jar包,也按照上面的配置,100%你要出错。

  因为tomcat重新打包了相应的jar,你应该把factory="org.apache.commons.dbcp.BasicDataSourceFactory" 改为factory="org.apache.tomcat.dbcp.dbcp.BasicDataSourceFactory"
【无人机】基于改进粒子群算法的无人机路径规划研究[遗传算法、粒子群算法进行比较](Matlab代码实现)内容概要:本文围绕基于改进粒子群算法的无人机路径规划展开研究,重点探讨了在复杂环境中利用改进粒子群算法(PSO)实现无人机三维路径规划的方法,并将其与遗传算法(GA)、标准粒子群算法等传统优化算法进行对比分析。研究内容涵盖路径规划的多目标优化、避障策略、航路点约束以及算法收敛性寻优能力的评估,所有实验均通过Matlab代码实现,提供了完整的仿真验证流程。文章还提到了多种智能优化算法在无人机路径规划中的应用比较,突出了改进PSO在收敛速度全局寻优方面的优势。; 适合人群:具备一定Matlab编程基础优化算法知识的研究生、科研人员及从事无人机路径规划、智能优化算法研究的相关技术人员。; 使用场景及目标:①用于无人机在复杂地形或动态环境下的三维路径规划仿真研究;②比较不同智能优化算法(如PSO、GA、蚁群算法、RRT等)在路径规划中的性能差异;③为多目标优化问题提供算法选型改进思路。; 阅读建议:建议读者结合文中提供的Matlab代码进行实践操作,重点关注算法的参数设置、适应度函数设计及路径约束处理方式,同时可参考文中提到的多种算法对比思路,拓展到其他智能优化算法的研究与改进中。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值