超越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 工作原理
Mar 31 Servers
nginx配置文件使用环境变量的操作方法
Jun 02 Servers
Nginx禁止ip访问或非法域名访问
Apr 07 Servers
docker-compose部署Yapi的方法
Apr 08 Servers
阿里云日志过滤器配置日志服务
Apr 09 Servers
openstack云计算keystone组件工作介绍
Apr 20 Servers
Nginx 安装SSL证书完成HTTPS部署
Apr 28 Servers
解决IIS7下无法绑定https主机的问题
Apr 29 Servers
Linux下搭建SFTP服务器的命令详解
Jun 25 Servers
设置IIS Express并发数
Jul 07 Servers
Nginx文件已经存在全局反向代理问题排查记录
Jul 15 Servers
Apache Kafka 分区重分配的实现原理解析
Jul 15 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实现批量查询清除一句话后门的代码
2008/01/20 PHP
PHP下利用shell后台运行PHP脚本,并获取该脚本的Process ID的代码
2011/09/19 PHP
深入array multisort排序原理的详解
2013/06/18 PHP
php获取url参数方法总结
2014/11/13 PHP
用PHP代码给图片加水印
2015/07/01 PHP
PHP观察者模式实例分析【对比JS观察者模式】
2019/05/22 PHP
TP5框架实现的数据库备份功能示例
2020/04/05 PHP
别了 JavaScript中的isXX系列
2012/08/01 Javascript
html中的input标签的checked属性jquery判断代码
2012/09/19 Javascript
jquery移除、绑定、触发元素事件使用示例详解
2014/04/10 Javascript
JavaScript生成随机数的4种自定义函数分享
2015/02/28 Javascript
ztree获取选中节点时不能进入可视区域出现BUG如何解决
2015/12/03 Javascript
jQuery实现textarea自动增长宽高的方法
2015/12/18 Javascript
分享jQuery插件的学习笔记
2016/01/14 Javascript
javascript实现平滑无缝滚动
2020/08/09 Javascript
实现点击下箭头变上箭头来回切换的两种方法【推荐】
2016/12/14 Javascript
详解Jquery Easyui的验证扩展
2017/01/09 Javascript
JavaScript中Object基础内部方法图
2018/02/05 Javascript
详解在React里使用"Vuex"
2018/04/02 Javascript
详解基于mpvue的小程序markdown适配解决方案
2018/05/08 Javascript
vue上传图片到oss的方法示例(图片带有删除功能)
2018/09/27 Javascript
Postman的下载及安装教程详解
2018/10/16 Javascript
Vue中的情侣属性$dispatch和$broadcast详解
2019/03/07 Javascript
使用Vue-Awesome-Swiper实现旋转叠加轮播效果&平移轮播效果
2019/08/16 Javascript
Python中使用item()方法遍历字典的例子
2014/08/26 Python
Python实现简单的文本相似度分析操作详解
2018/06/16 Python
Python读写zip压缩文件的方法
2018/08/29 Python
python实现弹跳小球
2019/05/13 Python
Python命令行参数解析工具 docopt 安装和应用过程详解
2019/09/26 Python
基于Python获取照片的GPS位置信息
2020/01/20 Python
Python更换pip源方法过程解析
2020/05/19 Python
Python3自带工具2to3.py 转换 Python2.x 代码到Python3的操作
2021/03/03 Python
培训自我鉴定
2014/01/31 职场文书
投资意向书范本
2014/04/01 职场文书
学习型党组织建设经验材料
2014/05/26 职场文书
西游记读书笔记
2015/06/25 职场文书