首页 > 系统相关 >超越 Nginx!号称下一代 Web 服务器,用起来够优雅!

超越 Nginx!号称下一代 Web 服务器,用起来够优雅!

时间:2022-10-09 16:34:12浏览次数:62  
标签:Web macrozheng caddy Caddy Caddyfile Nginx 使用 服务器 com


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

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

Caddy简介

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

超越 Nginx!号称下一代 Web 服务器,用起来够优雅!_web前端期末大作业

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 服务器,用起来够优雅!_web前端期末大作业_02

使用

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

基本使用

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

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

超越 Nginx!号称下一代 Web 服务器,用起来够优雅!_网页设计与制作_03

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

超越 Nginx!号称下一代 Web 服务器,用起来够优雅!_web前端期末大作业_04

  • 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 服务器,用起来够优雅!_网页设计与制作_05

  • 当然我们还可以使用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 服务器,用起来够优雅!_网页设计与制作_06

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

关键字

解释

使用

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 服务器,用起来够优雅!_web前端期末大作业_07

  • 修改​​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 服务器,用起来够优雅!_web课程与设计_08

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

超越 Nginx!号称下一代 Web 服务器,用起来够优雅!_html_09

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

超越 Nginx!号称下一代 Web 服务器,用起来够优雅!_html期末网页作业_10

动态代理

动态代理就是把代理服务器的请求转发到另一个服务上去,这里我们将把对​​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 服务器,用起来够优雅!_web课程与设计_11

文件压缩

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

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

超越 Nginx!号称下一代 Web 服务器,用起来够优雅!_web前端期末大作业_13

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

超越 Nginx!号称下一代 Web 服务器,用起来够优雅!_html_14

地址重写

有的时候我们的网站更换了域名,但还有用户在使用老的域名访问,这时可以通过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 服务器,用起来够优雅!_web课程与设计_15

总结

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

如果你想了解更多SpringBoot实战技巧的话,可以试试这个带全套教程的实战项目(50K+Star):github.com/macrozheng/…

参考资料

  • 项目地址:github.com/caddyserver…
  • 官方文档:caddyserver.com/


标签:Web,macrozheng,caddy,Caddy,Caddyfile,Nginx,使用,服务器,com
From: https://blog.51cto.com/u_15398742/5740702

相关文章

  • 实现web实时消息推送的方案-7种
    要实现一个站内信web消息推送的功能,对,就是下图这个小红点,一个很常用的功能。不过他还没想好用什么方式做,这里我帮他整理了一下几种方案,并简单做了实现。什么是消息推送......
  • docker 下nginx 实现文件下载
     1、新建目录存放文件 2、将目录挂载到容器,新增配置如下  3、nginx配置文件新增配置location~*(.*.apk){#代理后缀为apk的文件add_h......
  • webpack使用
    一、概述模块化和打包 Webpack是一个前端资源加载/打包工具。它将根据模块的依赖关系进行静态分析,然后将这些模块按照指定的规则生成对应的静态资源。从图中我们可以看......
  • node+express搭建服务器环境
    一、概述express是一个基于​​Node.js​​平台,快速、开放、极简的Web开发框架,网址​​Express-基于Node.js平台的web应用开发框架-Express中文文档|Express......
  • 【Web开发】Python实现Web服务器(Sanic)
    1、简介https://sanic.dev/zh/https://github.com/sanic-org/sanicSanic是Python3.7+Web服务器和Web框架,旨在提高性能。它允许使用Python3.5中添加的async/awa......
  • docker start a web container
    dockerstartawebcontainerStep1:SetupDefinetheapplicationdependencies.Createadirectoryfortheproject:mkdirwebcdwebCreateafilecalled......
  • 青少年CTF平台-Web-PingME
    题目描述题目难度一颗星,五十分。解题记录进入题目中,发现这是一个ping功能我们用连字符||进行分割两个语句,保证同时运行且输出。Payload为127.0.0.1||ls发现有f......
  • 搭建nginx下载服务器
    1,获取nginx的安装包​​ http://nginx.org/download/nginx-1.9.0.tar.gz​​2,解压tar xvf nginx-1.9.0.tar.gz3,配置nginx的安装目录./configure--prefix=/home/work/......
  • 青少年CTF平台-Web-POST&GET
    题目描述一星简单题,看我如何给你过了。启动环境,等待三十秒先喝口水。做题过程访问题目地址,说让我们用GET方式提交一个名称为get且值为0的变量。在URL后面加上?get=......
  • 青少年CTF平台-Web-Robots
    题目信息题目名称:Robots题目描述:昨天十三年社团讲课,讲了Robots.txt的作用,小刚上课没有认真听课正在着急,你能不能帮帮忙?题目难度:一颗星解题过程访问题目链接在这里......