전성빈의 사리사욕

[배포하기] 3. Nginx란? 내가 만든 서버는 뭐지? 본문

백엔드 로드맵따라가기/배포하기

[배포하기] 3. Nginx란? 내가 만든 서버는 뭐지?

Been2 2020. 11. 13. 16:58
728x90

서버를 AWS EC2에 위치 시킨 후 DNS를 등록해서 배포 하려 찾아보는 도중

 

WEB Server는 nginx를 사용하는게 좋다는 글을 봤다.

 

분명 내가 Node.js 에서 express를 사용하며 만든 작지만 소중한 나의 서버가 있는데 nginx를 사용하란다.

 

도대체 내가 만든 서버는 뭐고 nginx는 뭐고 둘의 차이는 뭐고 역할은 무엇일까 궁금해서 찾아본다.

 


개념

 

nginx 란?

 

nginx란 웹 서버 제품중 하나이다.

 

 

Web Server란?

 

웹서버의 개념

  웹 클라이언트로부터 HTTP Request를 받아 Static file(html, css, js)을 제공하는 프로그램이다.

 

web server의 기능

  HTTP을 기반으로 하여 클라이언트의 요청을 서비스 하는 기능을 담당한다.

  요청에 따라 2가지 기능 중 적절하게 선택하여 수행한다.

  기능 1 )

    정적인 컨텐츠 제공

    WAS를 거치지 않고 바로 자원을 제공

  기능 2)

    동적인 컨텐츠 제공을 위한 요청 전달

    클라이언트 요청을 WAS에 보내고, WAS가 처리한 결과를 client에게 response한다.

 

Web Server의 예

  Apache Server, Nginx, IIS

 

WAS란?

 

WAS의 개념

  WAS(Web Application Server)란 DB 조회나 다양한 로직 처리를 요구하는 dynamic 컨텐츠를 제공하기 위해 만들어진 application Server이다.

  HTTP를 통해 컴퓨터나 장치에 애플리케이션을 수행해주는 미들웨어이다.

  웹 컨테이너 (Web container)  혹은 서블릿 컨테이너 (Servlet Container)라고도 불리운다.

    - 웹 컨테이너는 JSP, Servlet을 실행시킬 수 있는 소프트웨어를 말한다.

    - WAS는 JSP, Servlet 구동 환경을 제공한다.

 

WAS의 역할

  WAS = Web Server + Web Container

  웹서버의 기능들을 구조적으로 분리하여 처리하고자 하는 목적으로 생긴 개념이다.

    - 분산 트랜잭션, 보안, 메시징, 쓰레드 처리 등의 기능을 처리하는 분산 환경에서 사용된다.

    - 주로 DB 서버와 같이 수행된다.

  현재는 WAS가 가지고 있는 WebServer도 정적인 컨텐츠를 처리하는 데 있어서 성능상 큰 차이가 없다.

 

WAS의 기능

  프로그램 실행 환경과  DB접속 기능 제공

  여러개의 트랜잭션 관리 기능

  업무를 처리하는 비지니스 로직 수행

 

WAS의 예

  Apache Tomcat, JBoss, Jeus, Web Sphere

 


 

WAS나 Web Server에 대해서는 자세히 알아봐야겠다.

 

nginx는 결국 정적인 컨텐츠를 담당하고 동적인 요청을 web application에 넘기는 중간 역할같은 서버라 생각해야겠다.

 

하지만 nginx를 node.js로 구현한 서버들과 같이 사용한다는 글 들을 보면 Reverse Proxy로도 사용 한다고 한다.

 

Proxy는 간단하게 방화벽으로 접근을 중간에서 대신 해줘 보안이나 요청 부담을 나누는 역할이다. 즉, nginx를 통해

 

앱서버의 보안을 어느정도 같이 한다는 의미인것 같다.

 

 

그리고 내가 express로 만든 서버는 정적인 컨텐츠를 static으로 제공하기도 하고 비지니스 로직을 가지고 있고

 

직접 DB에 트랜잭션도 날리며 동적인 컨텐츠를 제공하기도 하기 때문에 아마 WAS인거 같다. 

 

 

nginx와 내가 express로 만든 서버에 대해 아주 조금이나마 궁금증이 해결 되었으니 나중에 더 찾아보자.

 


nginx 실행하기 

 

 

$ sudo apt-get install nginx

일단 nginx를 사용하기 위해 설치해주자.

 

$ service nginx start

nginx를 실행 시켰는데 password를 입력하란다. AWS instance에 OS를 바로 설치하고 이용해서 딱히 설정을 안해줬는데 일단 root 계정을 사용하면 될거 같았다.

 

$ su passwd

root 계정의 비밀번호를 설정해줬다. root로 로그인 후 위 명령어를 재입력 해서 nginx를 실했시켰다.

 

$ netstat -atnp

nginx가 실행이 됐는지 확인하기 위해 현재 열려있는 포켓을 확인하려 한다. 뒤 옵션들을 통해

소켓, tcp, 프로세스의 이름, 포트번호를 검색해서 80번 포트에 nginx master가 있는것을 확인했다.

 

$ sudo apt-get install net-tools

net-stat를 사용하기 위해선 net-tools 패키지가 필요 하다는데 나는 없다고 뜬다. 설치해주자.

설치를 하고나서 다시 netstat를 확인해서 80번 포트에 nginx가 실행되는 있는것을 확인했다.

 

 

AWS console로 가서 내 인스턴스의 정보중 DNS가 있다. 시큐리티 그룹에서 80번 포트를 어디서든 접속할 수 있게 해줬기 때문에 DNS를 인터넷에 검색하면 nignx의 default main page가 나온다.

 

 

접속하기 더욱 편하게 하기 위해 다음에는 DNS를 설정해서 간단한 주소로 만들어보자.


추가로 공부할 것 :

 

리눅스 :apt-get

          netstat options

          net-tools

웹 서버: event-driven  vs  thread 

            load Balancing

Proxy : what is a proxy

         front-proxy and reverse proxy

nginx : how does nginx work?

          환경설정

          

 

출처 : gmlwjd9405.github.io/2018/10/27/webserver-vs-was.html

728x90