超越 Nginx!號(hào)稱下一代 Web 服務(wù)器,用起來夠優(yōu)雅!

源?/?? ? ? ??文/?
Nginx是一款非常流行的Web服務(wù)器,在Github上已有
16K+Star,我們經(jīng)常用它來做靜態(tài)資源托管或反向代理。最近發(fā)現(xiàn)了一款全新的Web服務(wù)器Caddy,Star數(shù)超越Nginx,標(biāo)星38K+Star。試用了一下Caddy,發(fā)現(xiàn)它使用起來比Nginx優(yōu)雅多了,功能也很強(qiáng)大,推薦給大家!
Caddy簡介
Caddy是一款功能強(qiáng)大,擴(kuò)展性高的Web服務(wù)器,目前在Github上已有38K+Star。Caddy采用Go語言編寫,可用于靜態(tài)資源托管和反向代理。

Caddy具有如下主要特性:
對(duì)比Nginx復(fù)雜的配置,其獨(dú)創(chuàng)的 Caddyfile配置非常簡單;可以通過其提供的 Admin API實(shí)現(xiàn)動(dòng)態(tài)修改配置;默認(rèn)支持自動(dòng)化HTTPS配置,能自動(dòng)申請(qǐng)HTTPS證書并進(jìn)行配置; 能夠擴(kuò)展到數(shù)以萬計(jì)的站點(diǎn); 可以在任意地方執(zhí)行,沒有額外的依賴; 采用Go語言編寫,內(nèi)存安全更有保證。
安裝
首先我們直接在CentOS 8上安裝Caddy,使用DNF工具安裝無疑是最簡單的,Docker安裝方式之后也會(huì)介紹。
使用如下命令通過DNF工具安裝Caddy,安裝成功后Caddy會(huì)被注冊(cè)成系統(tǒng)服務(wù);
dnf?install?'dnf-command(copr)'
dnf?copr?enable?@caddy/caddy
dnf?install?caddy
使用 systemctl status caddy查看Caddy的狀態(tài),可以發(fā)現(xiàn)Caddy已被注冊(cè)為系統(tǒng)服務(wù),但是還沒開啟。

使用
下面我們體驗(yàn)下Caddy的基本使用,對(duì)于Web服務(wù)器來說都是常用的操作,你準(zhǔn)能用的上!
基本使用
首先我們來個(gè)Caddy的入門使用,讓Caddy運(yùn)行在
2015端口上并返回Hello, world!。
直接使用 caddy命令將輸出Caddy的常用命令,基本看介紹就知道如何使用了,標(biāo)出來的是常用命令;

使用 caddy start命令可以讓Caddy服務(wù)在后臺(tái)運(yùn)行;

Caddy默認(rèn)使用JSON格式的配置文件,但由于JOSN格式配置書寫比較麻煩,又提供了 Caddyfile這種更加簡潔的配置形式,使用如下命令能自動(dòng)把Caddyfile轉(zhuǎn)化為JSON配置;
caddy?adapter
我們可以先創(chuàng)建一個(gè)名稱為 Caddyfile的文件,文件內(nèi)容如下,然后使用caddy adapter將它轉(zhuǎn)換為JSON配置,再使用caddy reload使配置生效,該配置將監(jiān)聽2015端口,并返回Hello, world!;
:2015
respond?"Hello,?world!"
然后我們使用curl命令訪問 localhost:2015,將返回指定的信息;

當(dāng)然我們還可以使用Caddy提供的 Admin API來查看配置信息,使用如下命令即可;
curl?localhost:2019/config/
當(dāng)前JSON配置如下,如果你直接使用JSON配置的話需要書寫如下配置,使用 Caddyfile確實(shí)方便很多!
{
?"apps":?{
??"http":?{
???"servers":?{
????"srv0":?{
?????"listen":?[":2015"],
?????"routes":?[{
??????"handle":?[{
???????"body":?"Hello,?world!",
???????"handler":?"static_response"
??????}]
?????}]
????}
???}
??}
?}
}
Caddyfile基本語法
下面案例將使用 Caddyfile來進(jìn)行配置,我們有必要了解下它的語法,Caddyfile的具體語法規(guī)則如下。

