设为首页 收藏本站
查看: 533|回复: 0

[经验分享] 边学边谈 ---- Tomcat 6 的配置与部署

[复制链接]

尚未签到

发表于 2017-2-3 06:17:06 | 显示全部楼层 |阅读模式
  转自:
  http://blog.csdn.net/jwhndsc/archive/2010/03/24/5410533.aspx
  
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" 

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-336685-1-1.html 上篇帖子: Tomcat配置多域名绑定和虚拟目录 下篇帖子: server2003一台服务器配置多个tomcat和集群
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表