EJB - Ketekunan

EJB 3.0, kacang entitas yang digunakan dalam EJB 2.0 sebagian besar digantikan oleh mekanisme persistensi. Sekarang kacang entitas adalah POJO sederhana yang memiliki pemetaan dengan tabel.

Berikut adalah aktor kunci dalam persistence API -

  • Entity- Sebuah objek persisten yang merepresentasikan record penyimpanan data. Ini bagus untuk dibuat bersambung.

  • EntityManager- Antarmuka persistensi untuk melakukan operasi data seperti menambah / menghapus / memperbarui / menemukan objek persisten (entitas). Ini juga membantu menjalankan kueri menggunakanQuery antarmuka.

  • Persistence unit (persistence.xml) - Satuan persistensi menjelaskan sifat-sifat mekanisme persistensi.

  • Data Source (*ds.xml)- Sumber Data menjelaskan properti terkait penyimpanan data seperti url koneksi. nama pengguna, kata sandi, dll.

Untuk mendemonstrasikan mekanisme persistensi EJB, kita perlu melakukan tugas-tugas berikut -

  • Step 1 - Buat tabel di database.

  • Step 2 - Buat kelas Entitas yang sesuai dengan tabel.

  • Step 3 - Buat Sumber Data dan Unit Persistensi.

  • Step 4 - Buat EJB stateless yang memiliki instance EntityManager.

  • Step 5- Perbarui EJB tanpa kewarganegaraan. Tambahkan metode untuk menambahkan catatan dan mendapatkan catatan dari database melalui manajer entitas.

  • Step 6 - Klien aplikasi berbasis konsol akan mengakses EJB tanpa kewarganegaraan untuk menyimpan data dalam database.

Buat tabel

Buat tabel books dalam database default postgres.

CREATE TABLE books (
   id     integer PRIMARY KEY,
   name   varchar(50)
);

Buat kelas Entity

//mark it entity using Entity annotation 
//map table name using Table annotation
@Entity
@Table(name="books")
public class Book implements Serializable{
    
   private int id;
   private String name;

   public Book() {        
   }

   //mark id as primary key with autogenerated value
   //map database column id with id field
   @Id
   @GeneratedValue(strategy= GenerationType.IDENTITY)
   @Column(name="id")
   public int getId() {
      return id;
   }
   ...
}

Buat DataSource dan Unit Persistence

Sumber Data (jboss-ds.xml)

<?xml version = "1.0" encoding = "UTF-8"?>
<datasources>
   <local-tx-datasource>
      <jndi-name>PostgresDS</jndi-name>
      <connection-url>jdbc:postgresql://localhost:5432/postgres</connection-url>
      <driver-class>org.postgresql.driver</driver-class>
      <user-name>sa</user-name>
      <password>sa</password>
      <min-pool-size>5</min-pool-size>
      <max-pool-size>20</max-pool-size>
      <idle-timeout-minutes>5</idle-timeout-minutes>
   </local-tx-datasource>
</datasources>

Unit Persistensi (persistence.xml)

<persistence version = "1.0" xmlns = "http://java.sun.com/xml/ns/persistence" xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd">

   <persistence-unit name = "EjbComponentPU" transaction-type = "JTA">
      <jta-data-source>java:/PostgresDS</jta-data-source>
      <exclude-unlisted-classes>false</exclude-unlisted-classes>
      <properties/>
   </persistence-unit>
   
   <persistence-unit name = "EjbComponentPU2" transaction-type = "JTA">
      <provider>org.hibernate.ejb.HibernatePersistence</provider>
      <jta-data-source>java:/PostgresDS</jta-data-source>
      <exclude-unlisted-classes>false</exclude-unlisted-classes>
	  
      <properties>
         <property name="hibernate.hbm2ddl.auto" value="update"/>
      </properties>
   </persistence-unit>
   
</persistence>

Buat EJB Stateless Memiliki Instance EntityManager

@Stateless
public class LibraryPersistentBean implements LibraryPersistentBeanRemote {
	
   //pass persistence unit to entityManager.
   @PersistenceContext(unitName="EjbComponentPU")
   private EntityManager entityManager;         

   public void addBook(Book book) {
      entityManager.persist(book);
   }    

   public List<Book> getBooks() {        
      return entityManager.createQuery("From Books").getResultList();
   }
   ...
}

Setelah membangun modul EJB, kita membutuhkan klien untuk mengakses kacang tanpa status, yang akan kita buat di bagian selanjutnya.

Contoh Aplikasi

Mari kita buat aplikasi uji EJB untuk menguji mekanisme persistensi EJB.

Langkah Deskripsi
1

Buat proyek dengan nama EjbComponent di bawah paket com.tutorialspoint.entity seperti yang dijelaskan di bab EJB - Buat Aplikasi . Anda juga dapat menggunakan proyek yang dibuat di EJB - Buat bab Aplikasi seperti bab ini untuk memahami konsep ketekunan EJB.

