태터데스크 관리자

도움말
닫기
적용하기   첫페이지 만들기

태터데스크 메시지

저장하였습니다.

현대 프로그래밍 언어나 프래임웍중에 스캐폴딩이라는 개념이 있다. 


이게 원래의 사전적인 의미는 다음과 같다.



출처: http://experientia.co.kr/?p=244


스캐폴딩(scaffolding)의 개념

– 스캐폴딩이란 교수자가 학생에 대하여 적절한 교수학습적 도움을 제공함으로써 유의미한 학습을 수행할 수 있도록 하는 것으로, 특히 학습자들로 하여금 자신의 현재 기능수준을 넘어서 다음단계의 수준까지 이르도록 돕기 위해 제공되는 지원


프로그래밍 언어에서의 스캐폴딩은 Data Model을 이용해서 CRUD(Create/Read/Update/Delete) 동작을 자동으로 제어해주는 코드를 생성해주거나 기능을 제공하는 것을 이야기한다.  Ruby on rails 에서 이런 기능을 제공하면서 인기를 끌게 되면서 다른 언어나 프레임웍에서도 비슷한 기능들을 제공하기 시작했다. 


PHP yii 프레임웍이나 나 groovy on grails에서도 이런 비슷한 기능들이 제공된다. 


사전적 의미에서 처럼 이런 기능을 제공하는 의미는 기본적인 코드를 제공함으로써 생산성 향상과 튜토리얼의 의미 모두를 만족시키기 위함이 아닐까 생각이 된다. 


웹개발에서 이런 CRUD개발이 50%이상의 시간을 쓰는점을 본다면 이 코드를 기반으로 개발을 시작하게 되면 좀더 빠른 생산성을 가져갈수 있을것이다.


또한 관리자툴 같은곳에서는 이 기능만 활용해도 거의 대부분의 기능을 구현해 낼수가 있다. 


현재 진행하는 프로젝트에서도 운영자툴을 위하여 이러한 솔루션을 몇가지 검토를 해보았는데, 


Spring Roo와 OpenXava 이 두가지가 가장 좋아 보였다. 



두 프로젝트 모두 Model 클래스를 통하여 CRUD기능을 하는 화면까지 생성을 해준다. 


OpenXava의 경우는 코드를 생성해주는 방식은 아니고 모델을 런타임에 분석하여 해당 기능들을 제공하는 방식이다. 





이 프로젝트들의 단점은 무엇보다 도큐먼트의 부족이다.


특히 Spring roo의 도큐먼트는 매우 부족한 수준이다. 

그리고 프로젝트 초기에 이런 프레임웍으로 개발하겠다고 결정하고 시작을 해야 생산성 향상에 도움이 될것 같다. 프로젝트 중간에 이런 툴들을 integration시키려면 여러가지 문제가 속출해서 그것을 해결하다가 보니 오히려 생산성 저하가 오는것 같다. 


여러가지 이유로 OpenXava를 도입하려고 했었는데 이것도 이것 자체가 웹프레임웍이라서 spring MVC와 연동을 하기에는 쉽지 않고, 커스터마이징 기능을 개발하기에도 이미 개발해놓은 코드들을 재사용하지 못해 불편함이 따른다. 


관리자툴 개발에 시간을 절약하기 위하여 도입검토를 한건데 이런식이니 그냥 간단하게 비슷한 역할을 해주는 것을 개발하기로 결정했다. 


향후 시작하는 프로젝트에서는  시작전에 미리 검토를 하고 시작해야 겠다. 







Posted by Breeze.Kang

댓글을 달아 주세요






일명 배치잡(Batch Job) 이라고 하는 주기적으로 구동시켜야 하는 작업들을 Spring에서 구동 시키기 위하여서는 Spring Batch 라는 프로젝트가 따로 존재 합니다. 




Spring Batch가 배치작업의 끝판왕이라면 Spring이 주로 사용되기 이전부터 Quartz라는 라이브러리를 java쪽에서는 많이 사용을 했었는데요. 


Spring에서도 이 Quartz를 지원해서 간단하게 주기적인 배치작업을 구동시킬수 있습니다. 




이렇게 스케줄러를 이용해서 Spring project상에서 배치작업을 Invoke시키는 방식은 통합적인 코드로 스케줄 작업들을 관리할수 있기 때문에 관리 측면에서 유리한 점이 있습니다. Spring 프로젝트 배포 시스템에서 따로 설정을 해주거나 관리를 해줄 필요가 없구요. 


반면 WAS서버가 여러대가 동시에 구동되는 실제 대용량 환경을 고려해본다면 실제 배치잡이 한군데에서만 구동되어야 하는 경우가 있을 것입니다. 두개의 인스턴스가 동시에 구동이 된다면 로직상에 문제가 생길만한 작업의 경우에 말이죠. 


예를 들면 주기적으로 보상을 해주거나 리셋을 해야 한다거나 통계를 내야 한다거나 하는 작업들이 있겠네요. 


이렬경우는 배치작업이 셋팅된 프로젝트를 따로 분리하여 한대의 서버에만 설치를 한다거나,  한대의 서버에서만 배치작업이 구동되게 설정을 바꾼다거나 하는 작업이 필요 해집니다. 


이럴경우 좀 번거롭게 되는것이 사실입니다. 


그래서 그냥 간단하게 외부 라이브러리 없이 Async하게 작업을 구동시키는 컴포넌트를 만들고,  내부URL에서만 접속가능한 Controller를 만들어서 패키지를 모든 배포하고 cronjob을 한대의 서버에서만 셋팅해서 내부 URL을 원하는 타임에 호출하게 해주면 어떨까 생각해 봤습니다.


interface 

PvpRankingRewardWorker.java 



Implementation
PvpRankingRewardWokerImpl.java


Controller코드는 간단하므로 생략했고, 

cronjob에는 wget같은 유틸을 이용해서 wget URL 같이 등록을 해주면 될것 같습니다.


이런방식이 Spring batch나 Quartz를 사용하는 방식보다 간단해 보이는데 어떻게 생각하시나요?






Posted by Breeze.Kang

댓글을 달아 주세요