华为云征文|基于Flexus云服务器X实例部署caddy的教程

🔴大家好,我是雄雄,欢迎关注微信公众号:雄雄的小课堂


写在前面

事情的起因是这样的:那天我发现了个自动部署ssl证书、自动续签的一个产品很感兴趣,就直接发了个朋友圈,没想到下面有个技术大佬给我评论了一个单词:caddy,当时我还有点懵逼,不知道 这是啥意思,仔细一想,肯定是与ssl有关系,于是就去搜了下caddy,发现了新大陆!!!

在这里插入图片描述

官方仓库地址: https://github.com/mholt/caddy,感兴趣的小伙伴们可以去看看。

今天我们就用手里的华为云Flexus X实例的云服务器来研究一下caddy为何物,好处是什么?

caddy简单介绍

Caddy是一个基于Go语言开发的Web服务器,与其他Web服务器相比,它更注重用户体验和易用性。Caddy的设计初衷是为了让人类更轻松地使用,而不是仅仅为Web而设计。这使得Caddy在配置和使用上变得非常简单。

Caddy具备一系列开箱即用的特性,包括全自动支持HTTP/2协议、通过Let’s Encrypt实现全自动HTTPS配置、充分利用多核处理器优势、完全支持IPv6环境、良好的WebSockets支持、Markdown自动转换为HTML、易于定义的日志格式以及无依赖的二进制文件部署。

此外,得益于Go语言的跨平台特性,Caddy可以轻松支持Windows、Linux和Mac三大主流操作系统。


从上面这段话中,我们可以得出:

  1. Caddy是个预计Go开发的web服务器
  2. 通过Let's Encrypt实现全自动HTTPS配置
  3. 跨平台支持
  4. 完全支持ipv6环境

其实不光上面的这些优势,还有其他更多的优势,比如相比nginx而言,更加简洁,配置更加简单,最主要的是可以直接自动申请+配置ssl证书

在华为云Flexus X实例中安装caddy

我的系统是debain 11,所以安装方式可能和其他的linux系统安装不一样,不过也都很简单。

  1. 首先,添加Caddy官方的APT仓库:
curl -1sLf 'https://dl.cloudsmith.io/public/caddy/stable/gpg.key' | sudo tee /etc/apt/trusted.gpg.d/caddy-stable.asc
curl -1sLf 'https://dl.cloudsmith.io/public/caddy/stable/debian.deb.txt' | sudo tee /etc/apt/sources.list.d/caddy-stable.list

在这里插入图片描述

  1. 更新APT包索引:
sudo apt update
  1. 安装Caddy
sudo apt install caddy

等待安装成功就行。

docker中安装caddy

docker中安装其实也比较简单,我这边安装了个宝塔面板,所以直接从面板里面直接安装就行。首先我们找到caddy这个镜像。然后点击后面的安装即可。

在这里插入图片描述
然后我们等待安装就行:

在这里插入图片描述
当我们执行完安装后,就将caddy镜像下载到我们docker容器中,我们可以输入命令来启动一个容器加载此镜像,也可以直接在页面上操作。

注意:如果我们我想让caddy默认用80端口的话,就需要将原来服务器中的nginx服务停止掉,或者卸载掉,不然会造成端口冲突的。

在这里插入图片描述

也可以直接使用下面的命令来启动容器:

docker run -d -p 80:80 -p 443:443 --name mycaddy caddy caddy file-server 

启动完容器后,显示如下:

在这里插入图片描述
这就证明caddy已经可以了,下面我们来看看如何使用。

配置Caddy

Caddy的配置文件通常称为Caddyfile。以下是如何为Caddy配置反向代理的步骤:

  1. 创建Caddyfile

在您的宿主机上创建一个Caddyfile,内容如下:

example.com {
    reverse_proxy localhost:3000
}

其中:example.com指的就是我们的域名,然后localhost:3000则是我们需要反向代理的地址,相当于我们输入example.com后,caddy会自动给我们转发到本机的localhost:3000这个服务上,是不是很简洁。

  1. 挂载Caddyfile到容器

启动Caddy容器时,将Caddyfile挂载到容器内部:

docker run -d --name caddy-server -p 80:80 -p 443:443 -v /home/Caddyfile:/etc/caddy/Caddyfile caddy

反向代理配置

下面我们来演示一个带有额外http请求头的配置反向代理:

example.com {
    reverse_proxy localhost:3000 {
        header_up Host {host}
        header_up X-Forwarded-For {remote}
        header_up X-Forwarded-Proto {scheme}
    }
}

这个配置会向代理请求中添加一些有用的HTTP头。

当Caddy容器启动并加载Caddyfile后,Caddy会自动尝试为指定的域名获取和续订SSL证书。这是通过Let’s Encrypt的ACME协议实现的,因此,您不需要手动干预SSL证书的管理。

是不是很简单!!!

至此,我们基于Flexus云服务器X实例部署caddy的配置就完成了,大家看看有问题的话可以在下方直接评论留言!!!

  • 18
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

穆雄雄

哎,貌似还没开张来着呢~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值