超越Nginx的Web服務(wù)器caddy優(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)大,推薦給大家!
SpringBoot實戰(zhàn)電商項目mall(50k+star)地址:https://github.com/macrozheng/mall
Caddy簡介
Caddy是一款功能強(qiáng)大,擴(kuò)展性高的Web服務(wù)器,目前在Github上已有38K+Star。Caddy采用Go語言編寫,可用于靜態(tài)資源托管和反向代理。

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

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

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

Caddy默認(rèn)使用JSON格式的配置文件,但由于JOSN格式配置書寫比較麻煩,又提供了Caddyfile這種更加簡潔的配置形式,使用如下命令能自動把Caddyfile轉(zhuǎn)化為JSON配置;
caddy adapter
我們可以先創(chuàng)建一個名稱為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確實方便很多!
{
"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 | 單個網(wǎng)站配置 | 通過file_server可以配置靜態(tài)代理,通過reverse_proxy可以配置動態(tài)代理 |
| Matcher definition | 匹配定義 | 默認(rèn)情況下指令會產(chǎn)生全局影響,通過它可以指定影響范圍 |
| Comment | 注釋 | 使用#符號開頭 |
| Site address | 網(wǎng)站地址 | 默認(rèn)使用HTTPS,如需開啟HTTP,需要指定http://開頭 |
| Directive | 指令 | 指令賦予了Caddy強(qiáng)大的功能 |
反向代理
反向代理就是當(dāng)請求訪問你的代理服務(wù)器時,代理服務(wù)器會對你的請求進(jìn)行轉(zhuǎn)發(fā),可以轉(zhuǎn)發(fā)到靜態(tài)的資源路徑上去,也可以轉(zhuǎn)發(fā)到動態(tài)的服務(wù)接口上去。下面我們以對域名進(jìn)行代理為例,來講講如何進(jìn)行靜態(tài)代理和動態(tài)代理。
靜態(tài)代理
靜態(tài)代理就是將請求代理到不同的靜態(tài)資源路徑上去,這里我們將對docs.macrozheng.com的請求代理到我的文檔項目中,對mall.macrozheng.com的請求代理到mall的前端項目中。
首先我們修改下本機(jī)的host文件:
192.168.3.106 docs.macrozheng.com
192.168.3.106 mall.macrozheng.com
然后將我們的文檔項目和mall前端項目上傳到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文件格式不太合格的話,會出現(xiàn)如下警告,直接使用caddy fmt --overwrite格式化并重寫配置即可解決;

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

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

動態(tài)代理
動態(tài)代理就是把代理服務(wù)器的請求轉(zhuǎn)發(fā)到另一個服務(wù)上去,這里我們將把對api.macrozheng.com的請求代理到演示環(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)站訪問速度會很慢,這時我們可以通過讓Caddy開啟Gzip壓縮來提高網(wǎng)站的訪問速度。這里我們以mall的前端項目為例來演示下它的提速效果。
我們需要修改Caddyfile文件,使用encode指令開啟Gzip壓縮,修改完成后使用caddy reload命令刷新配置;
http://mall.macrozheng.com {
root * /mydata/caddy/html/mall
encode {
gzip
}
file_server browse
}
有個比較大的JS文件壓縮前是1.7M;

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

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

地址重寫
有的時候我們的網(wǎng)站更換了域名,但還有用戶在使用老的域名訪問,這時可以通過Caddy的地址重寫功能來讓用戶跳轉(zhuǎn)到新的域名進(jìn)行訪問。
我們需要修改Caddyfile文件,使用redir指令重寫地址,修改完成后使用caddy reload命令刷新配置;
http://docs.macrozheng.com {
redir http://www.macrozheng.com
}
此時訪問舊域名docs.macrozheng.com會直接跳轉(zhuǎn)到www.macrozheng.com去。
按目錄劃分
有時候我們需要使用同一個域名來訪問不同的前端項目,這時候就需要通過子目錄來區(qū)分前端項目了。
比如說我們需要按以下路徑來訪問各個前端項目;
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默認(rèn)的HTTPS功能,按如下步驟操作即可。
首先我們需要修改域名的DNS解析,直接在購買域名的網(wǎng)站上設(shè)置即可,這里以docs.macrozheng.com域名為例;
之后使用如下命令驗證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命令啟動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!"
之后使用如下命令啟動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é)
今天體驗了一把Caddy,其強(qiáng)大的指令功能,讓我們無需多余的配置即可實現(xiàn)各種功能,使用起來確實非常優(yōu)雅!尤其是其能自動配置實現(xiàn)HTTPS,非常不錯!Nginx能實現(xiàn)的功能Caddy基本都能實現(xiàn),大家可以對比下之前寫的Nginx使用教程 ,你就會發(fā)現(xiàn)使用Caddy來實現(xiàn)有多么優(yōu)雅!
參考資料
項目地址:https://github.com/caddyserver/caddy
更多關(guān)于caddy服務(wù)器的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
vscode設(shè)置免密登錄遠(yuǎn)程服務(wù)器的解決方案
當(dāng)我們使用vscode的ssh連接遠(yuǎn)程服務(wù)器后,過一段時間后,總是要求登錄服務(wù)器的密碼,遇到這樣的問題如何解決呢,下面給大家分享vscode設(shè)置免密登錄遠(yuǎn)程服務(wù)器的解決方案,感興趣的朋友跟隨小編一起看看吧2024-05-05
公網(wǎng)使用SSH遠(yuǎn)程登錄macOS服務(wù)器的過程(內(nèi)網(wǎng)穿透)
這篇文章主要介紹了公網(wǎng)使用SSH遠(yuǎn)程登錄macOS服務(wù)器【內(nèi)網(wǎng)穿透】,本次教程,我們將使用cpolar內(nèi)網(wǎng)穿透工具,映射ssh服務(wù)默認(rèn)端口:22端口,獲取公網(wǎng)地址,實現(xiàn)在公網(wǎng)環(huán)境下的ssh遠(yuǎn)程登錄,無需公網(wǎng)IP,也無需設(shè)置路由器,需要的朋友可以參考下2023-04-04
如何通過Apache Bench實現(xiàn)web壓力測試
這篇文章主要介紹了如何通過Apache Bench實現(xiàn)web壓力測試,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-05-05
Ubuntu服務(wù)器中Swapper與虛擬內(nèi)存配合的方法
當(dāng)物理內(nèi)存不足時,Swapper會幫助系統(tǒng)將不活躍的數(shù)據(jù)從內(nèi)存轉(zhuǎn)移到磁盤上的交換空間(Swap),以釋放內(nèi)存給需要更多資源的進(jìn)程,下面將詳細(xì)說明Swapper和虛擬內(nèi)存如何協(xié)作工作,并闡述它們在系統(tǒng)性能中的作用,感興趣的朋友一起看看吧2025-03-03
生產(chǎn)服務(wù)器突然本機(jī)無法訪問本機(jī)IP的端口的問題及解決方法
生產(chǎn)服務(wù)器突然無法訪問自己本機(jī)IP地址的端口,通過localhost或者127.0.0.1都可以正常訪問,本文給大家分享生產(chǎn)服務(wù)器突然本機(jī)無法訪問本機(jī)IP的端口的問題及解決方法,感興趣的朋友一起看看吧2023-11-11
服務(wù)器負(fù)載均衡是什么意思(服務(wù)器負(fù)載均衡的基本功能和實現(xiàn)原理)
這篇文章主要介紹了服務(wù)器負(fù)載均衡是什么意思,服務(wù)器負(fù)載均衡的基本功能和實現(xiàn)原理,需要的朋友可以參考下2017-08-08

