-
[비공개] 소프트웨어 설계 2.0
현장에서 보통 "설계"라는 말을 하면 대개는 화면 요구사항 도출과 데이터 모델(ERD를 결과로 내놓는) 작성을 의미한다. 물론, 파레토 법칙을 감안해서 이해해야 한다. 주류에 속하는 다수가 그렇다는 말이다. 현실에 만족하는 개발자가 말하는 설계와 다른 맥락의 설계가 있는데 여기에 대해 상당수가 합의하고 있음도 어렵지 않게 알 수 있다. 징후는 꽤 많다. '한국에 과연 설계가 있느냐?'라고 말하는 사람 사랑스러운 책, Domain-Driven Design 실증적인 설계 접근을 제시하는 TDD(Test Driven Development) 다른 산업의 발전 양상 머지않아 이 바닥 10년을 맞이한다. 한 분야에서 10년을 하면 고수가 된다고 한다. 고수가 되고 싶지는 않지만, 인생을 허비하지 않기 위해 남은 날에 대해 목표를 설정했다. 현재 통용되는 설계와 다른 설계를 하겠다고 마음을 먹는다. 의..추천 -
[비공개] 엔터프라이즈 시스템 개발 프로젝트에 Enterprise 2.0 대입하기
* 이 글은 월간 마이크로 소프트웨어에 기고했던 글을 잡지사측 배려로 공개하는 내용입니다. 소통과 협업을 강화하는 프로젝트 문화 조성하기 약 2년 전 일이다. 프로젝트 스폰서인 임원이 대뜸 회의를 자주 소집하지 말고 포털 사이트 블로그 같은 시스템을 구축해서 서로 이야기하자고 말했다. 메신저도 연동하고, 한 주제에 대해서 개발 업체와 고객 사이에 치열하게 논쟁하기 위해 장벽을 허물자는 것이다. 소신이 워낙 강해서 개발업체 프로젝트 관리자에게 의사소통을 위한 시스템을 구축한 이후로 착수를 미루자며 엄포를 놓았다. 아쉽게도 프로젝트 관리자가 거부하여 기회(?)는 날아갔다. 프로젝트에서 고객과의 활발한 의사소통이 프로젝트 성공에 미치는 영향은 지대하다. 하지만, 당시 프로젝트 관리자는 고객 수장이 블로그를 언급..추천 -
[비공개] DAO JUnit 테스트 Tips
1. 테이블 초기화 성능 향상 AbstractTransactionalJUnit4SpringContextTests(JUnit 4.x/Spring 2.5) 객체나AbstractTransactionalDataSourceSpringContextTests (JUnit 3.x/Spring 1.1)가 제공하는 deleteFromTables() 메소드는 하나 이상의 테이블에 있는 레코드 삭제를 돕는다. 테스트 메소드 내에서 레코드를 초기화 하는데 편의를 제공하지만, 테이블에 레코드가 많을 때는 조심해야 한다. 수만 건 정도만 되어서 몇 초가 걸리고, 천만 건 이상이면 불필요한 DB Lock을 유발하기도 한다. 이를 피하기 위해 simpleJdbcTemplate/jdbcTemplate 멤버 변수를 통해 DELETE 쿼리를 직접 실행하면 성능 저하를 막을 수 있다. jdbcTemplate.execute("DELETE FROM " + TABLE_NAME + " WHERE id = '0011'"); insertXlsData("code.xls"); // id = "0011" assertEquals(3, jdbcTemplate.queryForInt("SELECT COUNT(id) FROM " + TABLE_NAME + " WHERE id = '0011'")); 2. 성능 측정을 위한 정보 제..추천 -
[비공개] Spring 3.0 GA 출시, 그리고 작은 기여
스프링 3.0 GA(General Availability) 출시가 내일이다. GA란 표현이 생소할 수 있는데 최종 버전 혹은 정식 버전을 의미한다. 스프링 3.0을 공부하고 있지도 않았고, 딱히 최종 버전을 쓰고 싶어 기다린 터도 아니라 동동 구르며 출시를 기다리며 쓴 글은 아니다. 솔직히 고백하면 유치하게도 자랑하고 싶어 올린 글이다. :) 금요일에는 분명히 열린 이슈가 4~5였는데 다시 늘었다. 그 중 하나의 이슈에 낯익은 이름이 있다. Toby형 글을 읽고 메신저로 이야기를 나누다가 발견한 옥에 티다. 스프링의 Javadoc에 대한 신뢰가 있었던 터라 오류가 믿기지 않아 우선 Toby형에게 확인을 부탁했다. 그리고 혹시나 낡은 코드를 보고 뒷북치는 일이 아닐까 해서 스프링 프로젝트 Trunk에 있는 소스를 직접 확인했다. 이미 할당한 작업이 있는지도 보았는데 없었다. 짧은 영어 실..추천 -
[비공개] 새로운 자바 기술을 소개하는 글
어제는 영양가 없는 글을 비판하는 가운데 Java EE 스펙을 거론했는데, Toby형을 통해 좋은 글을 알게 되었다. RSS 구독이 불가능해 놓치고 있던 한국IBM DW의 칼럼이다. 이창신님의 자바 EE 6에서 의존성 주입은 그야말로 최신 글이고, 새로운 내용을 대하는 독자의 생소함을 생각해 무난히 따라 해 볼 수 있도록 썼다. 그리고, 얼만전까지 Java EE나 Servlet 3.0 과 같은 새로운 스펙에 대한 실용적인 글이 연재되었다. S 서블릿 3.0에서 파일 업로드 (2009년 10월) 넷빈즈 6.8로 자바 EE 6 시작하기 (2009년 9월) 3년을 기다렸다 (2009년 6월) Toby 형이 쓴 글도 있다. 자바 스펙을 직접 다루지는 않았지만, 자바 진영에서 일어나는 DI(Dependency Injection)의 발전과정을 그대로 담은 스프링의 애노테이션에 대한 글이다. Spring 3.0 (56) @Bean 사용의 주의사항 요구하는 배경 지식..추천 -
[비공개] TOGAF Enterprise Continuum 소개
Using a combined SOA and TOGAF environment for increased productivity: Part 1: Introduction to the TOGAF Enterprise Continuum 오늘 DW가 좋은 글을 많이 올린다. 요약을 시작하는 문구부터 마음에 든다. Service-oriented architecture (SOA) can transform organizational silos into functional groups, thereby measurably increasing productivity. 그리고, 현실 인식이다. At present, both the Open Group Architecture Framework (TOGAF) and SOA are unapproachable and poorly understood. 이후에 스크랩해 둘만 한 그림이 연속으로 보인다. 최상위 개념도 Architecture Continuum의 여러 상태(혹은 단계)를 나타내는 그림 그리고, 상태 전이(혹은 단계 전진)의 특성을 명쾌하게 정리했다. From conceptual to logical to physical From technology solutions to business technology systems From industry-neutral to vertical business domain-compliant architectures From general taxonomies to physical architectu..추천 -
[비공개] 이클립스 3.6 (헬리오스) 릴리즈 계획
M1 Friday, August 21, 2009 M2 Friday, October 2 M3 Friday, November 13 M4 Friday, December 18 M5 Friday, February 5, 2010 M6 Friday, March 19 EclipseCon! March 22 M7 Friday, May 7 RC1 Friday, May 21 RC2 Friday, May 28 RC3 Friday, June 4 RC4 Friday, June 11 Release Wednesday, June 23 출처: Helios Simultaneous Release 이유는 모르겠지만, 다른 문서와 일정 차이가 조금 있다. 구체적으로 알고 싶으면 구글 카렌더를 공유한다.추천 -
[비공개] 비즈니스 프로세스 처리 관련 좋은 모델
The Timeline/Milestone pattern라는 글을 보는데 마침 고민하던 문제라 모델이 한눈에 들어왔다. 결산 프로세스에 대해 고민하던 중이어서인지 꽤 인상적이다. 기사가 다룬 문제는 지표까지 관리한다는 점이나 특정 기술을 전제하고 있어 차이가 있지만,참조할 내용이 있다는 점만으로도 고마운 그림이다. 도해(diagram)를 사용함에 있어서도 문제 상황을 보여주는 그림 정보의 구성을 다룬 그림 그리고, 주요 상태도 시스템 수준의 큰 그림 핵심이 되는 컴포넌트의 상호작용을 그린 그림은 훌륭한 모델링 결과이고 효과적인 전개다. 모델링을 하려면 이 정도는 해야 할텐데...추천 -
[비공개] Spring Framework vs Java EE
JBoss 월드에서 "Java EE and the Spring Framework: Compare/Contrast"란 제목의 발표가 있었나 보다. 웹에 발표자료를 공개하고 있다. 작동하는 제품이 아니라 스펙인 Java EE와 제품을 비교하는 이유가 궁금했지만, 결국 잘 포장된 FUD로 컨퍼런스 참가자를 현혹할 의도가 아니었나 의심하게 하는 내용이 눈에 띈다. 출발점과 결론을 기록한 박스의 내용은 수긍이 가지만, Java EE와 Spring 프레임워크 비교는 한심하다. 이제는 지루할 지경인 XML 논쟁이 2009년에도 등장한다. 만일, 스프링 설정이 복잡하다고 기술적인 비교를 하려면 정의에 지나지 않는 Java EE가 아니라 Java EE를 구현한 제품의 모든 설정과 Spring(혹은 Spring + Tomcat)이 요구하는 설정을 비교해야 하지 않을까? Java EE 두 번째 항목을 보면 발표자의 수준을 의심할 수 있다. Non-redundant APIs with specialized roles 꾸러미 성격..추천 -
[비공개] 소통과 협업을 강화하는 프로젝트/조직 문화 조성
마침 DW에 올라온 글을 보고 어제 트위터에서 본 후배의 푸념이 생각났다. 예전에 형상관리도구 사용에 반감을 품은 개발자를 개발자/팀을 자주 만나곤 했다. 파일서버를 쓰거나 빌드 시점에서 한꺼번에 코드를 통합해오던 습성을 가진 개발자/팀에게 형상관리시스템 적용은 코드를 관리가 어렵게 하는 제약으로 비춰지는 듯하다. 그도 그럴 것이 SVN을 쓰고 나서는 골치 아픈 충돌을 해결하는 과정이 생겨 무척 번거롭게 볼 수도 있다. 요즘은 CI 도구를 사용하는데, 뒤로 미루던 통합 작업을 당겨서 일상으로 만드는 역할을 한다. 만일, SVN/CVS 사용에 큰 무리가 없는 팀이라면 CI 도구 적용에 큰 거부감이 없다. 하지만, SVN/CVS을 파일서버 대용으로 쓰는 식으로 충돌이 발생하지 않게 작업하는 조직이라면 CI 도구 적용은 요원할 수 있다. 보통 이런 팀은 통..추천