当前位置: 首页 > news >正文

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

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


先看这里

    • 写在前面
    • caddy简单介绍
    • 在华为云Flexus X实例中安装caddy
    • docker中安装caddy
    • 配置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的配置就完成了,大家看看有问题的话可以在下方直接评论留言!!!


http://www.mrgr.cn/news/16431.html

相关文章:

  • 【多线程】设计模式之单例模式
  • sicp每日一题[1.38]
  • 【CSP:202104-2】邻域均值(Java)
  • 【Python系列】SQLAlchemy 基本介绍
  • SPR系列单点激光雷达测距传感器|模组之CAN-OPEN软件调试说明
  • ​字​节​一​面​
  • Vue.js入门系列(十九):深入理解和应用组件自定义事件
  • [ABC133A] T or T
  • 23. 如何使用Collections.synchronizedList()方法来创建线程安全的集合?有哪些注意事项?
  • 设计模式之外观模式
  • 今日(2024年8月30日)科技新闻(本周)
  • 【Rust】——高级类型
  • win10多个wifi快速切换脚本
  • 15年让爱轮回
  • 黑神话悟空-提高画质、防卡顿、修复等各种功能、各种CT表、各种存档、武器包、人物、装备替换等185+MOD合集
  • “添加”业务功能开发
  • 通过python 操作mysql 脚本
  • “品牌VS套路:华为、格行、中兴随身WiFi谁才是真良心?“
  • VMware中CentOS虚拟机配置网络(Net模式)
  • git commit添加emoji表情