Caddy
优点:
- 自动支持HTTP/2协议
- 使用 Let’s Encrypt 让你的站点全自动变成全站HTTPS,无需任何配置,当然您可以使用自己的密钥和证书
- 得益于 Go 的特性,Caddy 只是一个小小的二进制文件,没有依赖,易于部署/使用 配置起来十分简便
- 可以合理使用多核
- Caddy 对 WebSockets 有很好的支持
- 自动把 Markdown 转成 HTML
- 完全支持最新的IPv6
- 以自定义格式创建日志
- 适用于所有已知的平台 - Windows,Linux,BSD,Mac,Android
缺点:
要说它的缺点,就是效率不如Apache、Nginx,因此对于以下几种还是十分友好的
推荐场景:
- 作为 个人博客的 Server
- 作为 静态页面的 WebServer
- 反向代理,管理多个站点
- 微服务 等等…
安装
Caddy 提醒定制化的下载,可以自由选择各种插件和平台,请前往官网: https://caddyserver.com/download 下载
一、一键脚本安装(非商业版本)1:
curl https://getcaddy.com | bash -s personal
脚本执行完成后,执行 which caddy
,可以看到 caddy 已被安装到了 /usr/local/bin/caddy;caddy -version
查看版本号
二、手动安装(需要商业许可证)
- https://caddyserver.com/download 进入到 caddy 官网的下载界面,选择平台和插件
- 然后使用下方 Direct link to download 内的链接即可
- 解压之后用 cp 命令放到 /usr/local/bin/caddy 就完成了安装
运行
caddy
输入 caddy
,然后打开浏览器输入: http://ip:2015 ,得到了一个404页面,Caddy 已经成功运行了
(1)、在无配置文件的情况下,Caddy 默认是映射当前程序执行的目录所有文件(即/usr/local/bin),因此可以创建一个文件:
touch index.html
echo "<h1>Hello Caddy...</h1>" >> index.html
刷新浏览器, Hello Caddy… 已经出现在页面上
(2)、默认情况下,Caddy 运行在 2015 端口,可以使用 Caddy 命令行工具来自定义运行端口
例:改为运行在80端口
caddy -port 80
其他帮助:
caddy -h
配置文件
一、Host网站配置
Caddy 的各种强大功能还得需要 Caddyfile 来体现,Caddy 不强制你把配置文件放到哪个特定文件夹,可以在任意目录放置我们的配置文件,通过命令行 caddy -conf 即可指定
创建配置文件(本文我们把配置文件放在/usr/local/bin/下)
touch /usr/local/bin/Caddyfile #创建配置文件
chown -R root:www-data /usr/local/bin #设置目录数据权限
编辑 /usr/local/bin/Caddyfile 文件
echo -e ":80 {
root /usr/local/bin/www
}" > /usr/local/bin/Caddyfile
- 解释
- 这是一个最简单的 Host 网站配置
- ‘:80’表示将网站绑定至可以访问到本机的任意一个IP,暴露在80端口,也可以写成 ‘0.0.0.0:80’
- root 参数则表示网站的根节点
通过 caddy -conf /usr/local/bin/Caddyfile
命令用Caddyfile配置文件方式运行Caddy
- 拓展配置
- 设置响应过期时间,启用 gzip, 指定各种日志的输出端等等
echo -e "0.0.0.0:80 {
root /usr/local/www/
timeouts none #响应过期时间 none - 不过期 60s - 1分钟过期
gzip #启用gzip
log /var/log/caddy/access.log #日志
errors /var/log/caddy/error.log #错误日志
}" > /usr/local/bin/Caddyfile
二、反向代理配置
echo -e ":80/api {
proxy / 127.0.0.1:8080/api {
transparent
}
}" > /usr/local/bin/Caddyfile
- 解释:
- 当浏览器收到所有包含:80/api 的请求都会自动转发到127.0.0.1:8080/api 这个地址
- transparent 这个设置保证了转发不会在浏览器生成任何额外的 301 或者 302 请求
三、自动HTTPS
为已经绑定域名的服务器自动从 Let’s Encrypt 生成和下载 HTTPS 证书,支持 HTTPS 协议访问,你只需要将绑定的 IP 换成 域名 即可
echo -e "xxx.com {
root /var/www/html/
}" > /usr/local/bin/Caddyfile
运行Caddy,按照提示输入你的 Email 之后,Caddy 会自动帮你获取并启用 HTTPS 证书
- (1)、需要 curl 文件传输工具支持,如果出现
-bash: curl: command not found
请先安装 curl
(2)、You must specify a personal or commercial license; see getcaddy.com for instructions.
– 您必须指定个人或商业许可证; 有关说明,请参阅 https://getcaddy.com
假设有非商业许可证,请使用:curl https://getcaddy.com | bash -s personal
或者wget -qO- https://getcaddy.com | bash -s personal
您购买了商业许可证,则必须设置您的帐户,环境变量中的ID和API密钥:export CADDY_ACCOUNT_ID = ...
export CADDY_API_KEY = ...
然后使用:curl https://getcaddy.com | bash -s commercial
↩