기본 콘텐츠로 건너뛰기

웹 어플리케이션이 나오기까지

이번 시간엔 웹 어플리케이션이 나오게 되기까지 과정을 알아보자.

데스크톱 애플리케이션

1. PC에 설치되어 실행되 웹 애플리케이션 보다 실행속도가 빠름.
    - office, 컴퓨터 게임 등등...
2. 문제점
  - 배포의 번거로움.
  - 보안에 취약 : 데이터 베이스에 접근할 때 취약 가능성
  - 애플리케이션 실행할 때 먼저 서버에 갱신된 버전이 있는지 조회 후 실행하면 어느정도 해결됨.
  - 단 보안에 취약...
 

클라이언트'서버 애플리케이션

  - 애플리케이션의 기능을 서버와 클라이언트로 분리.
  - 장점
    - 새로 프로그램이 수정 되도 서버 쪽만 변경하면 됨.
    - 기능 변경/추가에 유연하게 대처가 됨.
  - 문제점 개선 방안
    - 한번에 하나의 클라이언트 하고만 연결 됨.
    - 멀티 프로세스와 멀티 스레드로 위 문제를 해결한다.
  - 멀티 프로세스와 멀티 스레드
    - 멀티 프로세스는 원본 프로세스의 메모리를 모두 복제해 자원 낭비가 심함.
    - 멀티 쓰레드는 전체 메모리를 복제할 필요가 없음.
   

다중 클라이언트 요청 처리

  - 클라이언트의 요청 처리 부분을 별도의 작업으로 분리
  - 분리된 작업은 스레드에 정의
  - 다중 클라리언트 요청이 병행 처리됨.
  - C/S 환경의 프로그래밍이 복잡해지는 문제가 생김.
 

클라이언트'서버 아키텍처의 진화

1. 전통적인 클라이언트'서버 아키텍처
    - 서버는 데이터 처리를 맡고 클라이언트는 UI와 비즈니스를 처리했다.
    - 단점
        - 프로그램이 변경되면 PC에 다시 설치해야됨...
        - 클라이언트가 DBMS로 바로 접속해 보안 문제 발생.
       
2. 개선된 클라이언트'서버 아키텍처
    - 클라이언트의 업무 처리부분은 서버로 이관.
    - 클라이언트는 오직 UI만 담당.
    - 서버로부터 결과를 받으면 클라이언트에서 화면을 꾸며 뿌려줌.
    - 애플리케이션 서버?
        - 업무를 전담하게된 서버를 애플리케이션 서버라 부른다.
        - 클라이언트로부터 요청을 받으면 업무 로직에 따라 DBMS 서버를 사용해 데이터를 처리.
        - 클라이언트 접근제어도 함꼐 처리.
    - 서버에 기능이 변경 되도 바로 클라이언트에 적용할 수 있다.

웹 애플리케이션 아키텍처

1. 특징
    - 클라이언트와 통신은 웹 서버가 전담
    - 애플리케이션 서버는 애플리케이션 서버 실행 및 관리에 집중.
    - 비즈니스 로직과 UI 로직을 모두 서버에 배치되 추가 변경되도 서버만 바꾸믄 된다.
    - 단 웹 환경에선 애플리케이션 실행할 때마다 UI로직을 내려받기 때문에 오버헤드 발생.
    - 멀티 스레드 부분을 웹 브라우저와 웹 서버가 알아서 해줌.
   
2. 서버쪽
    - HttpServlet 클래스르르 상속받고 있다.
    - doGet() / doPost()를 재정의 한다.
   
3. 화면관련 오버헤드는 어떻게 극복할까?
    - AJAX
        - 같은 화면에서 데이터만 바뀔 때 서버에 UI 전체를 받아오기 보다, 데이터만 받아온다.
         
웹 처음 시작할 때 보았던 부분인데, 웹을 처음 시작할 당시 아 이렇구나.. 라는 감만 있었다.
양파껍질 스터디를 하고, 또 여러 프로젝트를 진행한 결과 웹 애플리케이션의 흐름이 한눈에 들어오기 시작했다.
 결론은 프로젝트도 많이 하고 책도 많이 읽고, 시간 지나고나서 느낌 좋았던책 다시 읽어보자!

끝~!!

댓글

이 블로그의 인기 게시물

[자바 웹 프로그래밍]2장 문자열 계산기 구현을 통한 테스트와 리펙토링

이번엔 2장에 나와 있는 내용 정리와 느낀점을 정리 해 보겠다. 1. main() 메소드를 활용한 테스트의 문제점.   - 소스코드 구현 후 정상적으로 동작하는지 확인 위해 일반적인 방법은 main()메소드를 활용하는 것이다.   - 실제 서비스를 담당하는 프로덕션 코드와 이 프로덕션 코드가 정상 동작 하는지 확인을 위한 main() 으로 나뉜다.   - 이 방법의 첫번째 문제점은 프로덕션코드와 main() 메서드가 함께 있다는 것이다.   - 프로덕션 코드와 테스트코드(main)을 분리할 수 있다.   - 두 번째 문제는 내가 구현하고 있는 메서드만 집중 할 수 없고, 클래스가 가지고 있는 모든 메서드를 테스트 할 수 밖에 없다.   - 다른 문제는 항상 콘솔로 확인을 할 수 밖에 없다는 것이다.   - 이를 위해 등장한 라이브러리가 JUnit 이다. 내 관심을 가지는 메서드에 대해 테스트 가능하다. 2. JUnit을 활용해 main() 메서드 문제 극복 2.1 한 번에 메서드 하나에만 집중.   - JUnit관련 라이브러리 추가 후  테스트 메서드에 @Test를 붙이면 된다.   - test 관련 코드 작성 후 Run > Run as> JunitTest를 실행해 보자.   - 각각 테스트 메서드를 독립적으로 실행할 수 있기 때문에 현재 내가 구현하고 있는 프로덕션 코드의 메서드에 집중할 수 있다. import org.junit.Test; public class CalculatorTest { @Test public void add() { Calculator cal = new Calculator(); System.out.println(cal.add(1,2)); } } 2.2 결과 값을 눈이 아닌 프로그램을 통해 자동화 import org.junit.Test; import static org.junit.Assert.assertEquals;

[고량주] 라오왕 연태고량주 플러스

나에게 처음 고량주란 이런것이다 라는걸 알려준 녀석이다. 부모님이 중국집을 하다 보니 가끔 초록색병 고량주를 먹었을때  역한 공업용 알콜 맛에 고량주는 나랑 안맞는다 생각했다가 우연히 양고기에 이녀석을 접한 뒤로 고량주의 맛을 알아버렸다... 제품명 : 라오왕 연태고량주플러스 제품유형 : 일반증류주 도수 : 34.2% 가격 : 9000원(홈플러스 익스프레스 기준) 재구매 의사 : 있다 시음평 : 역시 고량주 특유의 향인데, 열대과일 향도나고, 배향, 살짝 달달한 향이 난다.            목넘김은 34.2%에도 불구하고 그리 힘들지 않았다(주당이 된걸수도..)             중국요리나 양꼬치집에서 맛있는 술이 땡긴다면 강력추천한다.