超越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的zabbix 5.0安装部署的方法步骤
Jul 16 Servers
Nginx使用Lua模块实现WAF的原理解析
Sep 04 Servers
Nginx动静分离配置实现与说明
Apr 07 Servers
Nginx配置根据url参数重定向
Apr 11 Servers
Windows server 2012 R2 安装IIS服务器
Apr 29 Servers
Nginx限流和黑名单配置
May 20 Servers
阿里云服务器部署RabbitMQ集群的详细教程
Jun 01 Servers
Docker与K8s关系介绍不会Docker也可以使用K8s
Jun 25 Servers
云服务器部署 Web 项目的实现步骤
Jun 28 Servers
Nginx如何限制IP访问只允许特定域名访问
Jul 23 Servers
Linux中一对多配置日志服务器的详细步骤
Jul 23 Servers
Shell中的单中括号和双中括号的用法详解
Dec 24 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
网站加速 PHP 缓冲的免费实现方法
2006/10/09 PHP
php5 non-thread-safe和thread-safe这两个版本的区别分析
2010/03/13 PHP
PHP入门教程之面向对象的特性分析(继承,多态,接口,抽象类,抽象方法等)
2016/09/11 PHP
PHP的中使用非缓冲模式查询数据库的方法
2017/02/05 PHP
基于jQuery的图片左右无缝滚动插件
2012/05/23 Javascript
JavaScript1.6数组新特性介绍以及JQuery的几个工具方法
2013/12/06 Javascript
button没写type=button会导致点击时提交
2014/03/06 Javascript
JS判断字符串长度的5个方法(区分中文和英文)
2014/03/18 Javascript
三种动态加载js的jquery实例代码另附去除js方法
2014/04/30 Javascript
Angularjs制作简单的路由功能demo
2015/04/14 Javascript
JS如何判断json是否为空
2016/07/06 Javascript
bootstrap select插件封装成Vue2.0组件
2017/04/17 Javascript
JavaScript数据结构之双向链表和双向循环链表的实现
2017/11/28 Javascript
vue二级路由设置方法
2018/02/09 Javascript
vue组件实现进度条效果
2018/06/06 Javascript
vue实现未登录跳转到登录页面的方法
2018/07/17 Javascript
详解vantUI框架在vue项目中的应用踩坑
2018/12/06 Javascript
angular学习之动态创建表单的方法
2018/12/07 Javascript
JavaScript 面向对象基础简单示例
2019/10/02 Javascript
基于element-ui封装表单金额输入框的方法示例
2021/01/06 Javascript
python实现端口转发器的方法
2015/03/13 Python
Python实现批量检测HTTP服务的状态
2016/10/27 Python
python使用邻接矩阵构造图代码示例
2017/11/10 Python
PageFactory设计模式基于python实现
2020/04/14 Python
pycharm 实现调试窗口恢复
2021/02/05 Python
美国知名保健品网站:LuckyVitamin(支持中文)
2017/08/09 全球购物
Linux如何命名文件--使用文件名时应注意
2014/05/29 面试题
数据库测试通常都包括哪些方面
2015/11/30 面试题
《鞋匠的儿子》教学反思
2014/03/02 职场文书
承诺书的格式范文
2014/03/28 职场文书
乡镇交通安全实施方案
2014/03/29 职场文书
捐款活动总结
2014/08/27 职场文书
2016年清明节网上祭英烈活动总结
2016/04/01 职场文书
HTML+css盒子模型案例(圆,半圆等)“border-radius” 简单易上手
2021/05/10 HTML / CSS
JavaScript严格模式不支持八进制的问题讲解
2021/11/07 Javascript
排查MySQL生产环境索引没有效果
2022/04/11 MySQL