开箱即用的Web服务器


声明:文章部分内容转自 HelloGitHub 微信公众号!

众所周知,Web 服务器是 Web 开发中不可或缺的基础服务,在开发中经常会用到。耳熟能详的开源 Web 服务器有久负盛名的 Apache、性能强劲的 Nginx。而我们今天要介绍的开源项目是采用 Go 编写的 Web 服务端“后起之秀”:Caddy  它拥有下载无需安装就能用、零配置实现 HTTPS 等特点,从而在强者如云的 Web 服务器中占据了一席之地。

开箱即用的Web服务器

在这个 HTTPS 必选的时代,Caddy 凭借无需额外配置自动 HTTPS,分分钟完成 HTTPS 站点搭建,使它成为了中小型 Web 服务的首选服务器。Caddy 深受开源爱好者们的喜爱,2014 年开源至今共收获了 4.2 万颗星。

开箱即用的Web服务器


1. Caddy 功能介绍

Caddy 是一个强大的、可扩展的平台,可以为您的站点、服务和应用程序提供服务。

使用 Caddy 可以在 LinuxMacWindows 上快速部署 http(s) 站点或反向代理服务。支持:

  • HTTP/1.1HTTP/2
  • 同时接受 HTTPS 自动签发和手动管理
  • 虚拟主机 (多个站点工作在单个端口上)
  • 原生 IPv4IPv6 支持
  • 静态文件分发
  • 平滑重启/重载
  • 反向代理 (HTTPWebSocket)
  • 负载均衡和健康性检查
  • Markdown 渲染
  • 文件浏览服务
  • 等等

与传统的 Nginx 或者 Apache 相比,Caddy 整体只有一个可执行文件,安装便捷不易出现奇怪的依赖问题,配置文件结构清晰语法简单易于上手,依托于模块化架构可以使用 Go 语言快速开发扩展模块。

  • Easy configuration with the Caddyfile
  • Powerful configuration with its native JSON config
  • Dynamic configuration with the JSON API
  • Config adapters if you don’t like JSON
  • Automatic HTTPS by default
    • ZeroSSL and Let’s Encrypt for public names
    • Fully-managed local CA for internal names & IPs
    • Can coordinate with other Caddy instances in a cluster
    • Multi-issuer fallback
  • Stays up when other servers go down due to TLS/OCSP/certificate-related issues
  • Production-ready after serving trillions of requests and managing millions of TLS certificates
  • Scales to tens of thousands of sites … and probably more
  • HTTP/1.1, HTTP/2, and experimental HTTP/3 support
  • Highly extensible modular architecture lets Caddy do anything without bloat
  • Runs anywhere with no external dependencies (not even libc)
  • Written in Go, a language with higher memory safety guarantees than other servers
  • Actually fun to use
  • So, so much more to discover

2. Caddy 工具安装

使用的是 Ubuntu 的机器,介绍自动安装和手动安装!

开箱即用的Web服务器

  • 镜像部署
# https://hub.docker.com/_/caddy
$ docker pull caddy
  • 自动安装
# Debian, Ubuntu, Raspbian
$ sudo apt install -y debian-keyring debian-archive-keyring apt-transport-https
$ curl -1sLf 'https://dl.cloudsmith.io/public/caddy/stable/gpg.key' | sudo gpg --dearmor -o $ /usr/share/keyrings/caddy-stable-archive-keyring.gpg
$ curl -1sLf 'https://dl.cloudsmith.io/public/caddy/stable/debian.deb.txt' | sudo tee /etc/apt/sources.list.d/caddy-stable.list
$ sudo apt update
$ sudo apt install caddy

# Fedora, RedHat, CentOS
$ dnf install 'dnf-command(copr)'
$ dnf copr enable @caddy/caddy
$ dnf install caddy
  • 手动编译
# Go 1.17 or newer
$ git clone "https://github.com/caddyserver/caddy.git"
$ cd caddy/cmd/caddy/
$ go build
  • 手动下载
# https://caddyserver.com/download
$ mv caddy_linux_amd64 caddy
$ sudo chmod a+x caddy
$ mv caddy /bin/caddy
$ caddy version

通过命令行 apt 工具安装的 caddy 会自己生成部分配置文件,这种方式安装完成后会启动服务,开机自动启动。

  • 配置文件
# 服务自启动配置
/lib/systemd/system/caddy.service.

