Mule+Servlet+JPA

From Resin 3.0

Revision as of 22:53, 12 February 2008 by Emil (Talk | contribs)
Jump to: navigation, search

Mule and Resin using the Mule Servlet provider and JPA (Amber)

Mule can be run within Resin and use objects created by it as components. This allows Mule to take advantage of Resin IoC and Amber, Caucho's implementation of JPA. This example shows how to use all of these technologies together.

Compare this example to http://www.caucho.com/resin/examples/amber-basic/index.xtp

(The following has been tested with Resin 3.1.5 and Mule 1.4.3)

  1. Download Resin from http://www.caucho.com/download
  2. Unzip Resin into /usr/local/share/resin
  3. Create the Mule webapp directory structure:
    mkdir -p /usr/local/share/resin/webapps/mule/WEB-INF/lib/
    mkdir -p /usr/local/share/resin/webapps/mule/WEB-INF/classes/example/
    mkdir -p /usr/local/share/resin/webapps/mule/WEB-INF/classes/META-INF/
  4. Download Mule from http://mule.mulesource.org/display/MULE/Download
  5. Unzip Mule
  6. Copy all the jars included the Mule lib/ directory to
    /usr/local/share/resin/webapps/mule/WEB-INF/lib/
  7. Create the configuration file /usr/local/share/resin/webapps/mule/WEB-INF/resin-web.xml
    <?xml version="1.0" encoding="UTF-8"?>
    <web-app xmlns="http://caucho.com/ns/resin">
      <!-- Make the database accessible to Amber -->
      <database>
        <jndi-name>jdbc/resin</jndi-name>
        <driver type="org.gjt.mm.mysql.Driver">
          <url>jdbc:mysql://localhost:3306/MuleJPA</url>
          <user>root</user>
          <password/>
        </driver>
      </database>
    
      <!-- Tell Amber which database to use -->
      <ejb-server data-source="jdbc/resin"/>
    
      <!-- Create the bean reference for the Mule component -->
      <bean class="example.CourseComponent" name="courseComponent"/>
    
      <!-- Tell Mule where to find its configuration -->
      <context-param>
        <param-name>org.mule.config</param-name>
        <param-value>/WEB-INF/course-config.xml</param-value>
      </context-param>
    
      <!-- The listener that starts Mule.  The MuleResinContextListener
           extends Mule's own MuleXmlBuilderContextListener, but allows
           Mule to find Resin's beans. -->
      <listener>
        <listener-class>com.caucho.mule.MuleResinContextListener</listener-class>
      </listener>
    
      <!-- Set up a servlet that Mule can use for input -->
      <servlet servlet-name="mule-servlet"
               servlet-class="org.mule.providers.http.servlet.MuleReceiverServlet"/>
    
      <servlet-mapping url-pattern="/*" servlet-name="mule-servlet"/>
    </web-app>
    
  8. Create the JPA configuration file for Amber /usr/local/share/resin/webapps/mule/WEB-INF/classes/META-INF/persistence.xml
    <?xml version="1.0" encoding="UTF-8"?>
    <persistence xmlns="http://java.sun.com/xml/ns/persistence" version="1.0">
      <persistence-unit name="example">
        <class>example.CourseBean</class>
    
        <exclude-unlisted-classes/>
      </persistence-unit>
    </persistence>
    
  9. Create the configuration file for Resin IoC (WebBeans) /usr/local/share/resin/webapps/mule/WEB-INF/classes/META-INF/web-beans.xml
    <?xml version="1.0" encoding="UTF-8"?>
    <web-beans xmlns="http://caucho.com/ns/resin">
      <!--
         - The web-beans.xml marks a class root for WebBeans to search for
         - @Component beans.  Since the example doesn't need to override any
         - defaults, there's no additional configuration necessary.
         -->
    </web-beans>
    
  10. Create the configuration file for Mule /usr/local/share/resin/webapps/mule/WEB-INF/course-config.xml
    <?xml version="1.0" encoding="UTF-8"?>
    
    <!DOCTYPE mule-configuration 
      PUBLIC "-//MuleSource //DTD mule-configuration XML V1.0//EN"
             "http://mule.mulesource.org/dtds/mule-configuration.dtd">
    
    <mule-configuration id="Course_Service" version="1.0">
      <connector name="servletConnector" 
                 className="org.mule.providers.http.servlet.ServletConnector">
        <properties>
          <property name="servletUrl" value="course"/>
        </properties>
      </connector>
    
      <model name="courseModel">
        <!-- Mule will ask Resin IoC to find "courseComponent" -->
        <mule-descriptor name="CourseUMO" implementation="courseComponent">
          <inbound-router>
            <endpoint synchronous="true" address="servlet://course"/>
          </inbound-router>
    
          <outbound-router>
            <router className="org.mule.routing.outbound.OutboundPassThroughRouter">
               <endpoint address="stream://System.out"/>
            </router>
          </outbound-router>
        </mule-descriptor>
      </model>
    </mule-configuration>
    
  11. Create a JPA persisted data bean file /usr/local/share/resin/webapps/mule/WEB-INF/classes/example/CourseBean.java
    package example;
    
    import javax.persistence.*;
    
    @Entity@Table(name="basic_courses")
    public class CourseBean {
      private int _id;
      private String _course;
      private String _teacher;
    
      @Id@Column(name="id")
      @GeneratedValue
      public int getId()
      {
        return _id;
      }
    
      public void setId(int id)
      {
        _id = id;
      }
    
      @Basic
      public String getCourse()
      {
        return _course;
      }
    
      public void setCourse(String course)
      {
        _course = course;
      }
    
      @Basic
      public String getTeacher()
      {
        return _teacher;
      }
    
      public void setTeacher(String teacher)
      {
        _teacher = teacher;
      }
    }
    
  12. Create the Mule component /usr/local/share/resin/webapps/cxf/WEB-INF/classes/example/CourseComponent.java
    package example;
    
    import java.io.*;
    import javax.servlet.*;
    import javax.servlet.http.*;
    import javax.persistence.*;
    
    import org.mule.umo.lifecycle.Callable;
    import org.mule.umo.UMOEventContext;
    
    public class CourseComponent implements Callable
    {
      // Resin IoC will inject this
      @PersistenceContext(name="example")
      private EntityManager _manager;
    
      public Object onCall(UMOEventContext context)
      {
        StringBuilder sb = new StringBuilder();
    
        CourseBean []course = new CourseBean[2];
    
        course[0] = _manager.find(CourseBean.class, new Integer(1));
        course[1] = _manager.find(CourseBean.class, new Integer(2));
    
        sb.append("Course Details\n\n");
    
        for (int i = 0; i < course.length; i++) {
          sb.append("course: " + course[i].getCourse() + "\n");
          sb.append("teacher: " + course[i].getTeacher() + "\n\n");
        }
    
        return sb.toString();
      }
    }
    
  13. Start Resin with java -jar /usr/local/share/resin/lib/resin.jar
  14. Look at http://localhost:8080/mule/course
    It should show
    Course Details
    
    course: Potions
    teacher: Severus Snape
    
    course: Transfiguration
    teacher: Minerva McGonagall
    


    The same output should appear on the terminal where you ran Resin!

Personal tools