Skip to main content

글로벌소프트웨어를 꿈꾸다 를 읽고나서

글로벌 소프트웨어를 꿈꾸다

책은, 앞으로 한국의 소프트웨어 회사에서 지향해야 것이 아주 자세히 기술되어 있다.
책의 내용은 아주 간단하다. 1)코딩하기 이전에 SRS 적고, 2)소스관리시스템, 3)이슈(버그)관리시스템을 사용해야 한다는 것이다. 너무 쉽고 너무나도 알려져 있는 사항이다. 그러나 것을 제대로 실행하고 있느냐가 문제이다.

본인은 일본에서 8~9 가량 유학생활을 하면서, 파트타임으로 일본의 중소기업 (50명이내)에서 소프트웨어를 개발해 왔다. 그러나, 그들의 일하는 패턴은 저자가 서술한 실리콘밸리에서의 근무형태와 비슷했다. 사업이 시작되면 먼저 매니저가 고객과의 회의를 통해 전체적인 분석을 하고 문서화한다. 그리고 문서를 가지고 다시 고객을 찾아가 토의한 다음 문서를 보다 구체화시킨다. 최종적으로 고객과의 합의 문서를 기반으로 소프트웨어를 설계하기 시작한다. 설계가 어느 정도 되면 다른 엔지니어와 함께 토의를 차례 거처 설계문서를 완료한다. 단계가, 전체 공정 거의 절반(50%)이다. 다음은 사내 인력과 외부인력 (아르바이트포함)으로 실제 코딩작업에 들어간다. 작업이 전체공정 3분의 1 차지하게 되고, 나머지는 납기일까지 unit테스트, 통합테스트를 거쳐, 개발이 완료되고, 고객에게 납품을 한다. 여기서 프로젝트의 모든 업무가 완료된다.

회사의 규모는 우리회사와 비교조차 되지 않는다. 년간 매출이 100배 이상 차이가 난다. 하지만, 그들의 업무형태와 효율은 우리보다 상당히 뛰어나다. 우리가 앞으로 지향해야 것은 너무나도 뻔하다.a

우리나라사람들은 초등학생 바른 생활이라는 교과목을 배운다. 내용은 너무나도 간단한 부터 시작한다. 어른들을 만나면 공손히 인사를 한다. 길에 쓰래기가 버려져 있으면 주워서 쓰레기통에 버린다.
등등. 우리는 이런 사실들을 알고 있다. 하지만 지키고는 있지 않다. 오히려 어떤 이가 행위들을 지키면 뉴스나 신문에 나오기도 한다. 이상한 세상이다. 당연히 해야 일을 하면 어리석어 보이고, 오히려 지키지 않는 이들을 추종하는 이들이 많은 현실이 안타까울 뿐이다.

한편, 저자는 엔지니어는 중간에 관리직으로 이전해서는 된다고 기술하고 있다. 이미 선진국에서는 관리직으로 이전하는 이들이 적다. 이웃 나라인 일본만 하더라도, 백발이 50세 이상의 베테랑 엔지니어들이 많이 근무하고 있다. 그들은 젊은 엔지니어들의 활동량에는 비길 없지만, 그들의 경험, 노하우, 견지능력은 놀랍다. 그러나 그들이 젊은 엔지니어들 보다 기술 습득능력이 뛰어나다라고 말할 없지만
말이다. 실례로 내가 일본회사에서 뭔가를 개발하고 있을 , 이론과는 달리 해결되지 않는 프로그래밍이 있었다. 상황을 베테랑 엔지니어에게 설명한 조언을 구하니, 아주 쉽고 명료한 해결책을 가르쳐 주었다. 것은 그가 나보다 기술이 좋아서가 아니라 많은 유사한 경험이 있어서 이다. 결국 연구 개발에서는 기술과 도구가 변하더라도, 본질적인 내용은 불변하기 때문이다. 마치 우리 인간이 태어나서 죽을 때까지의 행위의 본질이 원시인이던 현대인이던 같은 것과 같이 말이다.

저자가 주장하고 있는 사항들은 이미 선진국에서 증명되었다. 이제 문제는,
것을 우리들도 하던지 아니면 이전과 같이 비효율적으로 것인지를 결정하는 것이다.
결정권은 한국회사의 형태상 경영자에게 있고, 판단이 내려지면 하위 조직원들은 지시를 따라서 보다 나은 제도를 만들어야 것이다. 하루 빨리 우리도 기타 선진국들과 같이 엔지니어가 일하기 좋은 환경이 구축되었으면 하는 바램이다.

Comments

Popular posts from this blog

사자성어(가)