# 配置文件内容
$ cat /lib/systemd/system/caddy.service
[Service]
ExecStart=/usr/bin/caddy run --environ --config /etc/caddy/Caddyfile
ExecReload=/usr/bin/caddy reload --config /etc/caddy/Caddyfile --force

# 服务启动的主配置文件
$ cat /etc/caddy/Caddyfile
:80 {
        # Set this path to your site's directory.
        root * /usr/share/caddy

        # Enable the static file server.
        file_server

        # Another common task is to set up a reverse proxy:
        # reverse_proxy localhost:8080
}
  • 二进制文件
# caddy
/usr/bin/caddy

3. Caddy 简单上手

安装完成之后,简单介绍下基本的使用方式!

这里将从 Caddy 常用命令开始,再到配置讲解,最后会通过一个实际案例来展示如何用 Caddy 配置网站和上线。

  • 常用命令
$ caddy
Caddy is an extensible server platform.

usage:
  caddy <command> [<args...>]

commands:
  adapt           指定配置文件 Adapts a config to Caddy native JSON
  add-package     添加扩展 Adds Caddy packages (EXPERIMENTAL)
  build-info      输出build信息 Prints information about this build
  environ         展示环境Prints the environment
  file-server     启动文件服务 Spins up a production-ready file server
  fmt             格式配置文件 Formats a Caddyfile
  hash-password   生成Hash密码 Hashes a password and writes base64
  help            帮助 Shows help for a Caddy subcommand
  list-modules    列出已安装模块 Lists the installed Caddy modules
  reload          重载配置并重启 Changes the config of running Caddy instance
  remove-package  删除扩展 Removes Caddy packages (EXPERIMENTAL)
  reverse-proxy   启动反向代理 A quick and production-ready reverse proxy
  run             启动服务(前台) Starts the Caddy process
  start           启动服务(后台) Starts the Caddy process
  stop            停止服务 Gracefully stops a started Caddy process
  trust           添加信任 Installs a CA cert into local trust stores
  untrust         删除信任 Untrusts a locally-trusted CA certificate
  upgrade         升级版本 Upgrade Caddy (EXPERIMENTAL)
  validate        校验配置是否合法 Tests whether a config file is valid
  version         输出版本信息 Prints the version

Use 'caddy help <command>' for more information about a command.

Full documentation is available at:
https://caddyserver.com/docs/command-line

Caddy 的原生配置文件使用的是 JSON 格式,但是为了用户编写方便它提供了 Caddyfile 作为接口让用户可以快速配置站点信息,运行时 Caddy 会自动将 Caddyfile 的配置信息转为 JSON 配置文件。Caddyfile 所能提供功能不如 JSON 配置文件强大,但是对于不需要复杂配置的用户而言完全够用了。

  • 配置文件
# matcher代表匹配器
# 如果提供则该指令将只对 matcher 描述的资源进行响应
directive [<matcher>] <args...> {
    subdirective [<args...>] # 子指令
}
  • 文件结构

开箱即用的Web服务器


4. Caddy 简单演示

简单演示,来解释配置文件的编写以及命令工具的使用!

下面将演示如何用 Caddy 搭建站点,加深理解配置格式和命令使用。

# 目录结构
.
├──&nbsp;Caddyfile
├──&nbsp;index.html
└──&nbsp;public
&nbsp;&nbsp;&nbsp;&nbsp;└──&nbsp;HG.html
<!--&nbsp;index.html&nbsp;-->
<!DOCTYPE html>
<html lang="en">
  <head>
    &nbsp;&nbsp;&nbsp;&nbsp;
    <meta charset="UTF-8" />
    &nbsp;&nbsp;&nbsp;&nbsp;
    <title>Hello&nbsp;World!</title>
  </head>
  <body>
    &nbsp;&nbsp;&nbsp;&nbsp;你好,世界!
  </body>
</html>

<!--&nbsp;HG.html&nbsp;-->
<!DOCTYPE html>
<html lang="en">
  <head>
    &nbsp;&nbsp;&nbsp;&nbsp;
    <meta charset="UTF-8" />
    &nbsp;&nbsp;&nbsp;&nbsp;
    <title>HelloGitHub</title>
  </head>
  <body>
    &nbsp;&nbsp;&nbsp;&nbsp;HelloGitHub
  </body>
</html>
# Caddyfile

