超越 Nginx,号称下一代 Web 服务器,用起来够优雅~
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语言编写,可用于静态资源托管和反向代理。
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已被注册为系统服务,但是还没开启。
使用
下面我们体验下Caddy的基本使用,对于Web服务器来说都是常用的操作,你准能用的上!
基本使用
首先我们来个Caddy的入门使用,让Caddy运行在
2015
端口上并返回Hello, world!
。
- 直接使用
caddy
命令将输出Caddy的常用命令,基本看介绍就知道如何使用了,标出来的是常用命令;
- 使用
caddy start
命令可以让Caddy服务在后台运行;
- Caddy默认使用JSON格式的配置文件,但由于JOSN格式配置书写比较麻烦,又提供了
Caddyfile
这种更加简洁的配置形式,使用如下命令能自动把Caddyfile
转化为JSON配置;
caddy adapter
- 我们可以先创建一个名称为
Caddyfile
的文件,文件内容如下,然后使用caddy adapter
将它转换为JSON配置,再使用caddy reload
使配置生效,该配置将监听2015
端口,并返回Hello, world!
;
:2015respond "Hello, world!"
- 然后我们使用curl命令访问
localhost:2015
,将返回指定的信息;
- 当然我们还可以使用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
的具体语法规则如下。
- 介绍下上图中的关键字,有助于理解。
关键字 | 解释 | 使用 |
---|---|---|
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目录中去,并进行解压操作:
- 修改
Caddyfile
文件,使用如下配置,修改完成后使用caddy reload
命令刷新配置;
http://docs.macrozheng.com {root * /mydata/caddy/html/docsfile_server browse
}http://mall.macrozheng.com {root * /mydata/caddy/html/mallfile_server browse
}
- 如果你的
Caddyfile
文件格式不太合格的话,会出现如下警告,直接使用caddy fmt --overwrite
格式化并重写配置即可解决;
- 通过
docs.macrozheng.com
即可访问部署好的文档项目了:
- 通过
mall.macrozheng.com
即可访问到部署好的前端项目了。
动态代理
动态代理就是把代理服务器的请求转发到另一个服务上去,这里我们将把对
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文档页面了。
文件压缩
如果我们的服务器带宽比较低,网站访问速度会很慢,这时我们可以通过让Caddy开启Gzip压缩来提高网站的访问速度。这里我们以mall的前端项目为例来演示下它的提速效果。
- 我们需要修改
Caddyfile
文件,使用encode
指令开启Gzip压缩,修改完成后使用caddy reload
命令刷新配置;
http://mall.macrozheng.com {root * /mydata/caddy/html/mallencode {gzip}file_server browse
}
- 有个比较大的JS文件压缩前是
1.7M
;
- 压缩后为
544K
,访问速度也有很大提示;
- 另外我们可以看下响应信息,如果有
Content-Encoding: gzip
这个响应头表明Gzip压缩已经启用了。
地址重写
有的时候我们的网站更换了域名,但还有用户在使用老的域名访问,这时可以通过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 /adminfile_server {root /mydata/caddy/html/admin}}route /app/* {uri strip_prefix /appfile_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/docsfile_server browse
}
- 然后使用
caddy run
命令启动Caddy服务器即可,是不是非常方便!
caddy run
Docker支持
当然Caddy也是支持使用Docker进行安装使用的,其使用和直接在CentOS上安装基本一致。
- 首先使用如下命令下载Caddy的Docker镜像;
docker pull caddy
- 然后在
/mydata/caddy/
目录下创建Caddyfile
配置文件,文件内容如下;
http://192.168.3.105:80respond "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上安装一样了。
总结
今天体验了一把Caddy,其强大的指令功能,让我们无需多余的配置即可实现各种功能,使用起来确实非常优雅!尤其是其能自动配置实现HTTPS,非常不错!Nginx能实现的功能Caddy基本都能实现,大家可以对比下之前写的Nginx使用教程 ,你就会发现使用Caddy来实现有多么优雅!
参考资料
- 项目地址:https://github.com/caddyserver/caddy
- 官方文档:https://caddyserver.com/
超越 Nginx,号称下一代 Web 服务器,用起来够优雅~相关推荐
- 超越 Nginx!号称下一代 Web 服务器,用起来够优雅!
Nginx是一款非常流行的Web服务器,在Github上已有16K+Star,我们经常用它来做静态资源托管或反向代理.最近发现了一款全新的Web服务器Caddy,Star数超越Nginx,标星38K+ ...
- Nginx+Keepalived实现Web服务器负载均衡
说明: 操作系统:CentOS 5.X 64位 Web服务器:192.168.21.127.192.168.21.128 站点:bbs.osyunwei.com和sns.osyunwei.com部署在 ...
- Nginx搭建部署Web服务器并与NFS结合搭建负载均衡服务器
Nginx搭建部署Web服务器并与NFS结合搭建负载均衡服务器 一.搭建NginxWeb服务器 此种方式是用yum安装Nginx,为保证安装成功需在安装之前提前安装epel扩展源. 用 ...
- Nginx+Tomcat构筑Web服务器集群
代理服务 代理服务可简单的分为正向代理和反向代理: 正向代理: 用于代理内部网络对Internet的连接请求(如VPN/NAT),客户端指定代理服务器,并将本来要直接发送给目标Web服务器的HTTP请 ...
- 比 Nginx 性能更强的下一代 Web 服务器
点击上方"芋道源码",选择"设为星标" 管她前浪,还是后浪? 能浪的浪,才是好浪! 每天 10:33 更新文章,每天掉亿点点头发... 源码精品专栏 原创 | ...
- 伪装nginx版本防止***web服务器
为了防止被***扫描到web服务器信息,通过相对应的web服务器信息找出对应的版本漏洞,从而对web服务器进行***,nginx虽然功能强大,但是也是软件,软件就可能会有漏洞,例如nginx-0.6. ...
- 电商网站搭建——什么是Nginx?常见web服务器有哪些?
一.什么是Nginx Nginx(engine x)是一个高性能的HTTP(请求-响应协议)和反向代理web服务器,同时也提供IMAP/POP3/SMTP服务. --引用自百度百科 1.主要功能是反 ...
- web 服务器-Nginx
文章目录 一.讲在 Nginx 之前 1.1 同步与异步 1.2 阻塞与非阻塞 1.3 epoll 模型(I/O 多路复用) 二.Nginx 详解 2.1 概述 2.2 工作模式 2.2.1 mast ...
- 轻松使用Nginx搭建web服务器
如果读者以前做过web开发的话,就应该知道如何去搭建一个web服务器来跑你的web站点,在windows下你可能会选择去用IIS,十分的快捷,在linux下,你可能首先会想到apache," ...
最新文章
- python之simplejson,Python版的简单、 快速、 可扩展 JSON 编码器/解码器
- wxWidgets:wxColour类用法
- IronRuby 0.0.1.0
- ios15之取消UITabbleViewCell的高亮效果
- dart --- 简单的闭包
- python数据处理常用函数_Python常用数据处理函数
- 小白学HarmonyOS,HarmonyOS 2.0正式发布 分布式能力获得全面升级
- [原创] IAR7.10安装注册教程
- 酷q服务器未响应,酷Q怎么了,停运后,其他机器框架,该怎么版
- 永洪bi_永洪BI_咨询服务_数据服务_云市场-华为云
- Win10 安装rational rose 7教程
- 怎么在mysql中编辑数据库_navicat怎么修改数据库名
- vue结合elementUI实现tag多标签页
- MacBook更换开机登录界面壁纸
- Postman+Newman+Git+Jenkins+Slack 接口自动化和监控
- 【bzoj 3680】吊打XXX
- 计算机组成原理知识架构
- 为什么你看书记不住,记住不会用?-我的技术学习方法论
- [js] 得到本月、上月、下月的起始、结束日期; 得到今年、去年、明年的开始、结束日期 day.js
- OpenCV C++案例实战十九《制作电子相册查看器》
热门文章
- 云安全初识之云计算篇
- Transformer:注意力机制(attention)和自注意力机制(self-attention)的学习总结
- Bugku Crypto 小山丘的秘密
- 统计教程|常用统计图——箱式图的绘制
- 不要再使用MD5和SHA1加密密码了!
- python正则\\\d、\\\\d、r'\\d'的理解
- 李泰山出品-java版CMS内容管理系统
- 帝国CMS调用图集第一张图片的方法
- 西电计算机学院王宇平,王宇平 | 个人信息 | 西安电子科技大学个人主页
- 为什么被人能月薪 20k 以上,而你一个月拿着 6K 的低保?差别就在这!