-
아키텍트Technique/ETC 2017. 6. 13. 10:19반응형
개발자로 시작한 사람들이 꿈꾸는 길은 과연 무엇을까? 어쩌면 높은 수준의 고급 개발자가 되는 것이 가장 일차적인 꿈이긴 하겠지만, 어느 정도 수준에 올라간다면 아마 설계자나 아키텍트를 꿈꾸지 않을까 생각해본다. 하지만, 아키텍트라는 분야는 단순히 프로그래밍만을 잘 한다고 해서 갈 수 있는 길이 아니기에 해야 할 공부도 상당히 많다. 특히 IT 분야에서는 아키텍트가 설계, 프로그래밍, 그리고 테스트 과정 뿐만 아니라 프로젝트 전반에 대한 공정, 인력, 비용,
산출물 등을 고려해서 진행을 해야 함으로 매우 어려운 분야라 할 수 있다.
그렇다면 아키텍트가 되기 위해서는 준비해야 하는 과정은 어떤 것이 있을까?
아마 다른 무엇보다도 제일 먼저 준비해야 할 것은 사용자 요구사항을 이해하고 분석하는 설계 과정이 아닐까 싶다. 이 과정을 가장 먼저 언급하는 이유 중 하나는 프로그래밍을 집중적으로 하는 사람들이 가장 꺼려하는 부분중 하나가 바로 사람들과의 만남으로 보기 때문이다. 실상 우리가 프로그래밍을 하는 이유는 결국 프로그램을 통해 편리함을 얻기 위한 것이기에 사용할 사람들의 의견을 듣고 설계하는 것이 매우 중요하다. 하지만, 일반적으로 개발자는 이 과정을 매우 버거워 하는 경향이 있다. 아마도 그러한 이유는 프로그래밍과는 다르게한 사람이 전체의 과정을 주관하기 보다는 많은 사람들이 서로 각ㄱ기 다른 의견을 내거나 심지어는 아주 상반된 의견을 낼 때 조율하는 과정이 만만치 않기 때문일 것이다. 따라서 많은 분들이 이 부분을 회피하려고만 하는데 진정으로 아키텍트가 되고 싶다고 생각한다면 반드시 극복해야하는 문제이다.
일단 사용자의 분석 설게에 대한 과정에 어느 정도 능력이 갖추어 진다면 그 다음 배워야할 분야는 효율적인 프로젝트 관리 분야이다.( 보통은 )
다양한 서적에는 아키텍트가 되기 위해 디자인 패턴이나 UML 등 기술적이 부분을 강조하는 경우가 많은데 이 부분뿐만 아니라 프로젝트라는 큰 과정을 어떻게 이끌어가야 할 지를 배워야한다. 왜냐하면 우리가 아키텍트가 되고자 하는 것은 단순히 툴이나 기술을 익히기 위해서가 아닌 고객이 원하는 결과물을 만들어 내는 것이기에 프로젝트를 효율적으로 관리할 수 있는 능력을 갖추는 것이야 말로 아키텍트가 반드지 지녀야할 덕목이라 본다.
프로젝트 관리를 잘한다는 것은 앞서 언급한 것처럼 정해진 기간 내에 원하는 사양에 맞추어 일을 끝내는 것뿐만 아니라 프로젝트 예산수립 부터 인력관리, 산출물 관리까지의 총제적 관점에서 일컫는 말이다. 즉 프로젝트를 운영할 수 있다. 따라서 이러한 능력을 갖춘다는 것은 개발에 대한 능력뿐만 아니라 전반적인 관리능력을 갖추어야 하는 것을 의미하기에 매 프로젝트마다 틈틈이 프로젝트를 어떻게 관리하는지 이해하려 하는 것이 좋다.
프로젝트 관리에 대해 어느 정도 능숙해진다면 마지막으로 준비해야 하는 부분은 프로젝트 포트폴리오 관리라고 생각한다. 이 부분에 대해서는 사람에 따라 달리 보는 분들도 있는데, 내 관점에서는 이 부분이야말로 아키텍트로 가는 매우 중요한 영역이라고 생각한다. 즉 , 다시 말해 프로젝트 관리 역량을 갖추게 된 뒤에 다수의 프로젝트를 동시에 진행할 수 있는 능력을 갖추어야 하는 것을 의미하는데, 때에 따라서는 현재 진행중인 프로젝트 들을 파기할 수 있는 능력도 갖추어야 한다고 본다. 물론, 이 과정은 매우 쉽지 않은 것들을 포함하고 있다. 다수의 프로젝트간에 서로 영향을 주는 경우에는 이를 조율하는 작업이 만만치 않기 때문이다. 실제 대형 프로젝트의 경우에는 작은 프로젝트들로 구성되어 진행을 하는 경우도 많기에 아키텍트가 이러한 능력을 갖는 것은 매우 중요하다고 본다.
또한 이렇게 다수의 프로젝트를 진행하다 보면 상황에 따라서 프로젝트들을 포기해야 하는 상황도 맞이하게 되는데 나는 아키텍트가 반드시 경험해봐야 하는 일이라고 생각한다. 누구에게나 이런 과정은 쉽지 않을 뿐만 아니라 특히 개발자의 경험을 가지고 있는 분들의 경우 진행 중인 프로젝트를 없앤다는 것은 어떤 의미인지 알기에 매우 힘들기는 하겠지만, 이 과정을 거쳐야만 진정한 의미의 아케텍트가 될 수 있따고 생각한다. 왜냐면 다소 관리적인 이 업무를 아키텍트가 해야 하는 것은 관련 프로젝트에 대해 누구보다도 잘 알고 있고, 또한 회사가 성공하기 위해서 아키텍트는 관련된 일들을 조정해야 하는 임무가 주어진다고 생각하기 때문이다. 때문에 많은 분들이 아키텍트라는 자리를 IT에 입문한 뒤에 한번쯤은 꿈을 꾸는 자리이지만, 막상 그 자리에 도달하게 되면 매우 어려움을 느끼기 때문이다.
반응형'Technique > ETC' 카테고리의 다른 글
자료구조 (0) 2017.05.25 좋은 프로그래머가 되는 24가지 방법 (0) 2016.10.21 [ 펌 ] 좋은 프로그래밍 습관 51 - 61 (0) 2016.10.21 [ 펌 ] 좋은 프로그래밍 습관 41 - 50 (0) 2016.10.21 [ 펌 ] 좋은 프로그래밍 습관 31 - 40 (0) 2016.10.21