超越Nginx的Web服务器caddy优雅用法


Posted in Servers onJune 21, 2022

前言

超越Nginx的Web服务器caddy优雅用法

Nginx是一款非常流行的Web服务器,在Github上已有16K+Star,我们经常用它来做静态资源托管或反向代理。最近发现了一款全新的Web服务器Caddy,Star数超越Nginx,标星38K+Star。试用了一下Caddy,发现它使用起来比Nginx优雅多了,功能也很强大,推荐给大家!

SpringBoot实战电商项目mall(50k+star)地址:https://github.com/macrozheng/mall

Caddy简介

Caddy是一款功能强大,扩展性高的Web服务器,目前在Github上已有38K+Star。Caddy采用Go语言编写,可用于静态资源托管和反向代理。

超越Nginx的Web服务器caddy优雅用法

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已被注册为系统服务,但是还没开启。

超越Nginx的Web服务器caddy优雅用法

使用

下面我们体验下Caddy的基本使用,对于Web服务器来说都是常用的操作,你准能用的上!

基本使用

首先我们来个Caddy的入门使用,让Caddy运行在2015端口上并返回Hello, world!。

直接使用caddy命令将输出Caddy的常用命令,基本看介绍就知道如何使用了,标出来的是常用命令;

超越Nginx的Web服务器caddy优雅用法

使用caddy start命令可以让Caddy服务在后台运行;

超越Nginx的Web服务器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,将返回指定的信息;

超越Nginx的Web服务器caddy优雅用法

当然我们还可以使用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的具体语法规则如下。

超越Nginx的Web服务器caddy优雅用法

介绍下上图中的关键字,有助于理解。

关键字 解释 使用
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目录中去,并进行解压操作:

超越Nginx的Web服务器caddy优雅用法

修改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格式化并重写配置即可解决;

超越Nginx的Web服务器caddy优雅用法

通过docs.macrozheng.com即可访问部署好的文档项目了:

超越Nginx的Web服务器caddy优雅用法

通过mall.macrozheng.com即可访问到部署好的前端项目了。

超越Nginx的Web服务器caddy优雅用法

动态代理

动态代理就是把代理服务器的请求转发到另一个服务上去,这里我们将把对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文档页面了。

超越Nginx的Web服务器caddy优雅用法

文件压缩

如果我们的服务器带宽比较低,网站访问速度会很慢,这时我们可以通过让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;

超越Nginx的Web服务器caddy优雅用法

压缩后为544K,访问速度也有很大提示;

超越Nginx的Web服务器caddy优雅用法

另外我们可以看下响应信息,如果有Content-Encoding: gzip这个响应头表明Gzip压缩已经启用了。

超越Nginx的Web服务器caddy优雅用法

地址重写

有的时候我们的网站更换了域名,但还有用户在使用老的域名访问,这时可以通过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优雅用法

总结

今天体验了一把Caddy,其强大的指令功能,让我们无需多余的配置即可实现各种功能,使用起来确实非常优雅!尤其是其能自动配置实现HTTPS,非常不错!Nginx能实现的功能Caddy基本都能实现,大家可以对比下之前写的Nginx使用教程 ,你就会发现使用Caddy来实现有多么优雅!

参考资料

项目地址:https://github.com/caddyserver/caddy

官方文档:https://caddyserver.com/

更多关于caddy服务器的资料请关注三水点靠木其它相关文章!


Tags in this post...