http://localhost:3000 {
    basicauth /public/* {
        # 匹配localhost:3000/public/*的请求为加上登陆保护
        # 用户名HG密码HelloGitHub
        # 密码使用 caddy hash-passowrd 指令生成
        HG JDJhJDE0JGxxxBNGJt
    }

    # 设置当前站点根目录为当前文件夹,*表示匹配所有的请求
    root * ./
    templates

    # 配置当前站点为静态文件服务器,可用于博客系统的搭建
    file_server {
        # 隐藏所有的 .git 文件
        hide .git
    }
}

:4000 {
    # 配置反向代理(匹配请求转发到)
    reverse_proxy /public/* http://localhost:3000
}
# 启动服务
$&nbsp;caddy&nbsp;run

# 测试
http://localhost:3000
http://localhost:3000/public/HG.html
http://localhost:4000

Caddy 除了简单易懂的配置文件方式,还提供了管理配置的接口。通过这些接口可以轻松实现 Web 服务器管理自动化、集成发布等高级功能。

  • POST /load  设置或替换活动配置
  • POST /stop  停止活动配置并退出进程
  • GET /config/[path]  导出指定路径的配置
  • POST /config/[path]  设置或替换对象;追加到数组
  • PUT /config/[path]  创建新对象或插入数组
  • PATCH /config/[path]  替换现有对象或数组元素
  • DELETE /config/[path]  删除指定路径的值
  • JSON 中使用 @id  轻松遍历配置结构
  • GET /reverse_proxy/upstreams  返回配置的代理上游的当前状态

开箱即用的Web服务器


5. Caddy 域名加密

从零完成 HTTPS 站点

第一步:安装,采用上面介绍的命令安装

第二步:设置域名解析地址,在购买域名的网站设置,设置 A 记录。

# 设置完生效需要几分钟,可通过下面的命令检查是否生效
$ curl&nbsp;"https://cloudflare-dns.com/dns-query?name=caddy.escapelife.site&type=A"&nbsp;-H&nbsp;"accept:&nbsp;application/dns-json"

第三步:创建配置文件 Caddyfile,无需额外的开启 HTTPS 的设置。

# 域名和访问返回的内容
caddy.escapelife.site

respond&nbsp;"Hello HTTPS!"

第四步:启动然后看效果

# 在同一目录下执行命令
# 访问&nbsp;caddy.escapelife.site&nbsp;检验效果
$ sudo caddy run

6. Caddy 容器使用

介绍容器使用 Caddy 服务的相关配置和注意事项

  • 配置信息
# Data directory(/data)
$HOME/.local/share/caddy

# Config directory(/config)
$HOME/.config/caddy
  • Basic Usage
# The default config file simply serves files
$ echo "hello world" > index.html
$ docker run -d -p 80:80 \
    -v $PWD/index.html:/usr/share/caddy/index.html \
    -v caddy_data:/data \
    caddy
...
$ curl http://localhost/
hello world
# To override the default&nbsp;Caddyfile
$ docker run -d -p 80:80 \
    -v $PWD/Caddyfile:/etc/caddy/Caddyfile \
    -v caddy_data:/data \
    caddy
  • Automatic TLS
# its A/AAAA DNS records to public IP
$ docker run -d -p 80:80 -p 443:443 -p 443:443/udp \
    -v /site:/srv \
    -v caddy_data:/data \
    -v caddy_config:/config \
    caddy caddy file-server --domain example.com
  • Building your own Caddy-based image
FROM caddy:

COPY Caddyfile /etc/caddy/Caddyfile
COPY site /srv
  • Adding custom Caddy modules
FROM caddy:-builder AS builder

RUN xcaddy build \
    --with github.com/caddyserver/nginx-adapter \
    --with github.com/hairyhenderson/[email protected]

FROM caddy:

COPY --from=builder /usr/bin/caddy /usr/bin/caddy
  • Docker Compose example
version: "3.7"

services:
  caddy:
    image: caddy:<version>
    restart: unless-stopped
    ports:
      - "80:80"
      - "443:443"
      - "443:443/udp"
    volumes:
      - $PWD/Caddyfile:/etc/caddy/Caddyfile
      - $PWD/site:/srv
      - caddy_data:/data
      - caddy_config:/config

volumes:
  caddy_data:
    external: true
  caddy_config:

7. Caddy 思考总结

送人玫瑰,手有余香!

看到这里你应该对 Caddy 有了一些了解,有没有一种相见恨晚的感觉?虽然它的性能比不了 Nginx 但如果论上手的难易度,CaddyNginx 几条街!主要是默认开启 HTTPS 功能太香了,你什么都不用管就可以免费、快速、轻松开启网站 HTTPS


文章作者: Escape
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 Escape !
  目录