Caddy簡介
Caddy是一款功能強大、高度可擴展的Web伺服器,目前已經獲得了38K Star的GitHub關注。 Caddy採用Go語言編寫,可用於靜態資源託管和反向代理。
Caddy具有以下主要特性:
對比Nginx複雜的配置,其獨創的Caddyfile配置非常簡單;
可透過其提供的Admin API實現動態修改配置;
預設支援自動化HTTPS配置,可自動申請HTTPS憑證並進行配置;
能夠擴展到數以萬計的站點;
可以在任意地方執行,沒有額外的依賴;
採用Go語言編寫,記憶體安全更有保證。
安裝
首先我們直接在CentOS 8上安裝Caddy,使用DNF工具安裝無疑是最簡單的,Docker安裝方式之後也會介紹。
使用以下指令透過DNF工具安裝Caddy,安裝成功後Caddy會被註冊成系統服務;
dnf install 'dnf-command(copr)'
dnf copr enable @caddy/caddy
dnf install caddy
使用systemctl status caddy查看Caddy的狀態,可以發現Caddy已被註冊為系統服務,但是還沒開啟。
使用
下面我們體驗下Caddy的基本使用,對於Web伺服器來說都是常用的操作,你準能用的上!
基本上使用
讓我們先嘗試使用Caddy進行入門,指定Caddy運行在2015端口,並返回「Hello, world!」資訊。
直接使用caddy指令將輸出Caddy的常用指令,基本看介紹就知道如何使用了,標出來的是常用指令;
使用caddy start指令可以讓Caddy服務在後台運行;
Caddy預設使用JSON格式的設定文件,但由於JOSN格式設定書寫比較麻煩,又提供了Caddyfile這種更加簡潔的設定形式,使用以下指令能自動把Caddyfile轉換成JSON設定;
caddy adapter
我們可以先建立一個名稱為Caddyfile的文件,檔案內容如下,然後再用caddy adapter將它轉換為JSON配置,再使用caddy reload使配置生效,該配置將監聽2015端口,並返回Hello, world!;
:2015
respond "Hello, world!"
然後我們使用curl命令訪問localhost:2015,將返回指定的信息;
當然我們也可以使用Caddy提供的Admin API來查看配置信息,使用如下命令即可;
curl localhost:2019/config/
當前JSON配置如下,如果你直接使用JSON配置的話需要書寫如下配置,使用Caddyfile確實方便很多!
{
"apps": {
"http": {
"servers": {
"srv0": {
"listen": [":2015"],
"routes": [{
"handle": [{
"body": "Hello, world!",
"handler": "static_response"
}]
}]
}
}
}
}
}
Caddyfile基本語法
下面案例將使用Caddyfile來進行配置,我們有必要了解下它的語法,Caddyfile的具體語法規則如下。
介紹下上圖的關鍵字,有助於理解。
關鍵字 |
解釋 |
使用 |
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的前端项目中。
首先我们修改下本机的host文件:
192.168.3.106 docs.macrozheng.com
192.168.3.106 mall.macrozheng.com
然后将我们的文档项目和mall前端项目上传到Caddy的html目录中去,并进行解压操作:
修改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服务上去。
首先我们修改下本机的host文件,添加如下规则
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
}
有个比较大的JS文件压缩前是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
}
}
HTTPS
Caddy能自动支持HTTPS,无需手动配置证书,这就是之前我们在配置域名时需要使用http://开头的原因,要想使用Caddy默认的HTTPS功能,按如下步骤操作即可。
首先我们需要修改域名的DNS解析,直接在购买域名的网站上设置即可,这里以docs.macrozheng.com域名为例;
请使用以下命令确认DNS解析记录是否正确,注意所配置的服务器的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
Docker支持
当然Caddy也是支持使用Docker进行安装使用的,其使用和直接在CentOS上安装基本一致。
首先使用如下命令下载Caddy的Docker镜像;
docker pull caddy
然后在/mydata/caddy/目录下创建Caddyfile配置文件,文件内容如下;
http://192.168.3.105:80
respond "Hello, world!"
之后使用如下命令启动caddy服务,这里将宿主机上的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
输入Caddy命令即可操作,之后的操作就和我们直接在CentOS上安装一样了。
以上是Nginx的Web伺服器caddy怎麼使用的詳細內容。更多資訊請關注PHP中文網其他相關文章!