GRails 2.3 Async 지원과 Servlet 3.0 공부하는 것/GRails2013. 3. 31. 22:50
오늘 오랜만에 Grails.com을 둘러 보았더니, Grails 2.3의 Async Support에 관련된 글이 올라왔다.
아마도 Grails 2.2에서 부터 지원하기 시작한 Suvlet 3.0의 async API에 대한 지원에 대한 것이라 관심있게 읽게 되었다. 읽다 보니 Grails의 기능 제공 보다는 Servlet 3.0에서 추가된 기능들에 대해서 알아봐야겠다는 생각이 들어 몇몇 사이트를 보면서 아래와 같이 정리하였다.
자료들을 찾다 보니, Servlet 2.5에서도 이미 제공하고 있었지만, 서버 vernder들의 상이한 기능제공으로 인해 사용하기에 적합하지 않은 부분들이 있었다고 한다. 그러나 3.0에서는 이러한 혼란 스러운 부분들이 제거되어 제공하게 되었다. Servlet 3.0은 2009년도 12월에 발표가 되었다.
[Servlet 3.0 변경사항]
배경을 약간 설명하게 되면, 기존의 Web Technology는 클라이언트(Web Browser)와 서버간의 전형적인 Request-Response 모델을 따르도록 설계되어 있었다. 이러한 구조는 Web 2.0이라는 기술적인 Trand가 변함에 따라서 작지만 많은 Request들을 연속적으로 Server에 요청을 하게 되고 이로 인한 지연과 성능적인 측변에서의 변화를 이끌어 내게 되었다.
Servlet 3.0의 특징으로는 java web application을 위해서 3가지 configuration옵션을 제공한다. Annotation, API 그리고 Xml이용해서 configuration 변경이 가능하다.
다음은 주요 기능들의 요약이다.
1. Annotations 추가: 기존 web.xml에서 제공하던 기능을 Annotation을 통해서 제공
- @WebServlet
- @WebListener
- @WebFilter
위 3개는 스프링 프레임워크 등을 사용해왔던 개발자라면 충분히 비슷하다고 생각할 것인데, 실제 사용번도 크게 다르지는 않다.
- @MultipartConfig
역시 스프링 프레임워크의 MultipartFile과 사용법과 용도가 유사하다.
2. Dynamic Registration of Servlet and Filters: 서블릿, 필터 클래스의 매핑과 등록 해제가 코드에서 가능
ServletContext.addServletMapping(..), ServletContext.addFilter(..)등의 ServletContext클래스를 이용하여 직접 코드상의 수정도 가능하다.
3. Pluggability: Annotation을 통한 서블릿, 필터 정의 또는 web-fragment.xml을 통해 배포 기술자의 모듈화 가능
4. Asynchronous Support: 말 그대로 비동기 모드 지원
5. Security: Annotation을 통한 용청별 권한 이증 지원
- @RolesAllowed
- @DenyAll
- @PermitAll
- @TransportProtected
Servlet 3.0과 관련된 주요 사이트들.
- https://blogs.oracle.com/enterprisetechtips/entry/asynchronous_support_in_servlet_3
- http://www.java.net/blogs/mode/
- http://ko.wikipedia.org/wiki/자바_서블릿
- http://en.wikipedia.org/wiki/Java_Servlet
[Grails 2.3 Async Support]
이제 본론으로 들어가야 할 때이다. Servlet 3.0이 생각보다 오래전에 발표되었지만, 아는 사람들과 실제 환경에서 적용하여 사용하는 사람들은 많지는 않아 보인다. 뭐.. google app engine도 최근에 지원하려고 준비고 있는 단계이니, 그럴수도 있겠지.)
오늘 읽어 본 글은 http://grails.io 에 올라온 글이다.
예제위주로 설명이 되어 있어서 이해는 어렵지 않은데 실제 코드를 만들지 않으면 별로 의미가 없을 수 있다. 나중에 꼭 해볼것을 다짐하면서...
Grails 2.3에서는 Promises패키지에 포함되어 있는 메소드들을 통해서 Async 기능을 제공하고 있다.
아래는 그 예제이다. 설명을 따로 하지 않아도 알겠지만 3개의 메소드를 async하게 실행해서, 그 결과를 wateAll 메소드를 통해서 전달 받는다.
import static grails.async.Promises.*
def p1 = task { 2 * 2 }
def p2 = task { 4 * 4 }
def p3 = task { 8 * 8 }
assert [4,16,64] == waitAll(p1, p2, p3)
아래는 GORM을 통한 query메소드를 호출하는 예제로 위의 예제와 사용법이 같다.
import static grails.async.Promises.*
def p1 = Person.async.get(1L)
def p2 = Person.async.get(2L)
def p3 = Person.async.get(3L)
def results = waitAll(p1, p2, p3)
그런데, 위의 예저들은 서블릿 3.0에서 제공하는 기능들과의 연관성이 전혀 없어 보인다.
다음의 예제들이 Async 방식을 지원하는 예제로 Service를 Annotation을 통해서 Async 서비스로 노출을 시기는 코드이다. 그 아래의 코드는 모든 메소드를 Async로 실행하는 코드이다.
import grails.async.*
class AsyncBookService {
@DelegateAsync BookService bookService
}
AsyncBookService asyncBookService
def findBooks(String title) {
asyncBookService.findBooks(title)
.onComplete { List results ->
println "Books = ${results}"
}
}
'공부하는 것 > GRails' 카테고리의 다른 글
GRails 대한 나의 생각... (2) | 2011.09.10 |
---|---|
GRails 개발 환경 만들기 - Spring Tool Suite (0) | 2011.07.30 |