前言
本文简单介绍基于容器部署dnsmasq、nginx、httpd的步骤,不对概念做详细说明。
一、dnsmasq
- 下载镜像
docker pull jpillora/dnsmasq
- 在本机创建配置文件
mkdir -p /data/dns
vi /data/dns/dnsmasq.conf
## 添加如下内容:
#dns解析日志
log-queries
#域名与IP映射
address=/<域名>/<IP>
- 运行容器
## HTTP_USER web ui 用户名
## HTTP_PASS web ui 密码
docker run -d\
--name dnsmasq \
--restart always \
-p 53:53/udp \
-p 8080:8080 \
-v /data/dns/dnsmasq.conf:/etc/dnsmasq.conf \
-e "HTTP_USER=user" \
-e "HTTP_PASS=12345" \
jpillora/dnsmasq
- web登录
访问:http://:8080/,其中ip为运行容器的机器IP。示例:
- 测试
## 安装dns解析工具
yum -y install bind-utils
## 使用nslook命令进行测试
nslookup pikachu.com 10.10.15.34
Server: 10.10.15.34
Address: 10.10.15.34#53
Name: pikachu.com
Address: 10.10.15.34
二、nginx
- 拉取镜像
docker pull nginx:latest
- 本地创建配置文件 my-proxy.conf
server {
listen 80;
server_name <监听的服务名称>; # 例如:pikachu.com
location / {
proxy_pass <实际访问的服务>; # 例如:http://10.10.15.34:8000/cgi-bin/test.cgi
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
# 可能需要其他代理配置,例如:proxy_set_header、proxy_redirect 等
}
}
- 启动容器
docker run -d --name nginx -p 80:80 \
-v /root/my-proxy.conf:/etc/nginx/conf.d/my-proxy.conf:ro \
nginx:latest
这样nginx就在监听80端口的访问,一旦访问<监听的服务名称>
,会将该服务转发到实际访问的服务。
三、httpd
- 拉取镜像
docker pull httpd
- 创建服务目录
mkdir /var/www/html
mkdir /var/www/cgi_bin
...
- 启动容器
说明: 在容器内,httpd默认工作路径为/usr/local/apache2/
文件结构:bin build cgi-bin conf error htdocs icons include logs modules
docker run -d --name httpd \
-p 80:80 \
-v /var/www/cgi-bin:/usr/local/apache2/cgi-bin/ \
-v /var/www/html:/usr/local/apache2/htdocs/ \
httpd:latest
如果使用cgi-bin,拷贝容器内httpd.conf文件到外部,对文件做如下修改:
<Directory "/var/www/cgi-bin">
AllowOverride None
Options ExecCGI
Order allow,deny
Allow from all
</Directory>
------------------
<Directory "/var/www/cgi-bin">
Options All
</Directory>
然后启动容器:
docker run -d --name httpd \
-p 80:80 \
-v <local httpd.conf>:/usr/local/apache2/conf/httpd.conf \
httpd:latest