docker-compose 搭建部署Caddy使用

原文链接:https://blog.csdn.net/LZY_1993/article/details/103943065

1、创建目录(在root目录下)

$ mkdir -p caddy/{conf,logs,www}
$ cd caddy

目录结构为个人习惯,可以按照自己的习惯配置,
 
2、配置Caddyfile

$ vi conf/Caddyfile
www.?????.net {
gzip
root /opt/www 
timeouts 30s
log /opt/logs/access.log 
proxy /other localhost:8080 
proxy /more localhost:8081 localhost:8082 #负载均衡
}

以上是在配置公网域名后的配置,还没有配置域名?那直接用 IP 就行,如下

192.168.1.2:80 192.168.1.2:443 {
gzip
root /opt/www 
tls self_signed #自动签名,很重要
timeouts 30s
log /opt/logs/access.log
proxy /other localhost:8080
}

相信很多人会和我一样,caddy是在 虚拟机 上部署,但是访问却在物理机上,如果按照网上的一些配置文档,随便编写一个域名,就会无法访问,不在同一个环境了,物理机上输入自定义的域名是不可能解析出ip访问到你的虚拟机的。

3、配置docker-compose.yml

$ vi docker-compose.yml
version: '3.3'

services:
# http/2 server
caddy:
image: abiosoft/caddy:latest
container_name: caddy
hostname: caddy
domainname: caddy
restart: always
network_mode: "host"
environment:
- TZ=Asia/Shanghai
- agree
- email ?????@qq.com
volumes:
- "/root/caddy/conf/Caddyfile:/etc/Caddyfile"
- "/root/caddy/.caddy:/root/.caddy"
- "/root/caddy/logs:/opt/logs"
- "/root/caddy/www:/opt/www"
ports:
- 80:80
- 443:443

其中三个环境变量(environment)非常重要
 1、配置上海时区
 2、同意caddy自动配置ssl证书
 3、caddy需要的反馈邮箱 

注意,如果自定义了自己的目录结构,这里的数据卷 volumes 下的配置也要对应你自己的目录结构

 
4、启动

$ docker-compose up -d
$ docker logs -f caddy # 查看日志

嗯?还没有安装 docker-compose ?

# 安装docker-compose
$ sudo curl -L https://github.com/docker/compose/releases/download/1.18.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose

# 添加目录权限
$ sudo chmod +x /usr/local/bin/docker-compose

# 验证docker-compose安装是否成功
$ docker-compose --version

5、测试
随便复制个文件到 www 目录下,我复制了个图片bg.jpg,
然后输入 https://192.168.1.2/bg.jpg

在火狐浏览器打开后是证书不被信任,点击高级,继续访问便可
 
6、相关命令

$ docker-compose up     # 前台启动容器,命令退出时,所有容器都将停止

$ docker-compose up -d     # 在后台启动容器并使它们保持运行

$ docker logs -f [container_id]     # 查看某一容器的启动的日志打印(日志从头打印)

$ docker logs -f --tail [数量] [container_id]     # 查看某一容器的启动的日志打印(查看最后n条日志打印)。 例:docker logs -f --tail 50 44b 

$ docker-compose stop     # 停止compose服务

$ docker-compose restart     # 重启compose服务

$ docker-compose kill     # kill compose服务

$ docker-compose ps     #查看compose服务状态

$ docker-compose rm     #删除compose服务




猜你喜欢

转载自www.cnblogs.com/lzy1993/p/12727382.html