介紹下上圖中的關(guān)鍵字,有助于理解。
| 關(guān)鍵字 | 解釋 | 使用 |
|---|---|---|
| Global options block | 服務(wù)器全局配置 | 可用于配置是否啟用HTTPS和Admin API等 |
| Snippet | 可以復(fù)用的配置片段 | 定義好后認(rèn)可以通過import關(guān)鍵字引用 |
| Site Block | 單個(gè)網(wǎng)站配置 | 通過file_server可以配置靜態(tài)代理,通過reverse_proxy可以配置動(dòng)態(tài)代理 |
| Matcher definition | 匹配定義 | 默認(rèn)情況下指令會(huì)產(chǎn)生全局影響,通過它可以指定影響范圍 |
| Comment | 注釋 | 使用#符號(hào)開頭 |
| Site address | 網(wǎng)站地址 | 默認(rèn)使用HTTPS,如需開啟HTTP,需要指定http://開頭 |
| Directive | 指令 | 指令賦予了Caddy強(qiáng)大的功能 |
反向代理
反向代理就是當(dāng)請(qǐng)求訪問你的代理服務(wù)器時(shí),代理服務(wù)器會(huì)對(duì)你的請(qǐng)求進(jìn)行轉(zhuǎn)發(fā),可以轉(zhuǎn)發(fā)到靜態(tài)的資源路徑上去,也可以轉(zhuǎn)發(fā)到動(dòng)態(tài)的服務(wù)接口上去。下面我們以對(duì)域名進(jìn)行代理為例,來講講如何進(jìn)行靜態(tài)代理和動(dòng)態(tài)代理。
靜態(tài)代理
靜態(tài)代理就是將請(qǐng)求代理到不同的靜態(tài)資源路徑上去,這里我們將對(duì)
docs.macrozheng.com的請(qǐng)求代理到我的文檔項(xiàng)目中,對(duì)mall.macrozheng.com的請(qǐng)求代理到mall的前端項(xiàng)目中。
首先我們修改下本機(jī)的host文件:
192.168.3.106?docs.macrozheng.com
192.168.3.106?mall.macrozheng.com
然后將我們的文檔項(xiàng)目和mall前端項(xiàng)目上傳到Caddy的html目錄中去,并進(jìn)行解壓操作:

修改 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文件格式不太合格的話,會(huì)出現(xiàn)如下警告,直接使用caddy fmt --overwrite格式化并重寫配置即可解決;

通過 docs.macrozheng.com即可訪問部署好的文檔項(xiàng)目了:

通過 mall.macrozheng.com即可訪問到部署好的前端項(xiàng)目了。

動(dòng)態(tài)代理
動(dòng)態(tài)代理就是把代理服務(wù)器的請(qǐng)求轉(zhuǎn)發(fā)到另一個(gè)服務(wù)上去,這里我們將把對(duì)
api.macrozheng.com的請(qǐng)求代理到演示環(huán)境的API服務(wù)上去。
首先我們修改下本機(jī)的host文件,添加如下規(guī)則:
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文檔頁面了。

文件壓縮
如果我們的服務(wù)器帶寬比較低,網(wǎng)站訪問速度會(huì)很慢,這時(shí)我們可以通過讓Caddy開啟Gzip壓縮來提高網(wǎng)站的訪問速度。這里我們以mall的前端項(xiàng)目為例來演示下它的提速效果。
我們需要修改 Caddyfile文件,使用encode指令開啟Gzip壓縮,修改完成后使用caddy reload命令刷新配置;
http://mall.macrozheng.com?{
????????root?*?/mydata/caddy/html/mall
????????encode?{
????????????gzip
????????}
????????file_server?browse
}
有個(gè)比較大的JS文件壓縮前是 1.7M;

壓縮后為 544K,訪問速度也有很大提示;

另外我們可以看下響應(yīng)信息,如果有 Content-Encoding: gzip這個(gè)響應(yīng)頭表明Gzip壓縮已經(jīng)啟用了。

