Osheep

时光不回头,当下最重要。

像iPhone一样好玩的Web服务器: Caddy

据Netcraft今年5月份放出了一篇统计文章中,ApacheNginx和微软的IIS分别以45.61%20.22%7.83%市场占有率依然排在“活跃网站所使用Web服务器市场份额”的前三甲。

《像iPhone一样好玩的Web服务器: Caddy》

但是在走势图中,我们俨然也感觉到其他Web服务器正在悄悄集结,通过自己不断的创新和优化来威胁着霸主们的地位。这其中,一个已经刚满2岁的家族小成员非常起眼,他就是有着“云计算时代的C语言”之称的Go语言所编写的Caddy

《像iPhone一样好玩的Web服务器: Caddy》

Caddy是什么?在Caddy的官网上给出一个最简单的介绍:“Caddy是一个能自动创建HTTPS功能的HTTP/2网站服务器”。简单的一句话,突出了两大卖点,“自动创建HTTPS”和“HTTP/2”。申请过HTTPS数字证书的人应该都知道,要部署一个HTTPS站点,需要走多少流程和提交多少资料,而且数字证书的年费价格不菲(屌丝想法),但是我要告诉你,这些,对于Caddy来说,都是自动操作的,而且重点是,上面这句话里没有体现出来,就是数字证书是免费的!免费的!免费的!重要的事情说三遍,具体怎么个实现,在下面介绍特性时会详细讲解给大家。

Caddy的作者是来自美国的Matthew Holt,因为是用Go语言开发的,所以Caddy天生里就带着高并发的基因。据国内技术人士测试,其同时并发数优于Apache,略低于Nginx。“几乎所有的功能在Caddy里的都是插件”,这是Matthew Holt对他的孩子的另一种诠释,“HTTP服务器是插件,高级的TLS特性也是插件,每一行命令实现的功能都是一个插件”。自始至终,Caddy就是一个内心强大,勇于挑战新事物的探险家,这完全得益于他的作者对互联网产品的深刻认知与理解。

一、运行

1.1 默认运行

废话不多说,我们先看看Caddy是怎样运行的。命令行里输入:

caddy

就是这么简单,在没有任何配置信息的情况下,Caddy会为你默认打开2015端口,呈现出一个404不存在的页面。

1.2 Caddyfile配置运行

如果需要配置更多信息,而也只需要一个Caddyfile配置文件。配置文件格式如下:

stozen.net   # Your site’s address

ext .html   # Clean URLs

errors error.log {       # Error log

404 error-404.html   # Custom error page

}

# PHP backend

fastcgi /blog localhost:9000 php

# API load balancer

proxy /api localhost:5001 localhost:5002

配置说明:

– stozen.net:网站绑定的域名

– ext:文件扩展名隐藏功能。此处如果访问/user地址,实质访问的是/user.html

– errors:记录错误日志的地址,并配置不同错误状态返回到客户端的错误页面

– fastcgi:支持fastcgi代理方式访问PHP站点

– proxy:支持反向代理和负载均衡

Caddyfile所在路径里执行caddy命令,站点便轻松运行。是不是比Apache和Nginx配置方便多了?

1.3 更快速的运行

在我们测试阶段,可以直接使用命令行参数的方式运行,无需`Caddyfile`,直接绑定域名。

caddy -host stozen.net

够简单吧?如果你觉得还不够,我再举些Caddy的特性功能。

二、特性

2.1 通用功能

Caddy通过Caddyfile来配置你的站点,简单直观,刚才我们已经见识到了。默认情况下,Caddy支持纯静态站点,当然,你如果使用了它自带的模板插件,反向代理功能或FastCgi等其他插件,还可是运行动态网站。Caddy有自己的命令行(Command Cli),可以快速配置站点运行。Caddy支持多核处理,Go语言里的goroutine技术让Caddy能处理更多的并发请求。在Caddy启动和关闭的时候,你还可以设置相应的系统命令去运行,这对于系统运维工程师来说绝对是非常友好的。Caddy的日志功能也相当强大,可以自定义日志格式,可以将日志输出到文件、stdout/stderr里,或者本地和远程的系统日志里。更方便的是,当Caddy的日志文件非常大时,Caddy会自动分割日志文件并移动它,这对于合理分配磁盘资源非常有用。最特别的就是Caddy完全依赖于插件,所有的服务器类型、指令、DNS providers都是插件,插件可以通过Go语言方便实现

2.2 部署特性

Caddy就是一个单独二进制文件,没有任何依赖,甚至连libc都不需要。天生的跨平台支持,支持各大Linux、windows发行版本,甚至连Android也能稳定运行。当然,你也可以在Docker镜像里安装Caddy,让站点开发更DevOps化。

2.3 安全特性

支持TLS传输协议,考虑客户端览器兼容性的情况下,让用户的信息传输更安全。采用了TLS的扩展技术SNI,解决了一个服务器使用多个域名和证书的问题。对于网络切换后的用户Session认证更加智能,使用了TLS session ticket的方式,当用户网络或服务器后台地址变化的情况下,连接请求依然有效。

Caddy能够自动获取Let’s Encrypt的证书,此证书是免费获取的,但是有效期只有一个月。Caddy能自动对证书进行续订,达到了证书永久有效的效果。官方自豪的说,Caddy是第一个实现此技术的Web服务器。

2.4 HTTP服务器特性

支持网站文件目录浏览功能,支持Gzip文件压缩功能,支持网站响应超时功能,支持单服务器下多虚拟站点功能。对Markdown静态文件天然支持,能将Markdown页面自动转换成HTML页面返回给浏览器。后端支持模板技术,动态生成网站内容。Caddy支持HTTP/2服务端推送技术,支持HTTP网站基础认证功能,重定向功能,修改Header头部信息功能。像Nginx一样,Caddy也支持反向代理和负载均衡技术,对Websocket的代理技术,也一样支持很好。其他的,包含隐藏路由扩展名,路径重写,自定义MIME类型等,都是非常好用的一些特性。

三、iPhone vs Caddy

《像iPhone一样好玩的Web服务器: Caddy》

像乔布斯创造的iPhone一样,Caddy属于外表设计时尚简单,用户操作简单,但是内部功能十分强大的产品。插件功能类似iPhone里的一个个应用,能给用户带来不同的体验和便捷。一句话,简约而不简单,值得用户研究并应用在自己的站点中。

说到最后,文章中只是简单的阐述了Caddy的一些特性功能,如果你想更多的了解它并应用在站点中,可以研究下Caddy的官网源码(https://github.com/caddyserver/website),官网使用了Caddy+Hugo等技术搭建,欢迎你也加入使用Caddy的队列!

点赞