2

Buat Book.java di bawah paket com.tutorialspoint.entity dan modifikasi seperti yang ditunjukkan di bawah ini.

3

Buat LibraryPersistentBean.java dan LibraryPersistentBeanRemote seperti yang dijelaskan di EJB - Membuat bab Aplikasi dan memodifikasinya seperti yang ditunjukkan di bawah ini.

4

Buat jboss-ds.xml diEjbComponent > setup folder dan persistence.xml diEjbComponent > src > conf map. Folder ini dapat dilihat di tab file di Netbeans. Ubah file ini seperti yang ditunjukkan di atas.

5

Bersihkan dan Bangun aplikasi untuk memastikan logika bisnis berfungsi sesuai persyaratan.

6

Terakhir, terapkan aplikasi dalam bentuk file jar di JBoss Application Server. Server Aplikasi JBoss akan dimulai secara otomatis jika belum dimulai.

7

Sekarang buat klien EJB, aplikasi berbasis konsol dengan cara yang sama seperti yang dijelaskan di bab EJB - Membuat Aplikasi di bawah topikCreate Client to access EJB. Ubah seperti yang ditunjukkan di bawah ini.

Komponen EJBC (Modul EJB)

Book.java

package com.tutorialspoint.entity;

import java.io.Serializable;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.EntityListeners;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;

@Entity
@Table(name="books")
public class Book implements Serializable{
    
   private int id;
   private String name;

   public Book() {        
   }

   @Id
   @GeneratedValue(strategy= GenerationType.IDENTITY)
   @Column(name="id")
   public int getId() {
      return id;
   }

   public void setId(int id) {
      this.id = id;
   }

   public String getName() {
      return name;
   }

   public void setName(String name) {
      this.name = name;
   }    
}

LibraryPersistentBeanRemote.java

package com.tutorialspoint.stateless;

import com.tutorialspoint.entity.Book;
import java.util.List;
import javax.ejb.Remote;

@Remote
public interface LibraryPersistentBeanRemote {

   void addBook(Book bookName);

   List<Book> getBooks();
    
}

LibraryPersistentBean.java

package com.tutorialspoint.stateless;

import com.tutorialspoint.entity.Book;
import java.util.List;
import javax.ejb.Stateless;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;

@Stateless
public class LibraryPersistentBean implements LibraryPersistentBeanRemote {
    
   public LibraryPersistentBean() {
   }

   @PersistenceContext(unitName="EjbComponentPU")
   private EntityManager entityManager;         

   public void addBook(Book book) {
      entityManager.persist(book);
   }    

   public List<Book> getBooks() {
      return entityManager.createQuery("From Book").getResultList();
   }
}
  • Segera setelah Anda menerapkan proyek EjbComponent di JBOSS, perhatikan log jboss.

  • JBoss secara otomatis membuat entri JNDI untuk kacang sesi kami - LibraryPersistentBean/remote.

  • Kami akan menggunakan string pencarian ini untuk mendapatkan jenis objek bisnis jarak jauh - com.tutorialspoint.stateless.LibraryPersistentBeanRemote

Output Log Server Aplikasi JBoss

...
16:30:01,401 INFO  [JndiSessionRegistrarBase] Binding the following Entries in Global JNDI:
   LibraryPersistentBean/remote - EJB3.x Default Remote Business Interface
   LibraryPersistentBean/remote-com.tutorialspoint.stateless.LibraryPersistentBeanRemote - EJB3.x Remote Business Interface
16:30:02,723 INFO  [SessionSpecContainer] Starting jboss.j2ee:jar=EjbComponent.jar,name=LibraryPersistentBeanRemote,service=EJB3
16:30:02,723 INFO  [EJBContainer] STARTED EJB: com.tutorialspoint.stateless.LibraryPersistentBeanRemote ejbName: LibraryPersistentBean
16:30:02,731 INFO  [JndiSessionRegistrarBase] Binding the following Entries in Global JNDI:

   LibraryPersistentBean/remote - EJB3.x Default Remote Business Interface
   LibraryPersistentBean/remote-com.tutorialspoint.stateless.LibraryPersistentBeanRemote - EJB3.x Remote Business Interface
...

EJBTester (Klien EJB)

jndi.properties

java.naming.factory.initial=org.jnp.interfaces.NamingContextFactory
java.naming.factory.url.pkgs=org.jboss.naming:org.jnp.interfaces
java.naming.provider.url=localhost
  • Properti ini digunakan untuk menginisialisasi objek InitialContext dari layanan penamaan java.

  • Objek InitialContext akan digunakan untuk mencari kacang sesi stateless.

EJBTester.java

