🧩 개발 기술 환경 정의
(1) 개발 기술 환경 현행 시스템 분석
[1] 운영체제 현행 시스템 분석
[2] 네트워크 현행 시스템 분석
[3] DBMS 현행 시스템 분석
[4] 미들웨어의 현행 시스템 분석
[5] 오픈 소스 사용시 고려 사항
[1] 운영체제 현행 시스템 분석
운영체제 ( Operating System )의 개념
-> 컴퓨터 시스템이 제공하는 모든 하드웨어, 소프트웨어를 사용할 수 있도록 해주고, 컴퓨터 사용자와 컴퓨터 하드웨어 간의 인터페이스를 담당하는 프로그램
사용자가 컴퓨터를 좀 더 쉽게 사용하기 위해 지원하는 소프트웨어
운영체제 현행 시스템 분석
[ 품질 측면 ]
- 신뢰도
- 장기간 시스템 운영 시 운영체제의 장애 발생 가능성
- 운영체제의 버그로 인한 재기동 여부- 성능
- 대규모 및 대량 파일 작업 ( 배치 작업 ) 처리
- 지원 가능한 메모리 크기 ( 32비트, 64비트 )[ 지원 측면 ]
- 기술 지원
- 공급사들의 안정적인 기술 지원
- 오픈 소스 여부- 주변 기기
- 설치 가능한 하드웨어
- 다수의 주변 기기 지원 여부- 구축 비용
- 지원 가능한 하드웨어 비용
- 설치할 응용 프로그램의 라이선스 정책 및 비용
- 유지 및 관리 비용
PC 운영체제
- Windows
- 중/소규모 서버, 일반 PC 등 유지, 관리 비용 장점- UNIX
- 대용량 처리, 안정성 높은 엔터프라이즈급 서버- Linux
- 중/대규모 서버 대상, 높은 보안성 제공모바일 운영체제
- 안드로이드
- 리눅스 운영체제 위에서 구동하며, 휴대폰 전화를 비롯한 휴대용 장치를 위한 운영체제와 미들웨어, 사용자 인터페이스 그리고 표준 응용 프로그램(웹 브라우저, 이메일 클라이언트, SMS, MMS )등을 포함하고 있는 소프트웨어 스택이자 리눅스 모바일 운영체제- iOS
- 스마트폰, 태플릿PC의 높은 보안성과 고성능 제공
네트워크 현행 시스템 분석
1. 네트워크의 개념
- 네트워크는 컴퓨터 장치들의 노드 간 연결 ( 데이터 링크 )을 사용하여 서로에게 데이터를 교환할 수 있또록 하는 기술
- 데이터 링크들은 광케이블과 같은 유선 매체 또는 와이 파이(Wi - Fi)와 같은 무선 매체를 통해 확립됨.
2. OSI 7계층
- OSI 7계층은 네트워크 통신에서 생긴 여러 가지 충돌 문제를 완화하기 위해 국제 표준화 기구(ISO ; International Standardization Organization)에서 제시한 네트워크 기본 모델이다.
OSI 7계층 및 각 계층의 PDU
계층 설명 프로토콜 전송단위 응용 계층 사용자와 네트워크 간 응용 서비스 연결,데이터 생성 HTTP, FTP 데이터 표현 계층 데이터 형식 설정, 부호교환, 암/복호화 JPEG, MPEG 데이터 세션 계층 연결 접속 및 동기제어 SSH, TLS 데이터 전송 계층 - 신뢰성 있는 통신 보장
- 데이터 분할과 재조립, 흐름 제어, 오류 제어, 혼잡제어 등을 담당TCP, UDP 세그먼트(Segment) 네트워크 계층 단말 간 데이터 전송을 위한 최적화된 경로 제공 IP, ICMP 패킷(Packet) 데이터 링크 계층 - 인접 시스템 간 데이터 전송, 전송오류 제어
- 동기화, 흐름 제어 등의 전송 기능 제공이더넷 프레임(Frame) 물리 계층 0과 1의 비트 정보를 회선에 보내기 위한 전기적 신호 변환 RS-232C 비트(Bit)
3.네트워크 현행 시스템 분석
- 현행 시스템이 구성된 네트워크 구조를 네트워크 구성도를 통해 분석한다.
- 네트워크 구성도를 통해 서버 위치, 서버 간 연결 방식을 파악할 수 있다.
- 백본망, 라우터, 스위치, 게이트웨이, 방화벽 등을 대상으로 분석한다.
- 네트워크 분석 시 물리적인 위치 관계 파악, 조직 내 보안 취약성 분석 및 대응이 가능
- 네트워크 장애 발생 추적 및 대응 등의 다양한 용도로 활용할 수 있다.
[ 백본망(Backbone Network) ]
- 다양한 네트워크를 상호 연결하는 컴퓨터 네트워크의 일부
- 각기 다른 LAN이나 부분망 간에 정보를 교환하기 위한 경로를 제공하는 망
[ 라우터(Router) ]
- 3계층 데이터 패킷을 발신지에서 목적지까지 전달하기 위해 최적의 경로를 지정하고
- 이 경로를 따라 데이터 패킷을 다음 장치로 전달하는 네트워크 장비
[ 스위치(Switch) ]
- 2계층 장비
동일 네트워크 내에서
출발지에 들어온 데이터 프레임을
목적지 MAC 주소 (Media Access Control Addres)기반으로 빠르게 전달하는 네트워크 장비[ 게이트웨이(Gateway) ]
- 컴퓨터 네트워크에서
서로 다른 통신망, 프로토콜을 사용하는 네트워크 간의 통신을 가능하게 하는 네트워크 장비[ 방화벽(Firewall) ]
- 외부로부터 불법 침입과 내부의 불법 정보 유출을 방지하고, 내/외부 네트워크의 상호간 영향을 차단하기 위한 보안 시스템
DBMS 현행 시스템 분석
1. DBMS ( Database Management System )의 개념
- DBMS는 데이터베이스라는 데이터의 집합을 만들고, 저장 및 관리할 수 있는 기능들을 제공하는 응용 프로그램
2. DBMS의 기능 ( I/F )
- DBMS의 기능은 중복 제어, 접근 통제, 인터페이스 제공, 관계 표현 등을 제공한다.
기능 설명 중복 제어 동일한 데이터가 여러 위치에 중복으로 저장되는 현상 방지 접근 통제 권한에 따라 데이터에 대한 접근 제어 인터페이스 제공 사용자에게 SQL 및 CLI, GUI 등 다양한 인터페이스 제공 관계 표현 서로 다른 데이터 간의 다양한 관계를 표현할 수 있는 기능 제공 샤딩/파티셔닝 구조 최적화를 위해 작은 단위로 나누는 기능 제공 무결성 제약조건 무결성에 관한 제약조건을 정의/검사하는 기능 제공 백업 및 회복 데이터베이스 장애 발생 시 데이터의 보존 기능 제공 DBMS 현행 시스템 분석
- 데이터베이스의
가용성, 성능, 기술 지원, 호환성, 구축 비용을 분석
관점 고려 사항 설명 성능 측면 가용성 - 장기간 시스템을 운영할 때 장애 발생 가능성
- 백업 및 복구 편의성
- DBMS 이중화 및 복제 지원 여부성능 - 대규모 데이터 처리 기능
- 대량 거래 처리 성능
- 다양한 튜닝 옵션 지원 여부
- 비용 기반 최적화 지원 및 설정의 최소화 지원 여부상호
호환성- 설치 가능한 운영체제 종류
- 다양한 운영체제에서 지원되는 JDBC, ODBC지원 측면 기술 지원 - 공급 업체들의 안정적인 기술 지원 여부
- 다수의 사용자 간의 정보 공유 여부
- 오픈 소스 여부구축 비용 - 라이선스 정책 및 비용
- 유지 및 관리 비용
JDBC ( Java DataBase Connectivity )
자바에서 데이터베이스를 사용할 수 있도록 연결해주는 응용 프로그램 인터페이스ODBC ( Open Database Connectivity )
데이터베이스를 액세스하기 위한 표준 개방형 응용 프로그램 인터페이스
미들웨어 현행 시스템 분석
1. 미들웨어(Middleware) 개념
- 서로 다른 애플리케이션이 서로 통신하는 데 사용되는 소프트웨어 ( AWS Docs ) https://aws.amazon.com/ko/what-is/middleware
- 분산 컴퓨팅 환경에서 응용 프로그램과 프로그램이 운영되는 환경 간에 원만한 통신이 이루어질 수 있도록 제어해주는 소프트웨어
- 운영체제와 소프트웨어 애플리케이션 사이에 위치하고 있따.
- 대표적인 미들웨어로는 WAS가 있다.
2. 웹 애플리케이션 서버
(WAS; Web Application Server)의 개념
- 웹 애플리케이션 서버는 서버게층에서 애플리케이션이 동작할 수 있는 환경을 제공하고, 트랜잭션 처리와 관리, 다른 이기종 시스템과의 애플리케이션 연동을 지원하는 서버
3. 미들웨어의 현행 시스템 분석
- 미들웨어의
가용성, 성능, 기술 지원, 구축 비용을 분석
관점 고려 사항 설명 성능 측면 가용성 - 장기간 시스템을 운영할 때 장애 발생 가능성
- 안정적인 트랜잭션 처리 능력
- WAS의 버그 등을 개선하는 패치 설치를 위한 재기동 기능 지원 여부
- WAS 이중화 지원 여부성능 - 대규모 데이터 처리 성능
- 다양한 설정 옵션 지원 여부
- 가비지 컬렉션의 다양한 옵션 기능 여부지원 측면 기술 지원 - 공급 벤더들의 안정적인 기술 지원 여부
- 다수의 사용자들 간의 정보 공유 여부
- 오픈 소스 여부구축 비용 - 라이선스 정책 및 비용
- 유지 및 관리 비용
- 총 소유 비용
가비지 컬렉션(GC; Garbage Collection)
메모리 관리 기법의 하나로, 프로그램이 동적으로 할당했던 메모리 영역 중에서 필요 없게 된 영역을 해제하는 기능
오픈소스(Open Source)
소스 코드를 공개해 소프트웨어 혹은 하드웨어 제작자의 권리를 지키면서 원시 소스 코드를 누구나 열람/사용할 수 있도록 한 오픈 소스 라이선스를 만족하는 소프트웨어
총 소유 비용(TCO; Total Cost of Ownership )
기업이 시간 경과에 따라 지불해야 하는 컴퓨팅 비용을 통합적인 관점에서 직접 이용뿐 아니라 이와 관련된 숨겨진 비용까지 포함하여 파악하는 기법
오픈 소스 사용 시 고려 사항
- 오픈 소스를 사용하는 경우에는
라이선스의 종류, 사용자 수, 기술의 지속 가능성 등을 고려해야한다.- 오픈 소스 소프트웨어의 전제 조건인
자유 배포, 소스 코드 공개, 파생작업 허용, 소스 코드 일관성 확보, 차별금지, 라이선스 배포, 포괄적 허용을 고려해야 한다.
🔍 개발 기술 환경 요구사항 파악
1. 기술 환경 정의를 위한 자료 수집
- 수집 자료 목록 및 조사 항목을 설정
기술 환경 정의를 위한 기초 자료 조사 항목 사례
구분 조사항목 설명 온라인 트랜잭션 처리(OLTP) 시스템 시스템 구축 형태 단독 시스템, 고가용성 시스템, 병렬 구성 여부 사용자 수 전체 사용자 수, 동시 사용자 비율, 연간 사용자 증가율 트랜잭션 수 연간 트랜잭션 수, 1일 평균 트랜잭션 수,
피크타임 트랜잭션 수, 예상 연간 트랜잭션 증가율
구분 조사항목 설명 웹/웹 애플리케이션 서버(WEB/WAS) 시스템 용도 및 서비스 형태 웹 페이지만 제공, 트랜잭션이 빈번하지 않은 웹 서비스, 트랜잭션이 빈번한 웹 서비스인지 여부 시스템
구성 형태1계층, 2계층, 3계층 접속자 수 평균/최고/연간 접속자 수, 증가율