在Linux下配置Tomcat的心得

  这是刚接触JAVA时写的一个心得,先放上来。


Linux下配置Tomcat最主要的问题就是配置环境变量。系统环境变量的配置在\etc\profile这个文件中。

Tomcat正常启动需要两个环境变量:JAVA_HOMECATALINA_HOME

JAVA_HOME指向JAVA的安装目录。例如JAVA_HOME=usr\java\j2sdk

CATALINA_HOME等同于TOMCAT_HOME这个变量,在Linux下设置CATALINA_HOME即可。例如CATALINA_HOME=\root\tomcat

然后在export命令后面添加 JAVA_HOME CATALINA_HOME即可。

 

设置如下:

JAVA_HOME=\usr\java\j2sdk

CATALINA_HOME=\root\tomcat

 

Export PATH JAVA_HOME CATALINA_HOME

 

这两个变量设置后,重新启动系统,Tomcat就可以正常启动了。Tomcat示例正常执行。

虽然示例能够正常执行,但是如果是自己写的jsp,会报页面异常的错误,错误提示大概是在-1行有错误。

这时如果用session.setAttribute("param","value");会出现错误提示,提示setAttribute方法找不到。

这是因为系统变量中没有设置java命令的执行地址。

 

\etc\profile中,将java命令的地址添加到PATH环境变量中。

PATH=\usr\java\j2sdk\bin:$PATH

 

配置时一定注意PATH=后面要带:$PATH,否则PATH环境变量没有保留原有值,进而使Linux系统无法正常登录。

 

设置如下:

JAVA_HOME=\usr\java\j2sdk

CATALINA_HOME=\root\tomcat

PATH=\usr\java\j2sdk\bin:$PATH

Export PATH JAVA_HOME CATALINA_HOME

 

重新启动系统,在终端中执行java命令,出现java帮组,则大功告成。jsp页面也不会再提示setAttribute方法错误。

 

剩下的就是引用类的设置。例如对mysqljdbc驱动类的引用和连接池的引用。

将需要的jar拷贝到\root\tomcat\common\lib目录下,如servlet.jartools.jarmysqljdbc连接类。

common目录中的类是Tomcat启动时给所有虚拟目录的jsp使用的类。

 

但即使common中有需要的类也一定要把jar放置到WEB-INF\lib目录中,这样才能保证jsp正常使用这些类。如果不存在lib,则创建该目录。

 

之后如果需要Tomcat创建连接池,则需要配置tomcat\conf\server.xml。在<host></host>添加创建连接池的代码。注意<Context></Context>标记一定要在<Logger/>标记之后,否则Tomcat无法启动。

 

代码如下:

<Host appBase="webapps" name="localhost">

<Logger className="org.apache.catalina.logger.FileLogger" prefix="localhost_quality_log." suffix=".txt" timestamp="true"/>

<Context path="/bass" docBase="bass" debug="0" reloadable="true" crossContext="true">

<Resource name="jdbc/mysql" auth="Container" type="javax.sql.DataSource"/>

<ResourceParams name="jdbc/mysql">

<parameter>

<name>maxActive</name>

<value>100</value>

</parameter>

<parameter>

<name>maxIdle</name>

<value>30</value>

</parameter>

<parameter>

<name>maxWait</name>

<value>10000</value>

</parameter>

<parameter>

<name>removeAbandoned</name>

<value>true</value>

</parameter>

<parameter>

<name>removeAbandonedTimeout</name>

<value>60</value>

</parameter>

<parameter>

<name>logAbandoned</name>

<value>false</value>

</parameter>

<parameter>

<name>factory</name>

<value>org.apache.commons.dbcp.BasicDataSourceFactory</value>

</parameter>

<parameter>

<name>username</name>

<value>root</value>

</parameter>

<parameter>

<name>password</name>

<value>passpass</value>

</parameter>

<parameter>

<name>driverClassName</name>

<value>com.mysql.jdbc.Driver</value>

</parameter>

<parameter>

<name>url</name>

<value>jdbc:mysql://linux01:3306/BASS</value>

</parameter>

</ResourceParams>

</Context>

</Host>

红色为原有的标记,蓝色为添加标记。

创建了"jdbc/mysql"Context对象,在jsp中对它进行初始化就可以创建Connection了。

 

jsp中创建连接的代码如下:

public static void ContextInitial()

{

try

{

ctx = new InitialContext();

if(ctx == null)

{

throw new Exception("没有匹配的环境");

}

}

catch(Exception e)

{

is_initial = false;

if(ctx != null)

{

try

{

ctx.close();

}

catch(Exception ee)

{

}

}

}

 

public static Connection getConn()

{

Connection conn = null;

try

{

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

if (ds == null)

{

throw new Exception("没有匹配数据库");

}

conn = ds.getConnection();

return conn;

}

catch(Exception e)

{

if(conn != null)

{

try

{

conn.close();

}

catch(SQLException ee)

{

conn = null;

}

}

return null;

}

}

 

需要注意的是获得的是个Connection而不是ConnectionPool

而且连接池只需要一次初始化,不多多吃初始化会造成数据库崩溃。在执行初始化方法前创建一个boolean静态变量检查是否已经进行过初始化。

Tomcat重新启动之后连接池会自动断掉,需要重新初始化。

 

 

重新启动Tomcat,这样jsp内容就能正常执行了。

 

远飞

2004225

posted on 2004-11-19 09:15  远飞  阅读(1324)  评论(0)    收藏  举报

导航