Java Programming, Lecture Notes # 1312
This lesson is also the third lesson in a miniseries intended to get you up and running with Sun's Enterprise JavaBeans(TM) very quickly.
In this and the next few lessons, I will walk you through the detailed steps necessary to deploy your new bean in the J2EE server.
You will learn about jar files and ear files and the difference between the two.
You will learn that the deployment descriptor is now packaged as an XML file in J2EE (instead of a serialized Properties object as was the case in earlier versions).
You will learn about J2EE Applications, which are higher-level constructs than enterprise beans.
You will learn about the three steps required for deployment of an enterprise bean.
The lessons in this miniseries will show you the steps involved in writing, compiling, deploying and executing a simple bean. The discussion will be brief and to the point.
More details in subsequent lessons
Subsequent lessons will come back and fill in the gaps to help you more-fully understand each of the steps.
Subsequent lessons will also teach you about the different kinds of beans and how to use those beans in different situations.
Recommended supplementary reading
It is strongly recommended that you study the previous lesson entitled Enterprise JavaBeans(TM), Getting Started with EJB, Part 2 before embarking on this lesson.
Additional supplementary material that I have written is available at Gamelan. As of the date of this writing, Gamelan does not maintain a consolidated index to my Java tutorials. Therefore, they may be difficult to locate on the Gamelan site. A consolidated index with links to the tutorials on the Gamelan site is available at Baldwin's Java Programming Tutorials.
The required steps
An earlier lesson entitled Getting Started with EJB, Part 1 contained a list of the required steps for writing, compiling, deploying and executing a simple bean. Abbreviated versions of the first seven steps in that list are repeated below.
The first two steps (shown in blue) require you to download and install the JDK and the J2EE. I am assuming that you are able to accomplish those two steps with no help from me.
Write/compile bean and interfaces
The next four steps (shown in green) were covered in the previous lesson entitled Getting Started with EJB, Part 2. In that lesson, I showed you explicitly how to accomplish all four of those steps.
Class files available
Having completed those steps, you should now have the class files necessary to deploy your bean into the J2EE server. That is the subject of the last step in the above list (shown in black).
The last step is a big one
The last step is a big one, so I will subdivide it into several sequential lessons.
In this and the next couple of lessons, I will walk you through the detailed steps necessary to deploy your new bean in the J2EE server. I will provide that information in cookbook fashion, meaning that I will tell you what to do but not necessarily why to do it.
Beans versus beans
Just in case you are reading this lesson without having read the earlier lessons in this series, I will tell you that an enterprise bean is not the same thing as a JavaBean Component(TM), as discussed in my series of tutorial lessons beginning with lesson number 500.
The minimum programming requirement for an enterprise bean consists of one class definition and two interface definitions.
In the previous lesson, I developed and discussed the elements of a simple bean, including the two required interface definitions. That is the bean that we will begin deploying in the J2EE server in this and the following lessons. Complete listings of the source code for the bean and the two interfaces are shown near the end of this lesson.
Required class files
At this point, you should have the following three class files as a result of compiling the bean class and the two interfaces from the previous lesson. Make sure that you have them all located conveniently in the same directory.
A note about packages
When you create your own beans, you will probably want to put them in packages. However, for learning purposes at this level, the use of packages simply adds unneeded complexity. Therefore, if you examine the source code for the bean and the two interfaces, you will find that I did not use package directives. Therefore, this bean and the two interfaces are all part of the default package.
If you have done much reading on EJB, you have probably read that an enterprise bean is packaged inside a jar file. The jar file contains the class files for the bean plus a couple of other files.
The deployment descriptor
One of the other files contained in the jar file is commonly referred to as the deployment descriptor. Depending on the age of the book that you were reading, you may have seen the deployment descriptor described as a serialized version of a Java Properties object.
Another application of XML
At some point in the history of EJB, that was the case. However, as of J2EE version 1.2.1, that has changed. The deployment descriptor is now an XML file.
In case you are unfamiliar with XML files, I have published quite a few tutorial lessons on XML. You will find a consolidated index to those lessons on my web site.
The application
Also, your reading may have led you to the conclusion that the jar file containing the EJB is deployed directly into the server. That is true for some server products. However, that is not true for J2EE from Sun. Rather, with J2EE from Sun, you must first wrap the EJB jar file in an application. Then the application is deployed into the server.
Jar files and ear files
The application is also packaged in an archive file, but the extension for the archive file is ear rather than jar. Presumably this extension indicates enterprise archive.
As you are probably already aware, you can view and extract the contents of a jar file using an unzip program such as WinZip. You can also view and extract the contents of an ear file using the same unzip program.
The HelloApp.ear file
After you finish deploying this simple enterprise bean, you will have a file named HelloApp.ear. If you view the contents of that file, you will see that it contains the following files:
If you extract the contents of the file, a new subdirectory named meta-inf will be created and the first three files listed above will be extracted into that directory.
The enterprise bean jar file
If you view the contents of the jar file named ejb-jar-ic.jar, you will find that it contains the following files:
Another jar file
While we are on the subject of jar files, let me mention that there is still another jar file involved in the use of J2EE. The deployment process produces a jar file that contains material required by the client program when it accesses the server to execute the enterprise bean.
A higher-level construct
A J2EE application is a higher-level construct than an enterprise bean.
Since this series of lessons is concentrating on enterprise beans, I'm not going to go into this in any detail at this point. Suffice it to say that in addition to enterprise beans, the J2EE application can also contain web components and J2EE Application Client components.
Web components
Web components consist of servlets and JSP files. (I have published numerous lessons on servlets and JSP. You can find a consolidated index to those lessons on my web site.) Web components, when present, are packaged inside a war file. The war file is in turn packaged inside the ear file.
Application Client components
J2EE Application Client components, when present, are packaged in a jar file, which is in turn packaged inside the ear file.
Steps for deployment
The process of deploying our enterprise bean into the server will consist of the following major steps.
You have learned about jar files and ear files.
You have learned that the deployment descriptor is now packaged as an XML file in J2EE.
You have learned that a J2EE Application is a higher-level construct than an enterprise bean.
You have learned about the three steps required for deployment of an
enterprise bean.
Subsequent lessons will cover the packaging of the Enterprise Bean and the deployment of the J2EE Application.
/*
File HelloBean.java
Copyright 2000 R.G.Baldwin Rev 9/15/00 This bean receives and
returns a String object
This is a stateless session
bean. According to
Implement the SessionBean
interface.
Tested using Sun j2ee
and JDK 1.3 under
public class HelloBean
implements SessionBean{
public void ejbCreate(){
public String
aBusinessMethod(String str){
public void ejbRemove(){
public void ejbActivate(){
public void ejbPassivate(){
public void setSessionContext(
public HelloBean(){}//public constructor }//end class HelloBean
Listing 1 |
/*
File HelloHome.java
Copyright 2000 R.G.Baldwin Rev 9/15/00 ***********************************************/ import javax.ejb.*; public interface HelloHome
extends EJBHome{
Listing 2 |
/*
File Hello.java
Copyright 2000 R.G.Baldwin Rev 9/15/00 ***********************************************/ import javax.ejb.*; import java.rmi.*; public interface Hello
extends EJBObject{
Listing 3 |
Copyright 2000, Richard G. Baldwin. Reproduction in whole or in part in any form or medium without express written permission from Richard Baldwin is prohibited.
Richard has participated in numerous consulting projects involving Java, XML, or a combination of the two. He frequently provides onsite Java and/or XML training at the high-tech companies located in and around Austin, Texas. He is the author of Baldwin's Java Programming Tutorials, which has gained a worldwide following among experienced and aspiring Java programmers. He has also published articles on Java Programming in Java Pro magazine.
Richard holds an MSEE degree from Southern Methodist University and has many years of experience in the application of computer technology to real-world problems.
-end-