"Continuous effort - not strength or intelligence - is the key to unlocking our potential" - Winston Churchill
Saturday, February 28, 2009
What is a Servlet and a Servlet Container ?
Web Servers , Web Containers & Application Servers
Web Servers
Web Servers accept http requests from the clients and serve them with http responses.
A web application runs within the web container of a web server.
Eg: Apache
Web Containers
Web Containers provide an environment to run Servlets and JSPs. It implements the web component contract of the J2EE architecture which specifies a runtime environment for web components that includes security, concurrency, life-cycle management, transaction, deployment, and other services.
At the beginning tomcat was just a servlet container and was not able to handle web requests on its own. It was also much slower and was not able to support heavy traffic production environments and it did not support SSL. As a result it was used in conjunction with the Apache web server to gain higher performance and security.
Over time Tomcat was improved as a standalone web server and running it alone was faster or just as fast as running it in conjunction with Apache Web Server.The current tomcat also has full support for SSL.
Eg: Tomcat
Application Servers
Application Servers provide a J2EE platform for the development, deployment, and management of enterprise applications. It provides an applet container, a Web container, and an EJB container.
Eg: JBOSS , Websphere
Sunday, February 22, 2009
List of JDBC Drivers
IBM DB2
jdbc:db2://HOST:PORT/DB
COM.ibm.db2.jdbc.app.DB2Driver
jdbc:odbc:DB
sun.jdbc.odbc.JdbcOdbcDriver
Microsoft SQL Server
jdbc:weblogic:mssqlserver4:DB@HOST:PORT
weblogic.jdbc.mssqlserver4.Driver
Oracle Thin
jdbc:oracle:thin:@HOST:PORT:SID
oracle.jdbc.driver.OracleDriver
PointBase Embedded Server
jdbc:pointbase://embedded[:PORT]/DB
com.pointbase.jdbc.jdbcUniversalDriver
Cloudscape
jdbc:cloudscape:DB
COM.cloudscape.core.JDBCDriver
Cloudscape RMI
jdbc:rmi://HOST:PORT/jdbc:cloudscape:DB
RmiJdbc.RJDriver
Firebird (JCA/JDBC Driver)
jdbc:firebirdsql:[//HOST[:PORT]/]DB
org.firebirdsql.jdbc.FBDriver
IDS Server
jdbc:ids://HOST:PORT/conn?dsn='ODBC_DSN_NAME'
ids.sql.IDSDriver
Informix Dynamic Server
jdbc:informix-sqli://HOST:PORT/DB:INFORMIXSERVER=SERVER_NAME
com.informix.jdbc.IfxDriver
InstantDB (v3.13 and earlier)
jdbc:idb:DB
jdbc.idbDriver
InstantDB (v3.14 and later)
jdbc:idb:DB
org.enhydra.instantdb.jdbc.idbDriver
Interbase (InterClient Driver)
jdbc:interbase://HOST/DB
interbase.interclient.Driver
Hypersonic SQL (v1.2 and earlier)
jdbc:HypersonicSQL:DB
hSql.hDriver
Hypersonic SQL (v1.3 and later)
jdbc:HypersonicSQL:DB
org.hsql.jdbcDriver
Microsoft SQL Server (JTurbo Driver)
jdbc:JTurbo://HOST:PORT/DB
com.ashna.jturbo.driver.Driver
Microsoft SQL Server (Sprinta Driver)
jdbc:inetdae:HOST:PORT?database=DB
com.inet.tds.TdsDriver
Microsoft SQL Server 2000 (Microsoft Driver)
jdbc:microsoft:sqlserver://HOST:PORT[;DatabaseName=DB]
com.microsoft.sqlserver.jdbc.SQLServerDriver
MySQL (MM.MySQL Driver)
jdbc:mysql://HOST:PORT/DB
org.gjt.mm.mysql.Driver
Oracle OCI 8i
jdbc:oracle:oci8:@SID
oracle.jdbc.driver.OracleDriver
Oracle OCI 9i
jdbc:oracle:oci:@SID
oracle.jdbc.driver.OracleDriver
PostgreSQL (v6.5 and earlier)
jdbc:postgresql://HOST:PORT/DB
postgresql.Driver
PostgreSQL (v7.0 and later)
jdbc:postgresql://HOST:PORT/DB
org.postgresql.Driver
Sybase (jConnect 4.2 and earlier)
jdbc:sybase:Tds:HOST:PORT
com.sybase.jdbc.SybDriver
Sybase (jConnect 5.2)
jdbc:sybase:Tds:HOST:PORT
com.sybase.jdbc2.jdbc.SybDriver
JDBC Drivers
More details on this API can be found here.
The JDBC API uses JDBC Drivers to connect to databases. There are four types of drivers.
Type 1: JDBC-ODBC Bridge
This type of drivers are used when the database doesn't have a pure Java driver for connectivity. The bridge will translate the JDBC calls into ODBC (Open Database Connectivity) calls. This method is platform dependent as ODBC is a Microsoft Windows interface to SQL.
Pros:
- Allows access to any database which has the ODBC driver installed.
- Degrades the performance as the JDBC calls goes through the bridge to the ODBC driver and then through the native database connectivity interface. The results comes back through the reverse process
- The ODBC driver and the native database connectivity interface has to be installed on the client machine.
- Cannot be used for web based applications as client side software is needed.
Type 2: Native-API/partly Java driver
This type of drivers communicates directly with the databases i.e they will convert the JDBC method calls into native calls for the database APIs. It is platform dependent as the native code has to be installed on the client machines.The driver is not written entirely in java as it communicates with the native code.
Pros:
- Better Performance than type 1 drivers.
- Lower performance than type 3 and 4 drivers.
- The native code (the vendor client library) has to be installed on the client side.
- Cannot be used for web based applications as client side software is needed.
Type 3: Net-protocol/all-Java driver
This type of drivers are written entirely in Java. The drivers follow a 3-tier architecture approach when connecting to a database. The JDBC calls are sent to the middleware server which directly or indirectly ( depending on the drivers used.) translates the JDBC requests to database specific calls through the native database connectivity interface. These drivers are platform independent.
Pros:
- Vendor database libraries do not have to be present on client machines.
- The middle ware server can provide middle ware services like caching (Query Results, Connections etc), Load balancing , System administration features such as logging and auditing.
- Database specific coding has to be done in the middle tier.
- The Middle ware Server layer might result in a time bottle neck.
Type 4: Native-protocol/all-Java driver
This type of drivers convert JDBC calls directly into the vendor-specific database protocols. The drivers are written purely in Java and is installed inside the JVM. As a result these drivers are platform independent.
Pros:
- Provides better performance as there is no need for translating JDBC requests to intermediary forms or a middle ware server to service the requests.
- Provides easier debugging as all aspects of the application to the database connection can be managed within the JVM.
- A seperate driver is needed for each database.