(原) Caddy Go开发 高性能 配置简单 HTTPS

原创文章,请后转载,并注明出处。

Caddy是什么?在Caddy的官网上给出一个最简单的介绍:“Caddy是一个能自动创建HTTPS功能的HTTP/2网站服务器”。简单的一句话,突出了两大卖点,“自动创建HTTPS”和“HTTP/2”。

caddy致力于成为一个易用的静态文件Web Server。Caddy的作者是来自美国的Matthew Holt,因为是用Go语言开发的,所以Caddy天生里就带着高并发的基因。据国内技术人士测试,其同时并发数优于Apache,略低于Nginx。“几乎所有的功能在Caddy里的都是插件”。

Git: https://github.com/caddyserver/caddy

官网:https://caddyserver.com/download

下载:https://github.com/caddyserver/caddy/releases

官网文档:https://caddyserver.com/docs/

配置文件:https://caddyserver.com/v1/tutorial/caddyfile

相关介绍网文:https://blog.csdn.net/weixin_34279184/article/details/93033005

关于https: https://caddyserver.com/docs/automatic-https

有网友翻译了一下:https://docs.getcaddy.cn/

网友的另一个v2中文文档

最新已经出v2测试版了,网上基本介绍的是v1。看起来v2麻烦了些,有点失去初衷的感觉。

配置起来十分简便,甚至可以 28 秒配置好一个支持 http2 的 server ,而且对各种 http 新特性都支持的比较早(比如 http2、quic都有支持)。

基本特性

  • 默认支持HTTP/2,使用 Let’s Encrypt 可以全自动变成全站HTTPS,无需任何配置(可配置自己CA证书);

  • 多核支持;

  • 完全支持IPv6;

  • 功能插件化,可以自己轻松开发插件;

  • 支持WebSockets;

  • 支持自动把md转成 HTML;

  • 简单的log日志配置;

  • 二进制部署,无依赖;

  • 反向代理,管理多个站点;


下载,解压 tar -xzf caddy.tar.gz caddy

运行即可打开http://localhost:2015,如果看到404错误,则需要根目录添加index文件(据说支持index.html,index.htm,default.html,default.htm)。

指定主机名: caddy -host example.com

指定配置文件:caddy -conf ./Caddyfile

配置文件内容

localhost:8080     //指定访问地址和域名
gzip               //数据压缩
log ../access.log  //日志

mysite.com {       //指定网站及配置
    root /www/mysite.com
    log ../mysite.log	
}


localhost:8080,https://site.com, http://ysite.com {  //多个网站配置相同

}

example.com/static,*.example.com { //通配符

}

localhost:{$PORT}     //配置文件中使用环境变量
root {%SITE_ROOT%}

foot.com:80{
	log ./foo.log
	gzip
}
bar.com:80{
	log ./bar.log
	gzip
	browse       //支持目录浏览
}

支持基本的反向代理功能,通过proxy middleware实现。

localhost:2015{
	log ./2015.log
	proxy /foo localhost:9001
	proxy /bar localhost:9002
}

负载均衡支持random(随机)、last_conn(最少连接)、round_robin(轮询)

localhost:2015{
	log ./2015.log
	proxy / localhost:9001 localhost:9003{
		policy round_robin
	}
	proxy /bar localhost:9002 localhost:9004 {
		policy least_conn
	}
}

对于最新的V2.0.0 - beta13版中,默认端口改为了2019,运行使用caddy run指令。

我简单的建立了一个Caddyfile

localhost:2021 {
   file_server
   root * /hugo/EaseBlog/public
}
localhost:2020 {
   redir http://i.scwy.net
}

将本地hugo建立的public目录开放到静态服务器上。

比较神奇的是这个

localhost:6060 {
   respond "Hello,world!"
}

浏览页面时,直接返回信息。

运行 caddy reload,它通过消息机制来重载配置文件。也可以通过 caddy stop 来停止服务运行。

运行 caddy file-server –browse ,若有index.html等文件则显示此文件,否则浏览目录及文件。

caddy file-server –listen :8080 指定端口

caddy file-server –root ~/mysite 指定根目录

caddy reverse-proxy –from 127.0.0.1:2016 –to localhost:8080 把2016端口的请求转给8080

然而在配置文件中写入却没有效果

localhost:9090 {
   reverse_proxy www.baidu.com:80
}

仿佛配置文件中改为域名,添加tls项为自己的邮箱,它即会自动帮你https

domain.com:443 {
  root /var/www/notadd/public
  index index.php
  tls you@163.com   # 自动申请证书,必须在外网,且80可访问
}

允许压缩在v2版本中改为encode gzip,注意root也改了 root * /wwww 这样。

据说直接支持markdown渲染为html,但在v2版本中不知道如何使用,有机会再研究。

相关文章