Tomcat-5.5.20下配置MySQL-5.0.27的数据库连接池(二)

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:

五、现在还没有配置好连接池,需要一个实际的Web应用例子来测试

1、  在数据zfvims上建立表bookssql如下
 
CREATE TABLE `books` (
  `id` varchar(8) NOT NULL,
  `name` varchar(24) default NULL,
  `title` varchar(96) default NULL,
  `price` float default NULL,
  `yr` int(11) default NULL,
  `description` varchar(30) default NULL,
  `saleAmount` int(11) default NULL,
  PRIMARY KEY  (`id`))
并插入数据:
insert into `books` values ('201','王芳','Java编程指南',33.75,1999,'让读者轻轻松松掌握Java语言',1000),('202','张丙','Weblogic技术参考',45.99,2002,'真的不错耶',2000),('203','孙艳','Oracle数据库教程',40,2003,'关于Oracle的最畅销的技术书',2000),('204','大卫','OakJava: 语言的革命',20.75,1998,'很值得一看',2000),('205','阿明','Apache从入门到精通',50.75,2002,'权威的Apache技术资料',2000),('206','洪军','Java与数据算法 ',54.75,2002,'权威的Java技术资料',2000);
 
2、  建立一个最简单的web应用,就包含两个文件:web.xmltestds.jsp,打成war包,内容分别如下:
web.xml
---------------------------------------------------------------------------------------------------
<?xml version="1.0" encoding="UTF-8"?>
 
<!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/dtd/web-app_2_3.dtd">
<web-app>
 
    <welcome-file-list>
        <welcome-file>test.jsp</welcome-file>
    </welcome-file-list>
</web-app>
---------------------------------------------------------------------------------------------------
testds.jsp
---------------------------------------------------------------------------------------------------
<%--
  Created by IntelliJ IDEA.
  FileName: FileName.jap 
  User:     LavaSoft
  Date:      2006-11-23
  Time:     0:41:43
  ReadMe:   测试tomcat数据源
--%>
 
<!--首先导入一些必要的packages-->
<%@ page import="java.io.*" %>
<%@ page import="java.util.*" %>
<%@ page import="java.sql.*" %>
<%@ page import="javax.sql.*" %>
<%@ page import="javax.naming.*" %>
<%@ page import="com.mysql.jdbc.Connection" %>
<!--设置中文输出-->
<%@ page contentType="text/html; charset=GBK" %>
 
 
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=GBK" />
 
    <title>DbJsp1.jsp</title>
</head>
<body>
<%
    //try开始
    try {
        java.sql.Connection con;
        Statement stmt;
        ResultSet rs;
 
//建立数据库连接
        Context ctx = new InitialContext();
        DataSource ds = (DataSource) ctx.lookup("java:comp/env/jdbc/zfvimsds");
        con = ds.getConnection();
//创建一个JDBC声明
        stmt = con.createStatement();
//增加新记录
        stmt.executeUpdate("INSERT INTO books (id,name,title,price) VALUES ('999','Tom','Tomcat Bible',44.5)");
//查询记录
        rs = stmt.executeQuery("SELECT id,name,title,price from books");
//输出查询结果
        out.println("<table border=1 width=400>");
        while (rs.next()) {
            String col1 = rs.getString(1);
            String col2 = rs.getString(2);
            String col3 = rs.getString(3);
            float col4 = rs.getFloat(4);
 
//convert character encoding
            col1 = new String(col1.getBytes("ISO-8859-1"), "GB2312");
            col2 = new String(col2.getBytes("ISO-8859-1"), "GB2312");
            col3 = new String(col3.getBytes("ISO-8859-1"), "GB2312");
 
//打印所显示的数据
            out.println("<tr><td>" + col1 + "</td><td>" + col2 + "</td><td>" + col3 + "</td><td>" + col4 + "</td></tr>");
        }
        out.println("</table>");
 
//删除新增加的记录
        stmt.executeUpdate("DELETE FROM books WHERE id='999'");
 
//关闭数据库连结
        rs.close();
        stmt.close();
        con.close();
    }
 
//捕获错误信息
    catch (Exception e) {
        out.println(e.getMessage());
    }
 