Servers 相关文章推荐
Nginx 502 Bad Gateway错误原因及解决方案
Mar 31 Servers
nginx 多个location转发任意请求或访问静态资源文件的实现
Mar 31 Servers
nginx里的rewrite跳转的实现
Mar 31 Servers
nginx限制并发连接请求数的方法
Apr 01 Servers
NGINX 权限控制文件预览和下载的实现原理
Jan 18 Servers
使用kubeadm命令行工具创建kubernetes集群
Mar 31 Servers
教你使用Jenkins集成Harbor自动发布镜像
Apr 03 Servers
Nginx禁止ip访问或非法域名访问
Apr 07 Servers
Windows Server 2019 配置远程控制以及管理方法
Apr 28 Servers
Windows Server 2019 安装DHCP服务及相关配置
Apr 28 Servers
Apache SkyWalking 监控 MySQL Server 实战解析
Sep 23 Servers
windows server2012 R2下安装PaddleOCR服务的的详细步骤
Sep 23 Servers
详解ZABBIX监控ESXI主机的问题
Jun 21 #Servers
Apache POI操作批量导入MySQL数据库
Jun 21 #Servers
Ubuntu安装Mysql+启用远程连接的完整过程
Jun 21 #Servers
shell进度条追踪指令执行时间的场景分析
Jun 16 #Servers
Linux服务器离线安装 nginx的详细步骤
Jun 16 #Servers
利用Apache Common将java对象池化的问题
Jun 16 #Servers
Tomcat 与 maven 的安装与使用教程
You might like
thinkphp中连接oracle时封装方法无法用的解决办法
2013/06/17 PHP
php提取微信账单的有效信息
2018/10/01 PHP
TopList标签和JavaScript结合两例
2007/08/12 Javascript
从零开始学习jQuery (六) jquery中的AJAX使用
2011/02/23 Javascript
js 立即调用的函数表达式如何写
2014/01/12 Javascript
javascript实现点击后变换按钮显示文字的方法
2015/05/13 Javascript
IE中document.createElement的iframe无法设置属性name的解决方法
2015/09/14 Javascript
javascript弹出带文字信息的提示框效果
2016/07/19 Javascript
JavaScript使用正则表达式获取全部分组内容的方法示例
2017/01/17 Javascript
seajs中模块依赖的加载处理实例分析
2017/10/10 Javascript
Vuex 进阶之模块化组织详解
2018/01/12 Javascript
JavaScript复制内容到剪贴板的两种常用方法
2018/02/27 Javascript
详解vue表单——小白速看
2018/04/08 Javascript
javascript验证form表单数据的案例详解
2019/03/25 Javascript
浅谈vue中使用编辑器vue-quill-editor踩过的坑
2020/08/03 Javascript
[13:18]《一刀刀一天》之DOTA全时刻21:详解TI新赛制 A队再露獠牙
2014/06/24 DOTA
python从sqlite读取并显示数据的方法
2015/05/08 Python
python实现合并两个数组的方法
2015/05/16 Python
在主机商的共享服务器上部署Django站点的方法
2015/07/22 Python
Python利用递归和walk()遍历目录文件的方法示例
2017/07/14 Python
python模块smtplib实现纯文本邮件发送功能
2018/05/22 Python
分享vim python缩进等一些配置
2018/07/02 Python
python去重,一个由dict组成的list的去重示例
2019/01/21 Python
python 工具 字符串转numpy浮点数组的实现
2020/03/14 Python
python3注册全局热键的实现
2020/03/22 Python
python 实现超级玛丽游戏
2020/11/25 Python
HTML5新增的标签和属性归纳总结
2018/05/02 HTML / CSS
HTML5添加鼠标悬浮音响效果不使用FLASH
2014/04/23 HTML / CSS
俄罗斯名牌服装网上商店:UNIQUE FABRIC
2019/07/25 全球购物
ManoMano英国:欧洲第一家专注于DIY和园艺市场的电商平台
2020/03/12 全球购物
bonprix荷兰网上商店:便宜的服装、鞋子和家居用品
2020/07/04 全球购物
俄罗斯第一家多品牌在线奢侈品精品店:Aizel.ru
2020/09/06 全球购物
电子商务专业学生职业生涯规划
2014/03/07 职场文书
我的中国梦演讲稿小学篇
2014/08/19 职场文书
高中生毕业评语
2014/12/30 职场文书
小学语文的各类谚语(70首)
2019/08/15 职场文书