1. 개발 환경 구축 (C)
- 개발 환경 구축 개요: 응용 소프트웨어의 개발을 위해 소프트웨어 및 하드웨어 장비를 구축하는 것
- 하드 웨어 환경 : 클라이언트 + 서버
- 클라이언트 : PC, 스마트폰
- 서버
- 웹 서버(Web Server) : 클라이언트에게 직접 요청을 받아 처리하는 서버
- HTTP,HTTPS 지원
- 통신 기록
- 정적 파일 관리
- 대역폭 제한 : 응답속도 제한하는 기능
- 가상 호스팅 : 하나의 서버로 여러 개의 도메인 이름 연결
- 인증
- 웹 어플리케이션 서버(WAS) : 사용자에게 동적 서비스 제공을 위해 웹 서버의 요청을 받아 데이터 가공 또는 웹 서버와 DB서버 또는 파일 서버 사이에서 인터페이스 역할
- 데이터베이스 서버(DB Server)
- 파일 서버
- 웹 서버(Web Server) : 클라이언트에게 직접 요청을 받아 처리하는 서버
- 소프트웨어 환경 : 시스템 소프트웨어 + 개발 소프트웨어
- 시스템 소프트웨어 : OS, 서버프로그램, DBMS
- 개발 소프트웨어
- 요구사항 관리 도구
- 설계/모델링 도구 : UML
- 구현 도구 : Eclipse, Node.js
- 빌드 도구 : 소스의 빌드, 배포, 라이브러리 관리 지원 - Jenkins,Maven
- 테스트 도구 : JUit, SpringTest
- 형상 관리 도구 : 버전별로 관리 - GIT, SVN
2. 모듈 (A)
- 모듈 : 모듈화를 통해 분리된 시스템의 각 기능
- 모듈의 단독으로 컴파일이 가능하고 재사용이 가능하다
- 기능적으로 독립되있다
- 모듈의 독립성은 결합도는 약하게 응집도는 강하게 크기는 작게만들어야 한다
- 결합도 : 모듈 간에 상호 의존하는 정도 (자,스.제.외.공.내....(저)자슥 제외 하고 공내!)
- 자료 결합도 : 모듈 간의 인터페이스가 자료 요소로만 구성되어 있다.
- 스탬프 결합도 : 두 모듈이 동일한 자료 구조를 조회한다.
- 제어 결합도 : 한 모듈이 다른 모듈에게 제어 요소를 전달한다.
- 외부 결합도 : 어던 모듈의 데이터를 외부의 다른 모듈이 참조한다.
- 공통(공유) 결합도 : 공통 데이터 영역을 여러 모듈이 사용한다.
- 내용 결합도 : 한 모듈이 다른 모듈의 내부 기능을 직접 참조하고나 수정한다.
- 응집도 : 내부 요소들의 서로 관련있는 정도
- 기능적 응집도 : 모든 요소가 단일 문제와 연관되어 있다.
- 순차적 응집도 : 모듈 내 하나의 활동으로 부터 나온 출력 데이터를 그 다음 활동의 입력 데이터로 사용
- 교환적 응집도 : 동일한 입, 출력을 사용하여 서로 다른 기능을 하는 요소들이 모여있다.
- 절차적 응집도 : 모듈이 다수의 관련 기능을 가질 때 모듈 내 요소들이 그 기능을 순차적으로 수행
- 시간적 응집도 : 특정 시간에 처리되는 기능이 모여져 있다.
- 논리적 응집도 : 유사한 성격, 특정 형태로 분류
- 우연적 응집도 : 서로 관련 없는 요소로만 구성
- 팬인(Fan-In), 팬아웃(Fan-Out)
- 팬인 : 제어하는 모듈의 수
- 팬아웃 : 제어되는 모듈의 수
3. 공통 모듈 (C)
- 공통 모듈 : 여러 프로그램에서 공통적으로 사용할 수 있는 모듈
- 명세 기법 준수
- 정확성
- 명확성
- 완전성
- 일관성
- 추적성
- 재사용 : 비용과 개발시간 절약을 위해 이미 개발된 기능을 파악하고 재구성하여 새로운 시스템에 사용하기 적합하도록 최적화 하는 것
- 외부 모듈과의 결합도는 낮고 응집도는 높아야 한다
4. DBMS 접속 (B)
- 사용자가 데이터를 사용하기 위해 응용 시스템을 이용하여 DBMS에 접근하는 것
- 웹 응용 프로그램 : 웹 응용 시스템을 통해 DBMS에 접근한다
- 웹 응용 시스템 : 웹 응용 프로그램이 DBMS에 접근하기 위한 인터페이스 제공
- 웹 응용 프로그램 <-> 웹 응용 시스템 (웹 서버 + WAS) <-> DBMS
- DBMS 접속 기술
- JDBC (Java DataBase Connecity)
- ODBC : 개발 언어에 관계 없이 사용할 수 있다. Excel, Text 등 다양한 DB에 접근할 수 있다.
- MyBatis : JDBC 코드를 단순화 하여 사용할 수 있는 SQL Mapping 기반 오픈 소스 접속 프레임워크이다.
- 동적 SQL (Dynamic SQL)
- 다양한 조건에 따라 SQL구문을 동적으로 변경하여 처리
- 사용자로부터 SQL문의 일부 or 전부를 입력받아 실행
- NVL 함수 사용할 필요 없음
'IT > 정보처리기사실기 공부' 카테고리의 다른 글
[정보처리기사실기] 화면 설계 (0) | 2020.10.05 |
---|---|
[정보처리기사실기] 서버 개발, 서버 개발 과정, 배치 프로그램 (0) | 2020.10.04 |
[정보처리기사실기] 통합구현 (0) | 2020.10.02 |
[정보처리기사실기] 인덱스, 뷰, 클러스터, 파티션, 데이터베이스 용량 설계 (0) | 2020.09.30 |
[정보처리기사실기] 데이터 모델, 정규화, 데이터 모델 변환, 반정규화 (0) | 2020.09.29 |