%>
</body>
</html>
---------------------------------------------------------------------------------------------------
3、  打成wartestweb.war,复制到E:\myserver\apache-tomcat- 5.5.20 \webapps下面,然后启动tomcat,然后再关闭,然后会发现在E:\myserver\apache-tomcat-5.5.20\conf\Catalina\localhost下面多了一个testweb.xml文件,将此文件打开,内容如下:
--------------------------------------------------------------------------------------------------
<?xml version="1.0" encoding="UTF-8"?>
<Context path="/">
</Context>
--------------------------------------------------------------------------------------------------
4、  修改这个生成的文件,方法是将(四-4)部分里面生成的连接池配置信息复制到这个文件里面,完成后如下:
--------------------------------------------------------------------------------------------------
<?xml version="1.0" encoding="UTF-8"?>
<Context path="/">
  <Resource
    name="jdbc/zfvimsds"
    type="javax.sql.DataSource"
    driverClassName="com.mysql.jdbc.Driver"
    password="leizhimin"
    maxIdle="2"
    maxWait="5000"
    username="zfvims"
    url="jdbc:mysql://127.0.0.1/zfvims"
    maxActive="4"/>
</Context>
--------------------------------------------------------------------------------------------------
 
5、  然后保存,打开[url]http://127.0.0.1:8080/testweb/[/url],如下图所示,说明连接池配置成功。
 
 
六、后记,其中有些需要特别说明的部分如下:
1、  我在tomcat- 5.0.28 5.5.20上都做类似的配置,发现两个生成的server.xml差异比较大,其中5.5生成的格式更简练一些。
2、  tomcat数据源在java程序中的访问必须为java:comp/env/jdbc/zfvimsds这样的格式,其中红色部分java:comp/env/是固定的写法,蓝色部分jdbc/zfvimsds是数据源的JNDI名字。
3、  另外Tomcat与集成开发环境IDE之间应用还有很多技巧,本人尤为推荐Idea5.12,最好用的java开发工具。


本文转自 leizhimin 51CTO博客,原文链接:http://blog.51cto.com/lavasoft/10483,如需转载请自行联系原作者
相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
打赏
0
0
0
0
265
分享
相关文章
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】数据库一主一备部署及一主两备部署时,主备手动切换方法及自动切换配置
【YashanDB知识库】数据库一主一备部署及一主两备部署时,主备手动切换方法及自动切换配置
【YashanDB知识库】数据库一主一备部署及一主两备部署时,主备手动切换方法及自动切换配置
docker拉取MySQL后数据库连接失败解决方案
通过以上方法,可以解决Docker中拉取MySQL镜像后数据库连接失败的常见问题。关键步骤包括确保容器正确启动、配置正确的环境变量、合理设置网络和权限,以及检查主机防火墙设置等。通过逐步排查,可以快速定位并解决连接问题,确保MySQL服务的正常使用。
202 82
YashanDB异构数据库链接配置
本指南介绍在YashanDB中配置异构数据库链接(DBLINK)的方法,特别是连接至Oracle数据库的前置要求与步骤。需确保YashanDB服务端安装plugin插件包、Oracle Instant Client及libaio库,否则可能导致错误或进程崩溃。文档还提供了Oracle Instant Client和libaio库的具体安装指导,帮助管理员顺利完成配置。
YashanDB数据库服务端SSL连接配置
YashanDB支持通过SSL连接确保数据传输安全,需在服务端生成根证书、服务器证书及DH文件,并将根证书提供给客户端以完成身份验证。服务端配置包括使用OpenSSL工具生成证书、设置SSL参数并重启数据库;客户端则需下载根证书并正确配置环境变量与`yasc_env.ini`文件。注意:启用SSL后,所有客户端必须持有根证书才能连接,且SSL与密码认证独立运行。
缓存与数据库的一致性方案,Redis与Mysql一致性方案,大厂P8的终极方案(图解+秒懂+史上最全)
缓存与数据库的一致性方案,Redis与Mysql一致性方案,大厂P8的终极方案(图解+秒懂+史上最全)
从 MySQL 到时序数据库 TDengine:Zendure 如何实现高效储能数据管理?
TDengine 助力广州疆海科技有限公司高效完成储能业务的数据分析任务,轻松应对海量功率、电能及输入输出数据的实时统计与分析,并以接近 1 : 20 的数据文件压缩率大幅降低存储成本。此外,taosX 强大的 transform 功能帮助用户完成原始数据的清洗和结构优化,而其零代码迁移能力更实现了历史数据从 TDengine OSS 与 MySQL 到 TDengine 企业版的平滑迁移,全面提升了企业的数据管理效率。本文将详细解读这一实践案例。
34 0
Docker Compose V2 安装常用数据库MySQL+Mongo
以上内容涵盖了使用 Docker Compose 安装和管理 MySQL 和 MongoDB 的详细步骤,希望对您有所帮助。
235 42
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等