奇想天外(기상천외) 보통 사람이 쉽게 짐작할 수 없을 정도로 엉뚱하고 기발한 생각 技成眼昏(기성안혼) 재주를 다 배우니 눈이 어두워짐. 늙어서 재주가 쓸모 없게 됨 起承轉結(기승전결) 한시의 詩 作에서, 절구체의 전형적인 구성법을 지칭 제1구를 기구, 제2구를 승구, 제3구를 절구, 제4구를 결구 문장 구성에 있어서의 4단계, 서론, 설명, 증명, 결론 寄與補裨(기여보비) 이바지하여 돕고 부족함을 보태어 줌. 杞人之優(기인지우) 杞나라 사람의 군걱정이란 뜻. 곧 쓸데없는 걱정이나 무익한 근심을 말함.(=杞憂) 旣張之舞(기장지무) 이미 벌린 춤. 이미 시작한 일을 중간에서 그만 둘 수 없다 騎虎難下(기호난하) 이미 시작된 일을 중도에서 그만 둘 수 없음을 비유한 말 騎虎之勢(기호지세) = 기호난하 奇貨可居(기화가거) 진기한 물건을 사 두었다가 때를 기다리면 큰 이익을 볼 수 있다 吉祥善事(길상선사) 매우 기쁘고 좋은 일 吉凶禍福(길흉화복) 길한 일, 흉한 일, 언짢은 일, 복된 일 寄與補裨(기여보비) 이바지하여 돕고 부족함을 보태어 줌. 杞人之優(기인지우) 杞나라 사람의 군걱정이란 뜻. 곧 쓸데없는 걱정이나 무익한 근심을 말함.(=杞憂)  B A B A B A B A B A B A B A

SDN(OpenFlow) 개요

OpenFlow는 SDN(Software Defined Network)의 하나의 콤포넌트이다. 아래는 2013/3/13 오픈프로우 코리아 주최로 열린 한국 SDN Interest Group 4번째 정기세미나의 내용이다. 다음에는 꼭 모임에 참석하고 싶다. SDN Architecture including OpenFlow 위 그림에서와 같이, Control Layer부분과 Application Layer부분이 최근 활발히 연구개발되고 있다. 그 중 Control Layer부분은 Controller가 많은 비중을 차지 하는데, 다음 절에서와 같이 이미 많은 벤더들이 많은 OpenFlow 기반의 Controller를 제공하고 있다. 그외 소규모 벤더들은 Controller가 아닌 Application Layer에서 보안, 로드벨런싱, 홈네트워크 등의 서비스가 지원되는 제품 개발에 힘쓰고 있다. SDN에서는 Router라는 명칭 대신, Switch라는 명칭을 사용하는데, 이는 Router보다 더 단순한 기능을 수행하고, 기존 레거시와 차별화를 위해 명명된 것으로 보인다. 또한, Switch를 반드시 벤더로부터 구매할 필요가 없다. 상황에 따라 리눅스 등의 운영체제를 기반으로 자체 개발이 가능하다. Controllers의 종류 SDN의 Controller 가운데 Open Source로 운영되는 것은 다음과 같다. 대부분 Java언어로 구현되어 있다. 따라서 플랫폼 또는 인프라 개발자라면 Java에 능숙해야 한다. NOX C++/Python Beacon Java Floodlight Java Maestro Java RouteFlow NOX, Quagga 보안을 위한 Open Source FortNOX Java 기반의 SE-FloodLight  공격 감지  인증  스위치의 Flow 처리 성능 고려 FRESCO OpenFlow Contro...

SAStruts란

SAStruts 개요 Struts는 Spring Framework 다음으로 많이 사용되고 있는 FrameWork이다. Struts는 프레임워크로 강력한 기능을 제공한다. 하지만, 개발 과정에서 부수적인 설정 작업이 개발자들을 힘들게 했다. 이 문제를 해결하기 위해, 일본 개발자 커뮤니티 Seasar(일본 오키나와의 전설 동물, 우리나라의 해태와 비슷^^) 에서 개발한 프레임워크가 SAStruts(Super Agile Struts)이다. 아래 아키텍처 그림과 같이, SAStruts의 모태는 Struts이다. 다만, 상기한 복잡하고 까다로운 설정 작업을 그림2와 같이 SAStruts가 개발자 대신 내부적으로 처리해 준다. 예를 들어, Struts는 항상 struts-config.xml을 읽고 Action 클래스를 호출한다. 이 때문에, 개발자는 소스 코드를 수정한 후, 늘 struts-c onfig.xml 파일을 검토 또는 수정해야 한다. 또한, 대형 프로젝트일 경우는, 이 struts-config.xml 파일이 경합을 자주 일으킨다. 이는 실로 개발자의 스트레스 치수를 높이는 원인이다. 반면, SAStruts는 이 번거로운 작업을 알아서 처리해 준다. 아리가또~~~ 입니다. 그림1 Struts 아키텍처 그림2 SAStruts 아키텍처 그럼, 이 번거로운 작업을 SAStruts는 어떻게 처리하는 것인지 궁금할 것이다. 그것은 Java의 annotation기술을 이용한 점이다. 예를 들어, @Execute, @ActionForm, @Resource 등 Seasar 커뮤니티에서 제공하는 Dolteng 플러그인을 사용하면, SAStruts 개발이 더욱 효율적이다. SAStruts 프로젝트는 다음과 같은 패키지 구조로 형성된다. [root package].action Action 클래스 [root package].condition 데이터베이스에 엑세스하는 조건 설정 [root p...