시스템 특징에 적합한 설계와 구현의 지침인 아키텍쳐 를 작성하고, 이것을 개발팀 전원이 파알할 수 있도록 하는 것이다. 이를 통해 시스템의 품질을 끌어 올린다. 다수가 참여하는 프로젝트에서 아키텍트의 주된 업무는설계 단계에 진행된다.
아키텍트는 설계 단계 전까지 준비한 아키텍쳐를 개발팀에게 전달 하고, 팀원들이 아키텍쳐 설계서에 따라 설계와 구현을 할 수 있도록 지원 한다.
- 아키텍트 이야기 -
정보시스템에 대한 전반적인 지식과 시스템 구축 노하우를 보유한 경험이 풍부한 기술 전문가로서
프로젝트 전반에 대한 기술적인 총괄 책임을 담당한다.
아키텍처 정의에서 아키텍트가 수행 하여야 하는 업무로서 프로젝트에서 구축 하고자 하는 정보 시스템의 기반 구조를 정의한다.
기반구조의 정의에는 시스템 플랫폼,운영 및 개발환경,표준 프로토콜,소프트웨어/하드웨어 솔루션 벤치마킹및 선정 ,시스템 인터페이스 관계 정의,데이터 분산 및 통합 방안등 시스템의 기본적인 골격에 관련된내용을 포함 한다.
- SI Project (전문가로 가는길) -
즉, 쉽게 설명하면 분석시에 업무담당자 한테 시스템 모모 필요 하니? 필요한 청사진 그리고 설계 단계에서 좀더 구체적으로 표준안 잡고 프레임웍 구축하고 개발자 교육하고
테스트 하는 일련에 Application A~Z까지 전체 총괄하는 롤이라고 이해 하시면 됩니다.
* 아키텍트 수행 역할
- 프로젝트 착수 시 제안서와 계약서를 검토하여 기본적인 소프트웨어 및 하드웨어 아키텍쳐 환경에 대안 초안을 작성 한다.
- 분석 단계에서 전체 시스템에 대한 아키텍쳐 정의를 통해 소프트웨어 및 하드웨어 인프라 구조 정의,
서버 및 네트워크의 기본 모델 정의, 어플리케이션 모듈의 최상위 수준 모델링 등을 수행한다.
- 분석 단계에서 프로세스 모델링 및 데이터 모델링을 수행할 때 시스템 기본 아키텍처를 준수하도록 분석 산출물에 대한 검증을 수행한다.
- 소프트웨어 개발 환경 표준을 정의한다. 소프트웨어 개발을 위한 개발도구의 선정과 프로토타이핑를 주관한다.
- 설계 단계에서 프로그램 및 데이터베이스에 대한 설계 내용을 아키텍처 관점에서 표준의 준수 여부를 검증한다.
- 시스템 테스트 시나리오에서 아키텍쳐와 관련된 시스템 테스트 시나리오의 작성을 총괄 한다.
* 아키텍트에게 요구 되는 것
※상,중,하는 역량의 중요도 입니다.
- 비용관리 (하)
- 일정 관리 (하)
- 요구 사항정의(하)
- 명세 수립 (중)
- 소프트웨어 설계 (상)
- 프로그래밍 (상)
- 개발 방법론 (상)
- 인프라 구축 (중)
- 테스트 방법 (중)
- 품질 관리 (하)
AA Role
[AA Role] 프로젝트 계획단계
계획단계에서 AA의 역할은 기업마다 크게 달라짐
- 업무 분석 주도 및 문서화
- PM을 지원하여 프로젝트 범위 정의
- 필요한 시간과 리소스 산정
- 외부 어플리케이션과의 인터페이스 정의 및 설계
1) AA는 프로젝트에서 사용될 기술을 선택한다
: 기업수준 --> 하드웨어, 운영체제, 소프트웨어, 언어 등
AA수준 --> ex) XML parser, third party package, utility 등
2) AA는 프로젝트에서 사용할 개발방법론과 프레임워크를 추천한다
3) AA는 어플리케이션의 종합적인 설계와 구조를 제공한다
4) AA는 어플리케이션 설계를 적절하게 문서화해야 한다
: 설계 문서화는 개발자들과 커뮤니케이션 하는 중요한 단계
: 문서는 프로젝트 중간에 사람이 교체되더라도 프로젝트가 제대로 유지될 수 있도록 한다
5) AA는 코드 작성 가이드라인을 수립한다
: 예외처리, 로깅, 테스트, 스레딩, 캐싱, 설정 등
6) AA는 인프라스트럭처 요구사항을 정의한다
[AA와 사람들] AA와 PM
1) AA는 PM에게 구현 작업을 식별해주어야 한다
: AA는 PM이 현실적으로 프로젝트 계획과 산정을 할 수 있도록 도와주어야 한다
2) AA는 PM을 도와 관리를 위한 프로젝트 비용과 효과를 산정한다
3) AA는 PM이 개발자 위치에 대한 인사결정을 할 수 있도록 도와준다
4) AA는 PM에게 기술적인 충고와 가이드를 제공해야 할 책임이 있다
[AA와 사람들] AA와 PL
1) AA는 PL에 의해 결정된 어플리케이션 요구사항이 적절한지 확인할 책임이 있다
AA와 사람들] AA와 디자이너
1) AA는 레이아웃이 기술적인 타당성을 갖는지 확인할 책임이 있다
AA와 사람들] AA와 업무 로직 개발자
1) AA는 업무 로직 개발자에게 가이드를 제공한다
: 업무로직 개발자는 엔터프라이즈 빈, 웹 서비스, 배치 작업, 업무 객체, 데이터 액세스 객체 등의 코드를 작성할 책임을 지닌다
AA와 사람들] AA와 데이터 모델러
1) AA는 데이터 모델이 적절한지 확인할 책임이 있다
: 데이터 모델러는 업무 분석가로부터 제공되는 정보를 사용하여 어플리케이션이 데이터베이스에 저장하는 모든 데이터를 식별하고, 정의하며
목록을 작성한다. (ER 다이어그램 작성)
AA와 사람들] AA와 데이터베이스 관리자
1) AA는 데이터베이스 관리자와 함께 작업하여 데이터베이스 저장소에 관련된 이슈나 문제를 해결한다
: 데이터베이스 관리자는 어플리케이션에 대한 업무 요구사항에 기초하여 데이터베이스 설계를 수행하고, 어플리케이션을 위한 데이터베이스 환경을
만들고 유지보수한다.
2) AA는 데이터 이관 요구사항이 이관 전문가에게 잘 제공되는지를 확인한다
AA와 사람들] AA와 테스트 전문가
1) AA는 테스트 전문가와 함께 작업하여 필요한 인프라스트럭처 요구사항과 자원을 식별한다
[출처] Java EE 아키텍처 핸드북 2판 - 성공적인 아키텍
아키텍트
아키텍트
아키텍트는 전체 시스템을 디자인하고 설계하는 역할을 가지는 사람이다.
아키텍처링은 크게 두가지로 나뉘어 지는데 첫번째는 비지니스 아키텍쳐, 다음은 테크니컬 아키텍쳐이다.
비 지니스 아키텍쳐랑, 해당 시스템이 비지니스적으로 어떤 의미를 갖는지에 대한 내용으로 사업 전략,비젼,요구사항 분석과 같은 범주와 관련이 된다. 시스템의 구현 목적은 어떤 비지니스의 목적을 달성하기 위함이다. 사업 전략이야 COO 분들이나, 아니면 비지니스 컨설턴트가 진행을 하기는 하지만, 비지니스 요건을 어떻게 시스템으로 구현하여 효과를 낼지는 IT 아키텍트의 역할이다. 그래서, 비지니스에 대한 아키텍쳐링도 매우 중요하다.
다음이 테크니컬 아키텍쳐인데, 전체 시스템의 그림을 그리고, 비지니스 요건을 충족하기 위한 기술적인 설계를 하는 역할이다.
강조하고자 하는 바는 비지니스 요건을 잘 이해해야 한다는 것이다.
예를 들어 분산 트렌젝션 요건이 있다고 하자. "주문과 결재" 두가지 기능을 묶어야 할경우, 여러가지 선택이 있다.
XA기반의 분산 트렌젝션을 사용하는 방법, 보상 트렌젝션 처리, 로깅을 통해서 유실분에 대한 처리, 아니면 유실되는 것 데로 놔두는 것...
고급 기능과 아키텍쳐에는 돈이 든다. 물론 XA기반으로 구현하면 좋겠지만, 해당 시스템이 느린 경우 LOCK 경합 문제가 발생할 수 도 있고, 복잡도가 높아지는 만큼 테스팅에 대한 코스트도 높아진다.
유료 회원 가입 프로세스 경우 차라리 에러가 나는데로 놔두는 것이 비용 측면에서 훨씬 유리할 수 있다. 공짜로 가입되었다고 Complain할 사람은 그리 없으니까는.
즉. 완벽한 보안 장치를 하기 위해서, 서랍에 자물쇠를 하느냐 몇천만원짜리 지문 인식 장치를 하느냐가 아닐까?
아키텍트의 능력 중에서 중요한 것은
숲을 보는 능력
아키텍트는 전체 시스템을 보는 능력이 매우 중요하다. 개개의 시스템과 구현 방법에 대해서는(나무를 보는 능력) Senior Developer만으로도 충분하다. 전체 시스템을 조망하고, 그 방향을 잡는 조타수의 역할이 아키텍트이다.
기술에 대한 폭 넓은 지식
제대로 된 설계를 하기 위해서는 어떤 기술이 적절한지 장단점과 위험 요소는 무엇인지를 파악해서 적재 적소에 알맞은 기술을 배치해야 한다. 아니면. 결국 벤더 영업이나 마케터 손에 놀아나게된다. 마치 피라미드 그룹에 걸린것 처럼.
현실을 인지하는 능력
아키텍쳐는 현실적이라야 한다. 아무리 좋은 아키텍쳐라도 금액과, 수행하는 팀원의 능력에 맞지 않으면 말짱 도루묵이다. 적절한 시간과 Learning Curve에 드는 시간도 충분히 고려되어야 한다.
그리고 인맥
왠 갑자기 인맥이냐라고 할 수 있지만. 아무리 뛰어난 아키텍트라도 여러 프로젝트를 경험해보기는 쉽지 않다. 인맥을 통해서, 경험을 공유하고, 문서 템플릿, Reference Architecture, Delivery methodology등을 수집할 수 있는 것은 좀더 안정적이고 성숙된 아키텍쳐를 설계할 수 있는 빠르고 확실한 방법을 제공한다.
커뮤니케이션
아키텍쳐는 기존의 아키텍쳐나 이해관계, 또는 새로운 도전등에 대한 반감에 부딪히기 쉽다. 이를 논리적으로 설득하고, 함께 일할 수 있는 협업 분위기를 만드는것 역시 아키텍트의 역할이다.
프로젝트를 하다보면 많은 AA (Application Architect)를 만난다. 프로젝트의 꽃이자 기술의 마지노선이 AA이다.
그런데 국내 AA를 보면, 숲보다는 나무를 보는 경우가 많고, 중반 이후에는 아키텍쳐에 대한 책임을 지지 않으려는 방어적인 자세로 가는 경우를 종종 봐 왔다. 실제적으로 AA에 대한 시간 배정과 역할에 대한 이해가 부족한 면도 있고. AA 들 자체가 좀더 전략적인 사고 를 가질 필요가 있다.
'Architecture' 카테고리의 다른 글
개발방법론 (0) | 2020.08.25 |
---|---|
Software Architect란? (0) | 2020.08.25 |
[ 아키 ] Function Point를 활용한 소프트웨어 비용산정 (0) | 2015.01.29 |
[ 아키] 웹기획 이란? (0) | 2011.12.19 |