package com.tutorialspoint.test;
   
import com.tutorialspoint.stateless.LibraryPersistentBeanRemote;
import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.List;
import java.util.Properties;
import javax.naming.InitialContext;
import javax.naming.NamingException;

public class EJBTester {

   BufferedReader brConsoleReader = null; 
   Properties props;
   InitialContext ctx;
   {
      props = new Properties();
      try {
         props.load(new FileInputStream("jndi.properties"));
      } catch (IOException ex) {
         ex.printStackTrace();
      }
      try {
         ctx = new InitialContext(props);            
      } catch (NamingException ex) {
         ex.printStackTrace();
      }
      brConsoleReader = 
      new BufferedReader(new InputStreamReader(System.in));
   }
   
   public static void main(String[] args) {

      EJBTester ejbTester = new EJBTester();

      ejbTester.testEntityEjb();
   }
   
   private void showGUI() {
      System.out.println("**********************");
      System.out.println("Welcome to Book Store");
      System.out.println("**********************");
      System.out.print("Options \n1. Add Book\n2. Exit \nEnter Choice: ");
   }
   
   private void testEntityEjb() {

      try {
         int choice = 1; 

         LibraryPersistentBeanRemote libraryBean =
         LibraryPersistentBeanRemote)ctx.lookup("LibraryPersistentBean/remote");

         while (choice != 2) {
            String bookName;
            showGUI();
            String strChoice = brConsoleReader.readLine();
            choice = Integer.parseInt(strChoice);
            if (choice == 1) {
               System.out.print("Enter book name: ");
               bookName = brConsoleReader.readLine();
               Book book = new Book();
               book.setName(bookName);
               libraryBean.addBook(book);          
            } else if (choice == 2) {
               break;
            }
         }

         List<Book> booksList = libraryBean.getBooks();

         System.out.println("Book(s) entered so far: " + booksList.size());
         int i = 0;
         for (Book book:booksList) {
            System.out.println((i+1)+". " + book.getName());
            i++;
         }           
      } catch (Exception e) {
         System.out.println(e.getMessage());
         e.printStackTrace();
      }finally {
         try {
            if(brConsoleReader !=null) {
               brConsoleReader.close();
            }
         } catch (IOException ex) {
            System.out.println(ex.getMessage());
         }
      }
   }
}

EJBTester melakukan tugas-tugas berikut.

  • Muat properti dari jndi.properties dan inisialisasi objek InitialContext.

  • Dalam metode testStatefulEjb (), pencarian jndi dilakukan dengan nama - "LibraryStatefulSessionBean / remote" untuk mendapatkan objek bisnis jarak jauh (stateful ejb).

  • Kemudian pengguna diperlihatkan User Interface toko perpustakaan dan dia diminta untuk memasukkan pilihan.

  • Jika pengguna memasukkan 1, sistem meminta nama buku dan menyimpan buku menggunakan metode stateless bean addBook () sesi. Session Bean mempertahankan buku dalam database melalui panggilan EntityManager.

  • Jika pengguna memasuki 2, sistem mengambil buku menggunakan metode kacang getBooks () sesi stateful dan keluar.

  • Kemudian pencarian jndi lainnya dilakukan dengan nama - "LibraryStatelessSessionBean / remote" untuk mendapatkan objek bisnis jarak jauh (stateless EJB) lagi dan pencatatan buku selesai.

Jalankan Klien untuk Mengakses EJB

Temukan EJBTester.java di project explorer. Klik kanan pada kelas EJBTester dan pilihrun file.

Verifikasi keluaran berikut di konsol Netbeans -

run:
**********************
Welcome to Book Store
**********************
Options 
1. Add Book
2. Exit 
Enter Choice: 1
Enter book name: Learn Java
**********************
Welcome to Book Store
**********************
Options 
1. Add Book
2. Exit 
Enter Choice: 2
Book(s) entered so far: 1
1. learn java
BUILD SUCCESSFUL (total time: 15 seconds)

Jalankan Klien Lagi untuk Mengakses EJB

Mulai ulang JBoss sebelum mengakses EJB.

Temukan EJBTester.java di project explorer. Klik kanan pada kelas EJBTester dan pilihrun file.

Verifikasi keluaran berikut di konsol Netbeans.

run:
**********************
Welcome to Book Store
**********************
Options 
1. Add Book
2. Exit 
Enter Choice: 1
Enter book name: Learn Spring
**********************
Welcome to Book Store
**********************
Options 
1. Add Book
2. Exit 
Enter Choice: 2
Book(s) entered so far: 2
1. learn java
2. Learn Spring
BUILD SUCCESSFUL (total time: 15 seconds)

Keluaran yang ditunjukkan di atas menyatakan bahwa buku disimpan dalam penyimpanan persisten dan diambil dari database.

Halaman sebelumnya