docker-compose入门示例:一键部署 Nginx+Tomcat+Mysql
整体环境配置
整体环境的配置,如果一个一个 Dockerfile 去写,那么是相当麻烦的,好在 Docker 有一个名为 Docker-Compose 的工具提供,我们可以使用它一次性完成整体环境的配置:
首先我们看看 docker-compose.yml 配置文件的内容:
version: "3"
services:
mysql:
container_name: mysql
image: 192.168.1.30:5000/mysql:5.7 #从私有仓库拉镜像
restart: always
volumes:
- ./mysql/data/:/var/lib/mysql/ #映射mysql的数据目录到宿主机,保存数据
- ./mysql/conf/mysqld.cnf:/etc/mysql/mysql.conf.d/mysqld.cnf #把mysql的配置文件映射到容器的相应目录
ports:
- "6033:3306"
environment:
- MYSQL_ROOT_PASSWORD=123456
nginx:
container_name: nginx
restart: always
image: 192.168.1.30:5000/nginx
ports:
- 80:80
- 443:443
- 5050:5050
- 4040:4040
volumes:
- ./nginx/conf/nginx.conf:/etc/nginx/nginx.conf #映射nginx的配置文件到容器里
- ./nginx/logs/:/var/log/nginx/
- ./nginx/data/:/var/share/nginx/html/ #映射nginx的网页目录到容器里
links:
- tomcat:t1 #连接 tomcat镜像
tomcat:
container_name: tomcat
restart: always
image: 192.168.1.30:5000/tomcat
ports:
- 8080:8080
- 8009:8009
volumes:
- ./tomcat/conf/server.xml:/usr/local/tomcat/conf/server.xml #映射 tomcat的配置文件到容器里
- ./tomcat/webapps/web:/usr/local/tomcat/webapps/web #映射一个web服务
- ./tomcat/logs/:/usr/local/tomcat/logs/
links:
- mysql:m1 #连接数据库镜像
一共设置了三个 service,分别是 mysql, nginx, tomcat,其中,需要注意的地方是它们的 volumes 以及 links。
mysql 环境配置
首先看看最简单的 mysql,它没有设置 links,因为是其他容器来连接它,不需要设置links。但是 mysql 的 volumes 最为重要,如果不设置 volumes 的话,每一次 docker 重启,或者 mysql 的 container 重启,database 数据就会啥都没有了。所以 mysql 的 volumes设置了mysql 产生的 data 文件需要映射到宿主机的./mysql/data 目录下,这个目录可以自己定,mysql 的配置文件从宿主机的./mysql/conf/mysqld.conf 读取,内容可自己配置好。
nginx 环境配置
它也设置了 volumes和links,这个地方的 links,建立了与 tomcat 容器的连接,因为nginx 负责监听 80 端口,tomcat 负责监听 8080 端口,nginx 接收到动态网页需要由 tomcat 来处理,就要转发到 8080端口。docker 的环境下,nginx 直接将请求转发到 8080,tomcat 是不会转发的。所以用llinks,这里的值为 t1,为名字。
在 nginx.conf文件中,要加上如下配置:
在http端中加
upstream backend { #后台负载均衡容器及端口,本例为一个,t1 tomcat容器的名字
server t1:8080;
}
在server加
location / {
proxy_pass http://backend$request_uri;
proxy_set_header Host $host:$server_port;
proxy_set_header X-Real-IP $remote_addr;
client_max_body_size 10m;
}
tomcat 环境配置
volumes:
- ./tomcat/conf/server.xml:/usr/local/tomcat/conf/server.xml #映射 tomcat的配置文件到容器里
- ./tomcat/webapps/web:/usr/local/tomcat/webapps/web #映射一个web服务
该server.xml文件提前在宿主机配置好,包括web网页;同时把web映射到容器的相应目录。
最后执行如下命令:
docker-compose up 或者 docker-compose -f *.yaml文件名
创建容器。如果没有出现错误,创建成功。
一般的错误,都是因为挂载目录有错误,有的是写错了,有的是映射到容器中的相应目录不正确,关于容器的目录我总结如下:
mysql::/etc/mysql/mysql.conf.d/mysqld.cnf 为配置文件位置
nginx: :/etc/nginx/nginx.conf 为配置文件位置,/var/share/nginx/html/ 为nginx的网页目录
tomcat: :/usr/local/tomcat/conf/server.xml 为tomcat的配置文件位置,/usr/local/tomcat/webapps 为网页站点目录
通过以上我们不只可以一键创建一个mysql,nginx, tomcat 的动静分离网站环境,同时我们对 docker-compose 有了一定的了解,使我们轻松完成docker-compose 的入门学习。
docker-compose入门示例:一键部署 Nginx+Tomcat+Mysql的更多相关文章
- shell一键部署nginx+tomcat
1.首先拉取环境 tomcat需要用到jdk环境 提前准备好nginx源码包,放于指定目录下 vim test.sh #!/bin/bash yum -y install gcc gcc-c++ z ...
- Docker Compose 一键部署Nginx代理Tomcat集群
Docker Compose 一键部署Nginx代理Tomcat集群 目录结构 [root@localhost ~]# tree compose_nginx_tomcat/ compose_nginx ...
- 使用docker部署nginx+tomcat架构(3):使用docker-compose简化部署操作
经历了之前的两篇,我们已经大体上了解了docker部署容器的过程. 使用docker部署nginx+tomcat架构 使用docker部署nginx+tomcat架构():访问mysql数据库 不过, ...
- 使用docker部署nginx+tomcat架构(2):访问mysql数据库
上一篇完成了通过docker部署nginx+tomcat的基础软件架构,但是距离一个真正可用的软件架构还差得很远.其中最重要的一点是缺少数据库这个角色的存在,那么本篇就来完善这一点. 废话少说,直接进 ...
- Tomcat热部署:Maven项目一键部署到Tomcat服务器 - 支持多环境
参考:Eclipse中的Maven项目一键部署到Tomcat服务器 - 支持多环境部署 命令 debug模式设置关联源码 eclipse --> 项目右键 --> Debug As --& ...
- Git+Gitlab+Ansible的roles实现一键部署Nginx静态网站(一)--技术流ken
前言 截止目前已经写了<Ansible基础认识及安装使用详解(一)--技术流ken>,<Ansible常用模块介绍及使用(二)--技术流ken><Ansible剧本介绍及 ...
- docker 部署 nginx+php+mysql
系统:centos7 使用root账户 开放80端口 firewall-cmd --zone=public --add-port=80/tcp --permanent 安装docker yum ins ...
- shell脚本一键部署nginx
一键部署nginx 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 ...
- Git+Gitlab+Ansible的roles实现一键部署Nginx静态网站(4)
前言 截止目前已经写了<Ansible基础认识及安装使用详解(一)–技术流ken>,<Ansible常用模块介绍及使用(二)–技术流ken><Ansible剧本介绍及使用 ...
随机推荐
- VS断点不生效
工程属性页中“配置属性”->“C/C++”->“常规”->“调试信息格式”,选择“用于“编辑并继承”的程序数据库(/ZI)”. 在“配置属性”->“链接器”->“调试”- ...
- oracle客户端plsql安装
1.确认版本 自己的操作系统版本(32位还是64位),oracle instant client(oracle客户端版本)和plsql版本 我自己的版本是:oracle客户端版本 64位,plsql ...
- Mysql学习---SQL语言的四大分类
SQL语言共分为四大类:数据查询语言DQL,数据操纵语言DML,数据定义语言DDL,数据控制语言DCL. 1. 数据查询语言DQL 数据查询语言DQL基本结构是由SELECT子句,FROM子句,WHE ...
- Vim快捷输出查找寄存器的内容(去除\<,\>和\V)
Vim自带的*搜索会自动在单词两头加上\<和\>,使用第三方的vnoremap *,则是加上前缀\V, 当我们想要输出刚刚搜索的内容时可用<C-r>/,但是很可能会带上多余的符 ...
- Spark Executor内幕彻底解密:Executor工作原理图、ExecutorBackend注册源码解密、Executor实例化内幕、Executor具体工作内幕
本课主题 Spark Executor 工作原理图 ExecutorBackend 注册源码鉴赏和 Executor 实例化内幕 Executor 具体是如何工作的 Spark Executor 工作 ...
- selenium+python 数据驱动-csv篇,可封装
#循环读取csv文件中的数据,可以作为用户名,密码等使用from selenium import webdriverimport csv#获取csv文件中password列with open(r'C: ...
- c++由string组成的struct初始化崩溃
struct _UserInfo { string username; string password; string ip; string port; } _UserInfo str={}; 这样就 ...
- [由于远程方关闭传输流,身份验证失败]一次处理支付接口bug记录
因公司系统升级,出现突然有些银行卡不能支付的情况,最开始排查发现是第三方平台接口返回有问题: 返回如下: 从11月7日下午开始一直联系第三方,第三方开始排查,一直说是数据格式有问题. 修改格式以后问题 ...
- 22、整合mybatis
搭建环境: 1).创建工程需要的maven坐标 这个mybatis的starter是mybatis官方出的适应springboot 2).数据连接池的使用 引入Druid数据连接池 <depen ...
- 面试准备——(二)专业知识(4)C/C++语言
1. 预处理 断言 assert的功能,assert(statement),如果statement为真则程序继续执行,为假则整个程序中断退出 3. #define [ #ifndef DISKSIM_ ...