Caddy是什么?在Caddy的官网上给出一个最简单的介绍:“Caddy是一个能自动创建HTTPS功能的HTTP/2网站服务器”。简单的一句话,突出了两大卖点,“自动创建HTTPS”和“HTTP/2”。
caddy致力于成为一个易用的静态文件Web Server。Caddy的作者是来自美国的Matthew Holt,因为是用Go语言开发的,所以Caddy天生里就带着高并发的基因。据国内技术人士测试,其同时并发数优于Apache,略低于Nginx。“几乎所有的功能在Caddy里的都是插件”。
Git: https://github.com/caddyserver/caddy
官网:https://caddyserver.com/download
下载:https://github.com/caddyserver/caddy/releases
官网文档:https://caddyserver.com/docs/
配置文件:https://caddyserver.com/v1/tutorial/caddyfile
相关介绍网文:https://blog.csdn.net/weixin_34279184/article/details/93033005
关于https: https://caddyserver.com/docs/automatic-https
有网友翻译了一下:https://docs.getcaddy.cn/
最新已经出v2测试版了,网上基本介绍的是v1。看起来v2麻烦了些,有点失去初衷的感觉。
配置起来十分简便,甚至可以 28 秒配置好一个支持 http2 的 server ,而且对各种 http 新特性都支持的比较早(比如 http2、quic都有支持)。
基本特性
-
默认支持HTTP/2,使用 Let’s Encrypt 可以全自动变成全站HTTPS,无需任何配置(可配置自己CA证书);
-
多核支持;
-
完全支持IPv6;
-
功能插件化,可以自己轻松开发插件;
-
支持WebSockets;
-
支持自动把md转成 HTML;
-
简单的log日志配置;
-
二进制部署,无依赖;
-
反向代理,管理多个站点;
下载,解压 tar -xzf caddy.tar.gz caddy
运行即可打开http://localhost:2015,如果看到404错误,则需要根目录添加index文件(据说支持index.html,index.htm,default.html,default.htm)。
指定主机名: caddy -host example.com
指定配置文件:caddy -conf ./Caddyfile
配置文件内容
localhost:8080 //指定访问地址和域名
gzip //数据压缩
log ../access.log //日志
mysite.com { //指定网站及配置
root /www/mysite.com
log ../mysite.log
}
localhost:8080,https://site.com, http://ysite.com { //多个网站配置相同
}
example.com/static,*.example.com { //通配符
}
localhost:{$PORT} //配置文件中使用环境变量
root {%SITE_ROOT%}
foot.com:80{
log ./foo.log
gzip
}
bar.com:80{
log ./bar.log
gzip
browse //支持目录浏览
}
支持基本的反向代理功能,通过proxy middleware实现。
localhost:2015{
log ./2015.log
proxy /foo localhost:9001
proxy /bar localhost:9002
}
负载均衡支持random(随机)、last_conn(最少连接)、round_robin(轮询)
localhost:2015{
log ./2015.log
proxy / localhost:9001 localhost:9003{
policy round_robin
}
proxy /bar localhost:9002 localhost:9004 {
policy least_conn
}
}
对于最新的V2.0.0 - beta13版中,默认端口改为了2019,运行使用caddy run指令。
我简单的建立了一个Caddyfile
localhost:2021 {
file_server
root * /hugo/EaseBlog/public
}
localhost:2020 {
redir http://i.scwy.net
}
将本地hugo建立的public目录开放到静态服务器上。
比较神奇的是这个
localhost:6060 {
respond "Hello,world!"
}
浏览页面时,直接返回信息。
运行 caddy reload,它通过消息机制来重载配置文件。也可以通过 caddy stop 来停止服务运行。
运行 caddy file-server –browse ,若有index.html等文件则显示此文件,否则浏览目录及文件。
caddy file-server –listen :8080 指定端口
caddy file-server –root ~/mysite 指定根目录
caddy reverse-proxy –from 127.0.0.1:2016 –to localhost:8080 把2016端口的请求转给8080
然而在配置文件中写入却没有效果
localhost:9090 {
reverse_proxy www.baidu.com:80
}
仿佛配置文件中改为域名,添加tls项为自己的邮箱,它即会自动帮你https
domain.com:443 {
root /var/www/notadd/public
index index.php
tls you@163.com # 自动申请证书,必须在外网,且80可访问
}
允许压缩在v2版本中改为encode gzip,注意root也改了 root * /wwww 这样。
据说直接支持markdown渲染为html,但在v2版本中不知道如何使用,有机会再研究。