Docker Compose 部署 nginx 代理 Tomcat 集群
- 备注:nginx 目录下的 nginx-1.12.2.tar.gz 文件 和 tomcat 目录下的 apache-tomcat-8.5.40.tar.gz 和 jdk-8u211-linux-x64.tar.gz 文件 需要自己下载
1、简介
- 使用Docker镜像部署Nginx代理的多个Tomcat集群:
- 使用 Dockerfile 构建 nginx 镜像
- 使用 Dockerfile 构建 tomcat 镜像
- mysql 镜像使用 docker hub 镜像
1、结构
├── docker-compose.yaml
├── etc
│ └── localtime
├── mysql
│ ├── conf
│ │ └── my.cnf
│ └── mysqldb
├── nginx
│ ├── conf.d
│ │ └── test.conf
│ ├── Dockerfile
│ ├── logs
│ │ ├── error.log
│ │ ├── test_access.log
│ │ └── test_error.log
│ ├── nginx-1.12.2.tar.gz
│ └── nginx.conf
├── tomcat
│ ├── apache-tomcat-8.5.42.tar.gz
│ ├── Dockerfile
│ ├── jdk-8u201-linux-x64.tar.gz
│ └── server.xml
└── webapps
└── ROOT
└── index.jsp
[root@docker01 ~]# mkdir -p nginx-tomcat/{etc,mysql,nginx,tomcat,webapps}
-
webapps 用于放置tomcat项目使用
-
mysqldb 数据将会存放在 mysql/mysqldb中
2、部署和构建
localtime
[root@compose ~]# cd /root/nginx-tomcat/e
[root@compose etc]# cp /etc/localtime .
my.cnf
[root@compose nginx-tomcat]# cd mysql/
[root@compose mysql]# ls
conf mysqldb
[root@compose mysql]# cd conf/
[root@compose conf]# cat my.cnf
[client]
port = 3306
socket = /var/lib/mysql/mysql.sock
default-character-set = utf8
[mysql]
port = 3306
socket = /var/lib/mysql/mysql.sock
default-character-set = utf8
[mysqld]
port = 3306
basedir = /var/lib/mysql
datadir = /var/lib/mysql
socket = /var/lib/mysql/mysql.sock
character-set-server = utf8
skip-external-locking
slow-query-log = on
long_query_time = 1
slow_query_log_file = /var/lib/mysql/slow.log
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES,NO_ZERO_DATE,NO_ZERO_IN_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER
log-error=/var/lib/mysql/mysql.log
pid-file=/var/lib/mysql/mysql.pid
Nginx Dockerfile
FROM centos:7
MAINTAINER bigberg
RUN yum -y install pcre-devel openssl-devel net-tools gcc gcc-c++ zlib zlib-devel \
make openssl
ADD nginx-1.12.2.tar.gz /tmp/
RUN cd /tmp/nginx-1.12.2 \
&& ./configure --prefix=/usr/local/nginx \
--with-http_ssl_module \
--with-http_gzip_static_module \
--with-http_realip_module \
&& make && make install
RUN mkdir -p /usr/local/nginx/logs \
&& groupadd -g 1001 nginx \
&& useradd -g 1001 -u 1001 -s /sbin/nologin -M nginx
CMD ["/usr/local/nginx/sbin/nginx", "-g", "daemon off;"]
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 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