Docker部署web环境之总结篇
3. 问题总结
问题总结1: 数据库容器时区问题以及环境变量的安全控制
- docker-compose.yml文件中的环境变量,可以配置的变量方法有两种:
方法一:docker-compose.yml文件中用environment的形式配置
environment:
TZ: Asia/Shanghai
第一种适用于数据服务(也适用于其他) environment:
- TZ=Asia/Shanghai
第二种适用于普通的服务.
yml文件中数据库服务中仅能识别第一种形式"<key>: <value>",基于配置的统一用法方便记忆,所有的环境变量的配置又都识别第一种形式,所以选择第一种
方法二:docker-compose.yml文件利用变量文件的形式引入多个变量(比较安全,推荐)
# cat docker-compose.yml
......
volumes:
- ./mysql/mysql5.7/conf:/etc/mysql/conf.d
- ./mysql/mysql5.7/data:/var/lib/mysql
command: --character-set-server=utf8
env_file:
- ./mysql/mysql5.7/conf/env
...... # cat ./mysql/mysql5.7/conf/env
TZ=Asia/Shanghai
MYSQL_ROOT_PASSWORD=admin
MYSQL_USER=user
MYSQL_PASSWORD=user123 这里可以env文件中的配置root密码相对安全,缩小密码文件的权限即可
优缺点:
方法一:会把密码信息暴露出来,若非要使用的话,建议只配置初始化密码,容器起来后立即修改root密码
方法二:会把比较敏感信息隐藏起来,放在文件中,比较安全(强烈推荐)
问题总结2: 反向代理中关于后端服务器访问日志记录客户端IP的问题
附: 客户端宿主机: 192.168.1.209
docker宿主机: 192.168.1.210
自定义容器网桥网关: 192.168.30.1
apache容器前端代理容器: 192.168.30.11
nginx容器前端代理容器: 192.168.30.12
tomcat后端服务器容器: 192.168.30.13
lamt反向代理中: 1.209(客户端) ---> 1.210:82(前端代理apache容器映射端口),那么tomcat容器访问日志会随着apache调用方式不同而不同,
通过http协议调用tomcat,访问日志则记录客户端IP;通过ajp协议调用tomcat,访问日志则记录前端代理IP。
lnmp反向代理中: 1.209(客户端) ---> 1.210:83(前端代理nginx容器映射端口),那么tomcat容器访问日志默认会记录前端代理IP,
若想要实现tomcat记录客户端真实IP,需要修改nginx+tomcat的配置文件,如下:
nginx配置需要添加:
location / {
proxy_pass http://lb_tomcat;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
tomcat配置需要添加:
修改server.xml 找到pattern行
原内容: pattern="%h %l %u %t "%r" %s %b"
修改后
新内容: pattern="%{X-FORWARDED-FOR}i %l %u %t %r %s %b %D %q %{User-Agent}i" resolveHosts="false"
重启容器即可,此配置也适用于宿主机内的反向代理配置
问题总结3: 创建网络的网桥命名太长
网桥的命名规则为: <docker-compose.yml 文件所在目录的目录名>_<网络服务的网络名>
如果想改成自定义的网络名,参考如下
自定义的网络名称中"_"下划线是去不掉的,要合理利用它,在docker-compose.yml文件所在目录下,编辑 .env 文件
添加内容:
# cat .env
COMPOSE_PROJECT_NAME="compose"
问题总结4: 编排lnmp环境时,root目录挂载问题
nginx服务名下面的root挂载目录要和 php服务名下的root挂载目录一致,否则,php找不到*.php文件,处理不了php文件的请求。
问题总结5: 控制宿主机内不同网段容器通信
默认创建的不同网段的桥接网络,容器之间是可以互相通信的,为了避免不必要的麻烦,避免出现容器被作为肉鸡情况,需要禁掉,添加配置如下:
# cat /etc/docker/daemon.json
{"icc": false}
问题总结6: docker容器防火墙规则的维护
- 防火墙DOCKER链
DNAT规则 查询/新增/加载
iptables -t nat -nL DOCKER --line (注意查询参数顺序)
iptables -t nat -A DOCKER -p tcp --dport 90 -j DNAT --to-destination 192.168.30.11:81 (参考)
firewall-cmd --reload
注:
DNAT规则不需要管理,会随着容器的启动,而动态变化;
DNAT规则控制着外网访问容器,在容器启动后,一旦手动介入删除掉规则,外网则访问不到该容器的内容,需要加载下防火墙规则或添加规则均可.
- 防火墙POSTROUTING链
SNAT规则 查询/删除/新增/加载
iptables -t nat -nL POSTROUTING --line (注意查询参数顺序)
iptables -t nat -D POSTROUTING 3
iptables -t nat -A POSTROUTING -s 192.168.20.0/24 -j MASQUERADE (参考)
firewall-cmd --reloadeg:MASQUERADE all -- 192.168.20.0/24 0.0.0.0/0
POSTROUTING链规则,无需手动添加,一开始创建网络时,docker会自动创建此规则.
若后期手动误操作删除了此规则,可以进行加载防火墙出现
若用网桥命令将网桥删掉后,对应的规则会保留,需要重启docke服务和加载防火墙规则,方能彻底删除弃用的规则。
SNAT规则控制着容器访问外网
Docker部署web环境之总结篇的更多相关文章
- Docker部署web环境之Lanmt
2. 案例二 整套项目多容器分离通过docker-compose部署lanmt环境 详细的安装准备环境,省略,配置以及部署参考案例一即可 即可实现批量创建web,也可以实现多web共用一个php或my ...
- Docker部署web环境之Lanmp
1. 案例一 整套项目多容器分离通过docker-compose部署lanmp环境 中方文档参考网址: docker/kubernets网址 http://www.dockerinfo.net/doc ...
- Docker部署SDN环境
2014-12-03 by muzi Docker image = Java class Docker container = Java object 前言 5月份的时候,当我还是一个大学生的时候,有 ...
- Docker部署web项目-jar包
一.Docker部署web项目-jar包 ①搜索mysql镜像 docker search mysql ②拉取镜像至本地仓库(本文选取的mysql镜像5.7版本) docker pull mysql/ ...
- docker部署-windows环境
docker部署-windows环境 1. docker windows 1.1. 安装 win7或者win8需要利用docker toolbox来安装,其是一个docker工具集,w ...
- Linux Ubuntu从零开始部署web环境及项目 -----部署项目 (三)
上一篇讲了如何在linux搭建web环境,这边将如何部署项目. 1,打包项目包 2,上传项目包 将.war项目包通过xftp上传到tomcat目录wabapps目录下 3,启动项目 通过xshell命 ...
- Linux Ubuntu从零开始部署web环境及项目 -----tomcat+jdk+mysql (二)
上一篇介绍如何在linux系统下搭建ssh环境 这篇开始将如何搭建web服务器 1,下载文件 在官网下载好 tomcat.jdk.mysql的linux压缩包 后缀名为.tar.gz 并通过xftp上 ...
- 手把手docker部署java应用(初级篇)
本篇原创发布于 Flex 的个人博客:点击跳转 前言 在没有 docker 前,项目转测试是比较麻烦的一件事.首先会化较长的时间搭建测试环境,然后在测试过程中又经常出现测试说是 bug,开发说无法 ...
- Linux Ubuntu从零开始部署web环境及项目 -----快捷键设置(四)
上篇将了如何在linux部署web项目,这篇介绍如何设置常用快捷键 一.路径快捷键设置 临时快捷键设置: 执行XShel,输入: alias 'aa=cd /etc/sysconfig' ...
随机推荐
- 【记录】linux 命令拷贝文件到远程服务器,linux下载文件到本地
Linux scp命令用于Linux之间复制文件和目录 -1 强制scp命令使用协议ssh1 -2 强制scp命令使用协议ssh2 -4 强制scp命令只使用IPv4寻址 -6 强制scp命令只使用I ...
- ftp服务的安装
ftp服务的安装 1.环境准备 2.安装服务 3.配置文件 3.1.匿名访问 把以下三个匿名上传写入开启 启动并查看服务状态: Linux客户端访问: Tips: 220表示服务正常,可以登陆:230 ...
- 【记录】Idea "Cannot resolve symbol 'SpringBootApplication'" 错误&“找不到主类”错误
初学,有一个Spring Boot的demo需要用Idea打开.我选择导入(Import Project选项)文件,出现如题错误,且yml文件格式也不正确显示(叶子). 后面细看目录,发现一个main ...
- C++在windows平台下不存在strptime函数,可以绕过该函数
https://blog.csdn.net/u011077672/article/details/50524469?utm_source=blogxgwz1
- 企业实践 | 如何更好地使用 Apache Flink 解决数据计算问题?
业务数据的指数级扩张,数据处理的速度可不能跟不上业务发展的步伐.基于 Flink 的数据平台构建.运用 Flink 解决业务场景中的具体问题等随着 Flink 被更广泛的应用于广告.金融风控.实时 B ...
- 《NULL-2019团队》第一次作业:OUC二手交易平台
前言 项目名称:OUC二手交易平台 项目简介:针对在校大学生的二手交易平台,相对于现在市面已有的二手APP,将其使用的普遍性范围缩小,针对在校大学生,这样可以有效的保证交易的真实性和公平性. NA ...
- 在Delphi中使用系统对应文件类型的图标
在应用程序的编写中,组合框(ComboBox).列表框(ListBox).等常见的部件,通常不仅要用于显示文字,而且还要显示其与文字相关的图标.在一般的Windows应用程序中,这些图标的显示都要随列 ...
- thinkphp 根据文件后缀的不同返回不同的结果
** * 根据文件后缀的不同返回不同的结果 * @param string $str 需要判断的文件名或者文件的id * @return integer 1:图片 2:视频 3:压缩文件 4:文档 5 ...
- 2018icpc南京/gym101981 I Magic Potion
题意: 若干个勇士,每个勇士只能杀特定的怪物.每个勇士只能杀1个怪,但是有一些药,喝了药之后能再杀一个,每个勇士只能喝一瓶药.问你最多杀多少怪. 题解: 按照如下建图套网络流板即可. 网上有题解说套D ...
- java.lang.String中的replace方法到底替换了一个还是全部替换了。
你没有看错我说的就是那个最常用的java.lang.String,String可以说在Java中使用量最广泛的类了. 但是我却发现我弄错了他的一个API(也可以说是两个API),这个API是关于字符串 ...