Server

[Docker] Nginx-tomcat 로드밸런서(Load Balancer) 구현하기 / feat.docker-compose

JinCode 2021. 11. 17. 15:11

[Docker] Nginx-tomcat 로드밸런서(Load Balancer) 구현하기

 

 

# Tree

├── docker-compose.yml
├── mariadb
│   ├── config
│   └── data
├── nginx
│   └── config
│       └── nginx.conf
├── tomcat1
│   └── webapps
│       └── index.html
└── tomcat2
    └── webapps
        └── index.html

 

 

# docker-compose.yml

version: "3.3"

services:
  nginx:
    image: nginx
    container_name: nginx
    restart: always
    ports:
      - 80:80
    volumes:
      - ./nginx/config/nginx.conf:/etc/nginx/nginx.conf

  tomcat1:
    image: tomcat
    container_name: tomcat1
    ports:
      - 10001:8080
    volumes:
     - ./tomcat1/webapps/:/usr/local/tomcat/webapps/ROOT

  tomcat2:
    image: tomcat
    container_name: tomcat2
    ports:
      - 10002:8080
    volumes:
     - ./tomcat2/webapps/:/usr/local/tomcat/webapps/ROOT

1. nginx

 - ports : nginx의 port입니다. 외부 80번 포트, container 80번 포트로 매칭하였습니다

 - volumes : container 외부에서 관리하기 위해, 로드밸런싱 설정을 위해  nginx/config 폴더를 생성 후 nginx.conf 파일을 만들었습니다. nginx.conf 파일은 아래에서 설명드리겠습니다.

 

2. tomcat

 톰캣 설정부분 입니다. 2개의 톰캣을 container로 만들며, 외부 port를 다르게 설정하며, container 포트는 동일하게 설정합니다.

 

 

# nginx/config/nginx.conf

user  nginx;
worker_processes  1;

error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log  /var/log/nginx/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    keepalive_timeout  65;

    #gzip  on;

    # include /etc/nginx/conf.d/*.conf;
    
    upstream tomcat {
        server 서버ip:10001;
        server 서버ip:10002;
        # 예시) server 123.45.678.999:10001;
        # 예시) server 123.45.678.999:10002;
    }

    server {
        listen 80;
        location / {
            proxy_pass http://tomcat;
        }
    }
}

1. upstream {tomcat} : upstream을 설정해야 합니다.

서버ip:port로 지정할 수 있습니다.

 

nginx upstream이란?

 > proxy_pass를 통해 nginx가 받은 Request를 넘겨 줄 서버를 정의

 

 

## 옵션

# 참조 : http://nginx.org/en/docs/stream/ngx_stream_upstream_module.html
########## ip_hash
upstream tomcat {
    ip_hash;
    server 서버ip:10001;
    server 서버ip:10002;
}
ip_hash - ip로 분배한다. 만약 A라는 ip가 server1에 접속했으면 이후에도 
server1에 계속 접속하게 되며, 한번 접속한 ip는 계속 같은 서버를 사용한다.


########## least_conn
upstream tomcat {
    least_conn;
    server 서버ip:10001;
    server 서버ip:10002;
}
least_conn - 가중치를 고려하면서 연결된 접속자가 가장 적은 서버로 분배


########## least_time
upstream tomcat {
    least_time;
    server 서버ip:10001;
    server 서버ip:10002;
}

least_time - 연결된 접속자가 가장 적으면서 + 평균 응답시간이 가장 적은 쪽으로 분배

 

 

# 심플한 HTML 작성

## tomcat1/webapps/index.html

## tomcat2/webapps/index.html

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
    tomcat1 (tomcat2에서는 tomcat2)
</body>
</html>

 

 

# docker-compose up -d

 

 

# 웹실행

새로고침을 하면 tomcat1과 tomcat2가 번갈아 가면서 접속이 되는것을 확인할 수 있다.

 

 

 

 

 

# 참고

https://velog.io/@ruddms936/%EB%A1%9C%EB%93%9C%EB%B0%B8%EB%9F%B0%EC%8B%B1