IT/정보처리기사실기 공부

[정보처리기사실기] 개발 환경 구축, 모듈, 공통 모듈, DBMS 접속

phobi-k 2020. 10. 4. 18:29

1. 개발 환경 구축 (C)

  • 개발 환경 구축 개요: 응용 소프트웨어의 개발을 위해 소프트웨어 및 하드웨어 장비를 구축하는 것
  • 하드 웨어 환경 : 클라이언트 + 서버
    • 클라이언트 : PC, 스마트폰
    • 서버
      • 웹 서버(Web Server) : 클라이언트에게 직접 요청을 받아 처리하는 서버
        • HTTP,HTTPS 지원
        • 통신 기록
        • 정적 파일 관리
        • 대역폭 제한 : 응답속도 제한하는 기능
        • 가상 호스팅 : 하나의 서버로 여러 개의 도메인 이름 연결
        • 인증
      • 웹 어플리케이션 서버(WAS) : 사용자에게 동적 서비스 제공을 위해 웹 서버의 요청을 받아 데이터 가공 또는 웹 서버와 DB서버 또는 파일 서버 사이에서 인터페이스 역할
      • 데이터베이스 서버(DB 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 함수 사용할 필요 없음