地址重寫
有的時(shí)候我們的網(wǎng)站更換了域名,但還有用戶在使用老的域名訪問,這時(shí)可以通過Caddy的地址重寫功能來讓用戶跳轉(zhuǎn)到新的域名進(jìn)行訪問。
我們需要修改 Caddyfile文件,使用redir指令重寫地址,修改完成后使用caddy reload命令刷新配置;
http://docs.macrozheng.com?{
????????redir?http://www.macrozheng.com
}
此時(shí)訪問舊域名 docs.macrozheng.com會(huì)直接跳轉(zhuǎn)到www.macrozheng.com去。
按目錄劃分
有時(shí)候我們需要使用同一個(gè)域名來訪問不同的前端項(xiàng)目,這時(shí)候就需要通過子目錄來區(qū)分前端項(xiàng)目了。
比如說我們需要按以下路徑來訪問各個(gè)前端項(xiàng)目;
www.macrozheng.com?#訪問文檔項(xiàng)目
www.macrozheng.com/admin?#訪問后臺(tái)項(xiàng)目
www.macrozheng.com/app?#訪問移動(dòng)端項(xiàng)目
我們需要修改 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能自動(dòng)支持HTTPS,無需手動(dòng)配置證書,這就是之前我們?cè)谂渲糜蛎麜r(shí)需要使用
http://開頭的原因,要想使用Caddy默認(rèn)的HTTPS功能,按如下步驟操作即可。
首先我們需要修改域名的DNS解析,直接在購買域名的網(wǎng)站上設(shè)置即可,這里以
docs.macrozheng.com域名為例;之后使用如下命令驗(yàn)證DNS解析記錄是否正確,注意配置的服務(wù)器的
80和443端口需要在外網(wǎng)能正常訪問;
curl?"https://cloudflare-dns.com/dns-query?name=docs.macrozheng.com&type=A"?\
??-H?"accept:?application/dns-json"
修改 Caddyfile配置文件,進(jìn)行如下配置;
docs.macrozheng.com?{
????????root?*?/mydata/caddy/html/docs
????????file_server?browse
}
然后使用 caddy run命令啟動(dòng)Caddy服務(wù)器即可,是不是非常方便!
caddy?run
Docker支持
當(dāng)然Caddy也是支持使用Docker進(jìn)行安裝使用的,其使用和直接在CentOS上安裝基本一致。
首先使用如下命令下載Caddy的Docker鏡像;
docker?pull?caddy
然后在 /mydata/caddy/目錄下創(chuàng)建Caddyfile配置文件,文件內(nèi)容如下;
http://192.168.3.105:80
respond?"Hello,?world!"
之后使用如下命令啟動(dòng)caddy服務(wù),這里將宿主機(jī)上的 Caddyfile配置文件、Caddy的數(shù)據(jù)目錄和網(wǎng)站目錄掛載到了容器中;
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進(jìn)入caddy容器內(nèi)部執(zhí)行命令;
docker?exec?-it?caddy?/bin/sh
輸入Caddy命令即可操作,之后的操作就和我們直接在CentOS上安裝一樣了。

總結(jié)
今天體驗(yàn)了一把Caddy,其強(qiáng)大的指令功能,讓我們無需多余的配置即可實(shí)現(xiàn)各種功能,使用起來確實(shí)非常優(yōu)雅!尤其是其能自動(dòng)配置實(shí)現(xiàn)HTTPS,非常不錯(cuò)!Nginx能實(shí)現(xiàn)的功能Caddy基本都能實(shí)現(xiàn),大家可以對(duì)比下之前寫的Nginx使用教程?,你就會(huì)發(fā)現(xiàn)使用Caddy來實(shí)現(xiàn)有多么優(yōu)雅!
參考資料
項(xiàng)目地址:https://github.com/caddyserver/caddy 官方文檔:https://caddyserver.com/
end

頂級(jí)程序員:topcoding
做最好的程序員社區(qū):Java后端開發(fā)、Python、大數(shù)據(jù)、AI
一鍵三連「分享」、「點(diǎn)贊」和「在看」
