边学边谈 ---- Tomcat 6 的配置与部署

Tomcat 6的下载  安装 这里不说了 安装后环境变量会自动添加 最好检查一下 没有的话手动添加 网上很多 这里不赘述。

 

Tomcat 6 的目录结构与之前的版本是不同的,现在很多网上的甚至书上的 都用 5.0、 5.5甚至4.0的目录结构来讲6.0是很不负责任的。

目录结构:

     lib       存放的是jar文件,服务器和所有的web应用程序都可以访问。

     bin: 存放启动、停止服务器的脚本文件;

     conf:存放服务器的配置文件,最重要的是server.xml文件;

     logs: 存放服务器的日志文件;

     temp:存放Tomcat运行时的临时文件;

     webapps:web应用的发布目录;

     work:Tomcat的工作目录,默认情况下把编译JSP文件生成的servlet类文件放于此目录下;

 

建议:tomcat6  配置虚拟目录或数据源 不在conf/server.xml 配置,要独立出来。

 

 

 

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/Catalina/localhost 目录下 建立与工程同名的 XML 文件,里面配置 context,文件内容以 <Context> 开始 ,以 </Context> 结尾。

  添加代码如下:

独立出来之后这个path属性设置什么,访问路径都是XML的名  也就是工程名

<Context path="/JSP_JDBC" docBase="E:/javaworkspace/j2eeworkspace/JSP_JDBC/WebRoot"  reloadable="true">   

    <Resource name="jdbc/myDataSource"

              auth="Container" 

              type="javax.sql.DataSource"

              maxActive="100"

              maxIdle="30"

              maxWait="10000"

              username="root"

              password="root"

              driverClassName="com.mysql.jdbc.Driver"

              url="jdbc:mysql://localhost:3306/test?autoreconnect=true"

     />

</Context>

  其中:

  name 表示指定的jndi名称

  auth 表示认证方式,一般为Container,有Application

  type 表示数据源类型,使用标准的javax.sql.DataSource

  maxActive 表示连接池当中最大的数据库连接

  maxIdle 表示最大的空闲连接数

  maxWait 当池的数据库连接已经被占用的时候,最大等待时间

  username 表示数据库用户名

  password 表示数据库用户的密码

  driverClassName 表示JDBC DRIVER ,根据使用的数据库不同而改变

url 表示数据库URL地址

 

  示例代码:

<%

 

 try{

  Connection con=null;

  Statement stat=null;

  ResultSet rs =null;

 

  Context ctx=new InitialContext();

  DataSource ds=(DataSource)ctx.lookup("java:comp/env/jdbc/myDataSource");

  con=ds.getConnection();

 

  stat=con.createStatement();

 

  String sql="select * from mytest";

 

  rs=stat.executeQuery(sql);

 

  while(rs.next()){

     out.println("<li>Col1: "+rs.getInt(1));

     out.println("<li>Col1: "+rs.getString(2));

  } 

  rs.close();

  stat.close();

  con.close();

  } catch (NamingException ne) {

    // TODO Auto-generated catch block

    ne.printStackTrace();

  } catch (SQLException se) {

    // TODO Auto-generated catch block

    se.printStackTrace();

  } 

 %>

  同时需要把使用的数据驱动jar包放到Tomcatlib目录下。

 

  如果你使用其他数据源如DBCP数据源,需要在<Resouce 标签多添加一个属性如

   factory="org.apache.commons.dbcp.BasicDataSourceFactory"   来指定数据源工厂类名

当然你也要把DBCP相关jar包放在tomcatlib目录下。

 

  这样的好处是,以后的项目需要这些jar包,可以共享适合于项目实施阶段。

  

    如果是个人开发阶段一个tomcat下部署多个项目,在启动时消耗时间,同时可能不同项目用到不同数据源带来麻烦。所以有配置方法2

 

  2.在项目的中配置:

  在WebRoot下面建文件夹META-INF,里面建一个文件context.xml

 

  添加内容和 配置1一样

 

  同时加上<Resouce 标签 多添加一个属性如

 

    factory="org.apache.commons.dbcp.BasicDataSourceFactory"

 

  示例代码也和配置1一样

 

  这样做的:可以把配置需要jar包直接放在WEB-INFlib里面 和服务器内容无关

 

  总后一点:提醒大家,使用tomacatDBCPjar包,确实tomcat把它放了进去,可是认为不用添加DBCP数据源的jar包,也按照上面的配置,100%要出错。

  因为tomcat重新打包了相应的jar,应该把 

  factory="org.apache.commons.dbcp.BasicDataSourceFactory"

     改为

  factory="org.apache.tomcat.dbcp.dbcp.BasicDataSourceFactory" 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值