EJB-Stateless Bean
Stateless Session Bean은 일반적으로 독립적 인 작업을 수행하는 데 사용되는 엔터프라이즈 Bean 유형입니다. 이름에 따른 상태 비 저장 세션 빈에는 연결된 클라이언트 상태가 없지만 인스턴스 상태를 유지할 수 있습니다. EJB 컨테이너는 일반적으로 상태 비 저장 빈 개체의 풀을 만들고 이러한 개체를 사용하여 클라이언트의 요청을 처리합니다. 풀 때문에 인스턴스 변수 값은 조회 / 메소드 호출에서 동일하다고 보장되지 않습니다.
상태 비 저장 EJB를 만드는 단계
다음은 상태 비 저장 EJB를 만드는 데 필요한 단계입니다-
비즈니스 방법을 노출하는 원격 / 로컬 인터페이스를 만듭니다.
이 인터페이스는 EJB 클라이언트 애플리케이션에서 사용됩니다.
EJB 클라이언트가 EJB 세션 빈이 배포되는 동일한 환경에있는 경우 @Local 주석을 사용합니다.
EJB 클라이언트가 EJB 세션 빈이 배치 될 다른 환경에있는 경우 @Remote 어노테이션을 사용하십시오.
위의 인터페이스를 구현하여 상태 비 저장 세션 빈을 만듭니다.
@Stateless 어노테이션을 사용하여 Stateless Bean을 표시하십시오. EJB 컨테이너는 배포 중에이 주석을 읽어 필요한 관련 구성 또는 인터페이스를 자동으로 생성합니다.
원격 인터페이스
import javax.ejb.Remote;
@Remote
public interface LibrarySessionBeanRemote {
//add business method declarations
}
상태 비 저장 EJB
@Stateless
public class LibrarySessionBean implements LibrarySessionBeanRemote {
//implement business method
}
예제 애플리케이션
상태 비 저장 EJB를 테스트하기위한 테스트 EJB 애플리케이션을 만들어 보겠습니다.
단계 | 기술 |
---|---|
1 | EJB-Create Application 장에 설명 된대로 com.tutorialspoint.stateless 패키지 아래에 EjbComponent 라는 이름으로 프로젝트를 만듭니다 . 이 장에서 상태 비 저장 EJB 개념을 이해하기 위해 EJB-응용 프로그램 만들기 장 에서 만든 프로젝트를 사용할 수도 있습니다 . |
2 | 만들기 LibrarySessionBean.java 및 LibrarySessionBeanRemote을 에 설명 된대로 EJB - 응용 프로그램 생성 장을. 나머지 파일은 변경하지 마십시오. |
삼 | 응용 프로그램을 정리하고 빌드하여 비즈니스 논리가 요구 사항에 따라 작동하는지 확인합니다. |
4 | 마지막으로 JBoss Application Server에 jar 파일 형식으로 애플리케이션을 배포합니다. JBoss Application Server는 아직 시작되지 않은 경우 자동으로 시작됩니다. |
5 | 이제 EJB-응용 프로그램 만들기 장에서 설명한 것과 동일한 방식으로 콘솔 기반 응용 프로그램 인 EJB 클라이언트를 만듭니다.Create Client to access EJB. |
EJBComponent (EJB 모듈)
LibrarySessionBeanRemote.java
package com.tutorialspoint.stateless;
import java.util.List;
import javax.ejb.Remote;
@Remote
public interface LibrarySessionBeanRemote {
void addBook(String bookName);
List getBooks();
}
LibrarySessionBean.java
package com.tutorialspoint.stateless;
import java.util.ArrayList;
import java.util.List;
import javax.ejb.Stateless;
@Stateless
public class LibrarySessionBean implements LibrarySessionBeanRemote {
List<String> bookShelf;
public LibrarySessionBean() {
bookShelf = new ArrayList<String>();
}
public void addBook(String bookName) {
bookShelf.add(bookName);
}
public List<String> getBooks() {
return bookShelf;
}
}
JBOSS에 EjbComponent 프로젝트를 배포하자마자 jboss 로그를 확인하십시오.
JBoss는 세션 빈에 대한 JNDI 항목을 자동으로 생성했습니다. LibrarySessionBean/remote.
이 조회 문자열을 사용하여 유형의 원격 비즈니스 오브젝트를 가져옵니다. com.tutorialspoint.stateless.LibrarySessionBeanRemote
JBoss 애플리케이션 서버 로그 출력
...
16:30:01,401 INFO [JndiSessionRegistrarBase] Binding the following Entries in Global JNDI:
LibrarySessionBean/remote - EJB3.x Default Remote Business Interface
LibrarySessionBean/remote-com.tutorialspoint.stateless.LibrarySessionBeanRemote - EJB3.x Remote Business Interface
16:30:02,723 INFO [SessionSpecContainer] Starting jboss.j2ee:jar=EjbComponent.jar,name=LibrarySessionBean,service=EJB3
16:30:02,723 INFO [EJBContainer] STARTED EJB: com.tutorialspoint.stateless.LibrarySessionBeanRemote ejbName: LibrarySessionBean
16:30:02,731 INFO [JndiSessionRegistrarBase] Binding the following Entries in Global JNDI:
LibrarySessionBean/remote - EJB3.x Default Remote Business Interface
LibrarySessionBean/remote-com.tutorialspoint.stateless.LibrarySessionBeanRemote - EJB3.x Remote Business Interface
...
EJBTester (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
이러한 속성은 Java 이름 지정 서비스의 InitialContext 개체를 초기화하는 데 사용됩니다.
InitialContext 객체는 상태 비 저장 세션 빈을 조회하는 데 사용됩니다.
EJBTester.java
package com.tutorialspoint.test;
import com.tutorialspoint.stateful.LibrarySessionBeanRemote;
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.testStatelessEjb();
}
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 testStatelessEjb() {
try {
int choice = 1;
LibrarySessionBeanRemote libraryBean =
LibrarySessionBeanRemote)ctx.lookup("LibrarySessionBean/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++;
}
LibrarySessionBeanRemote libraryBean1 =
(LibrarySessionBeanRemote)ctx.lookup("LibrarySessionBean/remote");
List<String> booksList1 = libraryBean1.getBooks();
System.out.println(
"***Using second lookup to get library stateless object***");
System.out.println(
"Book(s) entered so far: " + booksList1.size());
for (int i = 0; i < booksList1.size(); ++i) {
System.out.println((i+1)+". " + booksList1.get(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는 다음 작업을 수행합니다-
jndi.properties에서 속성을로드하고 InitialContext 객체를 초기화합니다.
testStatelessEjb () 메소드에서 jndi 검색은 "LibrarySessionBean / remote"라는 이름으로 수행되어 원격 비즈니스 객체 (상태 비 저장 ejb)를 얻습니다.
그런 다음 사용자에게 라이브러리 저장소 사용자 인터페이스가 표시되고 선택 항목을 입력하라는 메시지가 표시됩니다.
사용자가 1을 입력하면 시스템은 책 이름을 요청하고 stateless 세션 빈 addBook () 메소드를 사용하여 책을 저장합니다. Session Bean은 인스턴스 변수에 책을 저장하고 있습니다.
사용자가 2를 입력하면 시스템은 Stateless 세션 빈 getBooks () 메소드를 사용하여 책을 검색하고 종료합니다.
그런 다음 "LibrarySessionBean / remote"라는 이름으로 또 다른 jndi 검색이 수행되어 원격 비즈니스 오브젝트 (상태 비 저장 EJB)를 다시 얻고 도서 목록이 완료됩니다.
클라이언트를 실행하여 EJB에 액세스
프로젝트 탐색기에서 EJBTester.java를 찾습니다. EJBTester 클래스를 마우스 오른쪽 버튼으로 클릭하고run file.
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
***Using second lookup to get library stateless object***
Book(s) entered so far: 0
BUILD SUCCESSFUL (total time: 13 seconds)
클라이언트를 다시 실행하여 EJB에 액세스
프로젝트 탐색기에서 EJBTester.java를 찾습니다. EJBTester 클래스를 마우스 오른쪽 버튼으로 클릭하고run file.
Netbeans 콘솔에서 다음 출력을 확인하십시오.
run:
**********************
Welcome to Book Store
**********************
Options
1. Add Book
2. Exit
Enter Choice: 2
Book(s) entered so far: 0
***Using second lookup to get library stateless object***
Book(s) entered so far: 1
1. Learn Java
BUILD SUCCESSFUL (total time: 12 seconds)
위에 표시된 출력은 JBoss가 유지 관리하는 상태 비 저장 EJB 개체 수에 따라 달라질 수 있습니다.
단일 상태 비 저장 EJB 객체가 유지되는 경우 각 조회 후 동일한 책 목록을 볼 수 있습니다.
EJB 컨테이너는 모든 조회에 대해 동일한 상태 비 저장 EJB 객체를 반환 할 수 있습니다.
Stateless EJB Bean은 서버가 다시 시작되지 않을 때까지 인스턴스 변수 값을 유지합니다.