在Linux下配置Tomcat的心得
http://www.2182.cn/bbs/Images/face/3.gif [转帖]在Linux下配置Tomcat的心得在Linux下配置Tomcat的心得
这是刚接触JAVA时写的一个心得,先放上来。
在Linux下配置Tomcat最主要的问题就是配置环境变量。系统环境变量的配置在\etc\profile这个文件中。
Tomcat正常启动需要两个环境变量:JAVA_HOME和CATALINA_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方法错误。
剩下的就是引用类的设置。例如对mysql的jdbc驱动类的引用和连接池的引用。
将需要的jar拷贝到\root\tomcat\common\lib目录下,如servlet.jar、tools.jar和mysql的jdbc连接类。
common目录中的类是Tomcat启动时给所有虚拟目录的jsp使用的类。
但即使common中有需要的类也一定要把jar放置到WEB-INF\lib目录中,这样才能保证jsp正常使用这些类。如果不存在lib,则创建该目录。
之后如果需要Tomcat创建连接池,则需要配置tomcat\conf\server.xml。在添加创建连接池的代码。注意标记一定要在标记之后,否则Tomcat无法启动。
代码如下:
maxActive
100
maxIdle
30
maxWait
10000
removeAbandoned
true
removeAbandonedTimeout
60
logAbandoned
false
factory
org.apache.commons.dbcp.BasicDataSourceFactory
username
root
password
passpass
driverClassName
com.mysql.jdbc.Driver
url
jdbc:mysql://linux01:3306/BASS
红色为原有的标记,蓝色为添加标记。
创建了"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内容就能正常执行了
页:
[1]