Caddy简介Caddy是一款功能强大,扩展性高的Web服务器,目前在Github上已有 38K+Star 。Caddy采用Go语言编写,可用于静态资源托管和反向代理。Caddy具有如下主要特性:
安装
dnf install 'dnf-command(copr)'
使用
基本使用
caddy adapter
:2015
curl localhost:2019/config/
{
|
关键字 | 解释 | 使用 |
---|---|---|
Global options block | 服务器全局配置 | 可用于配置是否启用HTTPS和Admin API等 |
Snippet | 可以复用的配置片段 | 定义好后认可以通过import 关键字引用 |
Site Block | 单个网站配置 | 通过file_server 可以配置静态代理,通过reverse_proxy 可以配置动态代理 |
Matcher definition | 匹配定义 | 默认情况下指令会产生全局影响,通过它可以指定影响范围 |
Comment | 注释 | 使用# 符号开头 |
Site address | 网站地址 | 默认使用HTTPS,如需开启HTTP,需要指定http:// 开头 |
Directive | 指令 | 指令赋予了Caddy强大的功能 |
反向代理就是当请求访问你的代理服务器时,代理服务器会对你的请求进行转发,可以转发到静态的资源路径上去,也可以转发到动态的服务接口上去。下面我们以对域名进行代理为例,来讲讲如何进行静态代理和动态代理。
静态代理就是将请求代理到不同的静态资源路径上去,这里我们将对docs.macrozheng.com
的请求代理到我的文档项目中,对mall.macrozheng.com
的请求代理到mall的前端项目中。
192.168.3.106 docs.macrozheng.com
192.168.3.106 mall.macrozheng.com
Caddyfile
文件,使用如下配置,修改完成后使用caddy reload
命令刷新配置;http://docs.macrozheng.com {
root * /mydata/caddy/html/docs
file_server browse
}
http://mall.macrozheng.com {
root * /mydata/caddy/html/mall
file_server browse
}
Caddyfile
文件格式不太合格的话,会出现如下警告,直接使用caddy fmt --overwrite
格式化并重写配置即可解决;docs.macrozheng.com
即可访问部署好的文档项目了:mall.macrozheng.com
即可访问到部署好的前端项目了。
动态代理就是把代理服务器的请求转发到另一个服务上去,这里我们将把对api.macrozheng.com
的请求代理到演示环境的API服务上去。
192.168.3.106 api.macrozheng.com
Caddyfile
文件,使用如下配置,修改完成后使用caddy reload
命令刷新配置;http://api.macrozheng.com {
reverse_proxy http://admin-api.macrozheng.com
}
api.macrozheng.com/swagger-ui.html
即可访问到mall-admin
的API文档页面了。
如果我们的服务器带宽比较低,网站访问速度会很慢,这时我们可以通过让Caddy开启Gzip压缩来提高网站的访问速度。这里我们以mall的前端项目为例来演示下它的提速效果。
Caddyfile
文件,使用encode
指令开启Gzip压缩,修改完成后使用caddy reload
命令刷新配置;http://mall.macrozheng.com {
root * /mydata/caddy/html/mall
encode {
gzip
}
file_server browse
}
1.7M
;544K
,访问速度也有很大提示;Content-Encoding: gzip
这个响应头表明Gzip压缩已经启用了。
有的时候我们的网站更换了域名,但还有用户在使用老的域名访问,这时可以通过Caddy的地址重写功能来让用户跳转到新的域名进行访问。
Caddyfile
文件,使用redir
指令重写地址,修改完成后使用caddy reload
命令刷新配置;http://docs.macrozheng.com {
redir http://www.macrozheng.com
}
docs.macrozheng.com
会直接跳转到www.macrozheng.com
去。
有时候我们需要使用同一个域名来访问不同的前端项目,这时候就需要通过子目录来区分前端项目了。
www.macrozheng.com #访问文档项目
www.macrozheng.com/admin #访问后台项目
www.macrozheng.com/app #访问移动端项目
Caddyfile
文件,使用route
指令定义路由,修改完成后使用caddy reload
命令刷新配置。http://www.macrozheng.com {
route /admin/* {
uri strip_prefix /admin
file_server {
root /mydata/caddy/html/admin
}
}
route /app/* {
uri strip_prefix /app
file_server {
root /mydata/caddy/html/app
}
}
file_server * {
root /mydata/caddy/html/www
}
}
Caddy能自动支持HTTPS,无需手动配置证书,这就是之前我们在配置域名时需要使用http://
开头的原因,要想使用Caddy默认的HTTPS功能,按如下步骤操作即可。
docs.macrozheng.com
域名为例;80
和443
端口需要在外网能正常访问;curl "https://cloudflare-dns.com/dns-query?name=docs.macrozheng.com&type=A" \
-H "accept: application/dns-json"
Caddyfile
配置文件,进行如下配置;docs.macrozheng.com {
root * /mydata/caddy/html/docs
file_server browse
}
caddy run
命令启动Caddy服务器即可,是不是非常方便!caddy run
当然Caddy也是支持使用Docker进行安装使用的,其使用和直接在CentOS上安装基本一致。
docker pull caddy
/mydata/caddy/
目录下创建Caddyfile
配置文件,文件内容如下;http://192.168.3.105:80
respond "Hello, world!"
Caddyfile
配置文件、Caddy的数据目录和网站目录挂载到了容器中;docker run -p 80:80 -p 443:443 --name caddy \
-v /mydata/caddy/Caddyfile:/etc/caddy/Caddyfile \
-v /mydata/caddy/data:/data \
-v /mydata/caddy/html:/usr/share/caddy \
-d caddy
docker exec
进入caddy容器内部执行命令;docker exec -it caddy /bin/sh