Caddy使用简介LinuxServer

印迹发布于:2019-3-17 1259

说起 HTTP server,使用最广泛的就是 apache 和 nginx 了,功能都非常强大,但相对而言,学习它们的配置是有一定难度的。最近发现了一个 golang 开发的 HTTP server,叫做 Caddy,配置起来十分简便,而且对各种 http 新特性都支持的比较早(比如 http2、quic都有支持)。

Caddy 是一款由 Go 编写的 Web Server 工具,能让网站自动支持 HTTPS。同样是使用 Let's Encrypt,换成 Nginx 就必须手工操作,并且还需要设置三个月更新证书的计划任务。且默认支持 http/2,很多事情都不需要再配置。它的配置文件也比 Nginx 的要简单很多,几十行的 Nginx 配置文件 Caddy 仅需要几行就可以搞定了。

官网: https://caddyserver.com

优点:

自动支持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:

(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
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 证书

Caddy 简单易用、自动 HTTPS ,此外 Caddy 还提供一大堆的插件供我们使用,是一款不错的 Web 服务器



http://www.virplus.com/thread-196.htm
转载请注明:2019-3-17 于 VirPlus 发表

推荐阅读
最新回复 (0)

    ( 登录 ) 后,可以发表评论!

    返回