Ubuntu 7.04 搭建JSP开发环境
MySQL+tomcat+apache+j2sdk1.6

在所有安装开始前先在Terminal中输入 rpm -q -a查看是否安装过rpm 和 rpm包的所需软件
如果没有安装rpm在Terminal中输入 sudo apt-get install rpm

一.安装MySQL

sudo apt-get install mysql-server
以root身份启动mysql服务 : /etc/init.d/mysql start
以root身份停止mysql服务 : /etc/init.d/mysql stop
启动mysql: mysql -u root -p
password

二.安装 j2sdk

1.下载jdk安装文件
到 SUN 的网站 里的 download 下载 j2sdk 最新版本:
http://java.sun.com/javase/downloads/netbeans.html
这次下载的是 jdk-6u1-linux-i586.bin
下载到了用户文件夹: 即 Places下拉框中的homefolder (/home/jinye)

2.安装jdk文件
在Terminal中输入 ./jdk-6u1-linux-i586.bin
在一长串协议说明后会询问你同不同意协议,敲入y 回车开始安装
安装后的文件夹名为 jdk1.6.0_01

3.为JDK建立连接
ln -s jdk1.6.0.0_01 jdk

三.安装tomcat

1.下载tomcat安装文件
在网站http://tomcat.apache.org中下载 tomcat
可以选择下载源代码或是二进制文件, 这次下载的是压缩二进制文件 apache-tomcat-6.0.13.tar.gz

2.解压安装tomcat
tar zxf apache-tomcat-6.0.13.tar.gz
在现目录下会出现解压后的文件夹 apache-tomcat-6.0.13

3.为Tomcat建立连接
ln -s apache-tomcat-6.0.13 tomcat

四.配置环境变量

在 /etc/profile 的最后加入如下内容后, 在系统中运行一下(重启主机)
PATH=$PATH:/home/jinye/jdk/bin:/home/jinye/jdk/jre/bin
JAVA_HOME=/home/jinye/jdk
Export JAVA_HOME
CLASSPATH="./:/home/jinye/jdk/lib:/home/jinye/jdk/jre/lib"
Export CLASSPATH
CATALINA_HOME=/home/jinye/tomcat
Export CATALINA_HOME

五.下载安装配置Apache服务器

1.安装
sudo apt-get install apache2

2.Apache2与tomcat6的整合

sudo install libapache2-mod-jk
查看一下在apache2的启动模块中是否有jk.load
sudo ls /etc/apache2/mods-enabled/
cgi.load mod-security.conf php5.conf proxy.conf rewrite.load userdir.load
jk.load mod-security.load php5.load proxy.load userdir.conf

修改workers.properties文件将tomcat_home 和 java_home 地址修改为上面安装jdk 和tomcat 的地址
sudo gedit /etc/libapache2-mod-jk/workers.properties
workers.tomcat_home=/home/jinye/tomcat
workers.java_home=/home/jinye/jdk

配置/etc/apache2/apache2.conf
将#sudo gedit /usr/share/doc/libapache2-mod-jk/httpd_example_apache2.conf里面的内容
复制到apache2.conf最后

sudo /etc/init.d/apache2 restart
sudo /usr/share/tomcat6/bin/./shutdown.sh
sudo /usr/share/tomcat6/bin/./startup.sh
sudo gedit /etc/rc.local
修改JDK_HOME 和JAVA_HOME 地址
export JDK_HOME=/home/jinye/jdk
export JAVA_HOME=/home/jinye/jdk

sudo gedit /etc/apache2/httpd.conf
打开httpd.conf文件,在该文件中添加如下人代码:
LoadModule jk_module /usr/lib/apache2/modules/mod_jk.so
JkWorkersFile "/etc/libapache2-mod-jk/workers.properties"
JkLogFile "/var/log/apache2/mod_jk.log"
JkLogLevel info
JkLogStampFormat "[%a %b %d %H:%M:%S %Y] "
JkMount /*.jsp ajp13_worker
JkMount /*/servlet/ ajp13_worker

打开http://localhost/index.jsp
看到apache tomcat 主页说明安装和整合成功

*注意***********************************************************
JkMount /*.jsp ajp13_worker
JkMount /*/servlet/ ajp13_worker
中的两个 “ajp13_worker” 是在文件/etc/libapache2-mod-jk/workers.properties中下面几行没有被注释掉的部分中出现的:

worker.list=ajp13_worker
worker.ajp13_worker.port=8009
worker.ajp13_worker.host=localhost
worker.ajp13_worker.type=ajp13
worker.ajp13_worker.lbfactor=1
worker.loadbalancer.balanced_workers=ajp13_worker

在修改/etc/apache2/httpd.conf时要注意保持相同
**************************************************************

六.在jsp中使用JDBC来连接MySQL数据库

1.下载JDBC驱动程序
www.mysql.com/downloads/中寻找connectors, 然后网页左侧有connector/J 点击会出现供选择的tar.gz和zip文件下载
下载.tar.gz文件

2.展开刚刚下载的文件(mysql-connector-java-5.0.6.tar.gz)
tar zxvf mysql-connector-java-5.0.6.tar.gz

3.配置连接文件
将刚刚展开的mysql-connector-java-5.0.6 中的mysql-connector-java-5.0.6-bin.jar文件拷贝到上面安装的jdk 和 tomcat下的lib文件夹中
cd mysql-connector-java-5.0.6
cp ./mysql-connector-java-5.0.6-bin.jar ~/jdk/lib
cp ./mysql-connector-java-5.0.6-bin.jar ~/tomcat/lib

4.在编写jsp过程中连接数据库可以用以下格式:
Class.forName("com.mysql.jdbc.Driver").newInstance();
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost/数据库名","用户名","密码");
Statement stmt = conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE);
String sql = "select * from 数据库名";
ResultSet rs = stmt.executeQuery(sql);

****注意: linux下的jsp文件中 中文输出有时为乱码,可以用在jsp文件中加入 <%@ page c %>*****


七.测试
sudo -sh
password

启动 mysql 服务:
#/etc/init.d/mysql start

启动tomcat 服务:
#/home/tomcat/bin/startup.sh

创建测试用的数据库和表:
#/mysql -u root -p
password

mysql> create database test;
mysql> use test;
mysql> create table test (test1 VARCHAR(20), test2 VARCHAR(20));
mysql> insert into test (test1,test2) values ('a','b');

//检查是否已经加入测试信息
mysql> show databases;
mysql> show tables;
mysql> select * from test;

在/home/jinye/tomcat/webapps/ROOT下创建一个新的空文件,起名为test.jsp,写入代码
测试程序代码如下:
//------------------------------------------------------------------------
<%@ page c%>
<%@ page import="java.util.*"%>
<%@ page import="java.sql.*"%>



<%

Class.forName("com.mysql.jdbc.Driver").newInstance();
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost/test","root","666nnn");
Statement stmt = conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE);
String sql = "select * from test";
ResultSet rs = stmt.executeQuery(sql);

while(rs.next()){ %>

您的第一个字段内容为:<%=rs.getString(1)%>
您的第二个字段内容为:<%=rs.getString(2)%>
<%}%>
<%out.print("数据库操作成功,恭喜您");%>
<% rs.close();
stmt.close();
conn.close();
%>


//-------------------------------------------------------------------------


打开firefox浏览器,输入网址: http://localhost:8080/test.jsp 看到刚才在命令行中创建的测试表中的信息。