白嫖Cloudflare Workers 搭建 Docker Hub镜像加速服务|

embedded/2024/9/24 11:02:38/

简介

基于Cloudflare Workers 搭建 Docker Hub镜像加速服务。

  1. 首先要注册一个Cloudflare账号。

  2. Cloudflare账号下域名的一级域名,推荐万网注册个top域名,再转移到Cloudflare,很便宜的。

  3. 注意 Worker 每天每免费账号有次数限制,为10万次。每分钟为1000次。

步骤

登录到CF的仪表盘 https://dash.cloudflare.com/

点击 workers-and-pages > 创建应用程序 > 创建 Worker > 点击保存 >点击完成 > 编辑代码

编辑代码

编辑 worker.js 文件

编辑覆盖后,ctrl + s 即可保存。

import HTML from './docker.html';
export default {async fetch(request) {const url = new URL(request.url);const path = url.pathname;const originalHost = request.headers.get("host");const registryHost = "registry-1.docker.io";if (path.startsWith("/v2/")) {const headers = new Headers(request.headers);headers.set("host", registryHost);const registryUrl = `https://${registryHost}${path}`;const registryRequest = new Request(registryUrl, {method: request.method,headers: headers,body: request.body,// redirect: "manual",redirect: "follow",});const registryResponse = await fetch(registryRequest);console.log(registryResponse.status);const responseHeaders = new Headers(registryResponse.headers);responseHeaders.set("access-control-allow-origin", originalHost);responseHeaders.set("access-control-allow-headers", "Authorization");return new Response(registryResponse.body, {status: registryResponse.status,statusText: registryResponse.statusText,headers: responseHeaders,});} else {return new Response(HTML.replace(/{{host}}/g, originalHost), {status: 200,headers: {"content-type": "text/html"}});}}
}

编辑 docker.html 文件

点击新建文件,创建此文件。ctrl + s 即可保存。

<!DOCTYPE html>
<html lang="zh-CN">
<head><meta charset="utf-8"><meta name="viewport" content="width=device-width, initial-scale=1"><title>镜像使用说明</title><style>body {font-family: 'Roboto', sans-serif;margin: 0;padding: 0;background-color: #f4f4f4;}.header {background: linear-gradient(135deg, #667eea, #764ba2);color: #fff;padding: 20px 0;text-align: center;box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);}.container {max-width: 800px;margin: 40px auto;padding: 20px;background-color: #fff;box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);border-radius: 10px;}.content {margin-bottom: 20px;}.footer {text-align: center;padding: 20px 0;background-color: #333;color: #fff;}pre {background-color: #272822;color: #f8f8f2;padding: 15px;border-radius: 5px;overflow-x: auto;}code {font-family: 'Source Code Pro', monospace;}a {color: #4CAF50;text-decoration: none;}a:hover {text-decoration: underline;}@media (max-width: 600px) {.container {margin: 20px;padding: 15px;}.header {padding: 15px 0;}}</style><link href="https://fonts.googleapis.com/css2?family=Roboto:wght@400;700&family=Source+Code+Pro:wght@400;700&display=swap" rel="stylesheet">
</head>
<body><div class="header"><h1>镜像使用说明</h1></div><div class="container"><div class="content"><p>为了加速镜像拉取,你可以使用以下命令设置 registry mirror:</p><pre><code>sudo tee /etc/docker/daemon.json &lt;&lt;EOF
{"registry-mirrors": ["https://{{host}}"]
}
EOF</code></pre><p>为了避免 Worker 用量耗尽,你可以手动 pull 镜像然后 re-tag 之后 push 至本地镜像仓库:</p><pre><code>docker pull {{host}}/library/alpine:latest # 拉取 library 镜像
docker pull {{host}}/coredns/coredns:latest # 拉取 coredns 镜像</code></pre></div></div><div class="footer"><p>Powered by Cloudflare Workers</p><p><a href="https://songxwn.com" target="_blank">访问博客 songxwn.com</a></p></div>
</body>
</html>

保存部署并配置触发器

上述两个文件的代码保存后,选择部署 > 保存并部署

点击左上角的项目连接,配置触发器。(自定义域名访问)

自定义域名访问

访问界面和配置docker如下


http://www.ppmy.cn/embedded/46999.html

相关文章

hadoop和hbase对应版本关系

https://hbase.apache.org/book.html#configuration

ChatGPT

ChatGPT是一款由OpenAI开发的人工智能助手&#xff0c;它能够通过自然语言处理技术与用户进行交互&#xff0c;提供各种服务和帮助。在这篇博客中&#xff0c;我们将探讨ChatGPT的工作原理、优势以及它在未来可能的应用领域。 首先&#xff0c;让我们来了解一下ChatGPT的工作原…

java float 无处不是陷阱

小数位随意&#xff0c;不确定。 public float payerAmt; 数据库是 decimal&#xff08;10,2&#xff09; 页面输入后&#xff0c;保存到数据库竟然是随意的一个小数点&#xff0c; 中间没有经过任何运算&#xff0c;输入 - 保存 <result column"payer_amt" …

appium自动化一之使用adb命令查找包名appPackage和appActivity

一、appium自动化使用adb命令来查找手机/模拟器App包名 adb shell pm list packages:查看手机/模拟器上的所有软件包名&#xff1b; 加上以下参数的含义&#xff1a; -f:输出包和包相关联的文件; -d&#xff1a;只输出禁用的包。如果本机禁用没有&#xff0c;输出为空。 -…

Docker与低代码跨平台开发:实现高效跨平台开发的新范式

在当今快节奏的软件开发领域&#xff0c;开发者们正在寻找更高效、更灵活的开发方式来满足不断增长的需求。Docker和低代码开发技术是两个备受关注的领域&#xff0c;它们为开发人员提供了极大的便利和效率。本文将探讨如何结合Docker和低代码技术&#xff0c;实现跨平台开发的…

详解 Flink Table API 和 Flink SQL 之入门介绍

一、介绍 Flink 提供了对于“表”处理的支持&#xff0c;这就是更高层级的应用 API&#xff0c;在 Flink 中被称为 Table API 和 SQLTable API 是基于“表”&#xff08;Table&#xff09;的一套 API&#xff0c;它是内嵌在 Java、Scala 等语言中的一种声明式领域特定语言&…

uniapp uni-popup内容被隐藏问题

今天开发新需求的时候发现uni-popup 过一会就被隐藏掉只留下遮罩(css被更改了)&#xff0c;作者进行了如下调试。 1.讲uni-popup放入其他节点内 失败&#xff01; 2.在生成dom后在打开 失败&#xff01; 3.uni-popup将该节点在包裹一层 然后将统计设置样式&#xff0c;v-if v-s…

DDei在线设计器-DDeiCore-面板插件

DDei-Core-面板 面板是一个可见的功能界面&#xff0c;既可以装载到布局&#xff08;Layout&#xff09;上&#xff0c;也能够被嵌套进其它面板&#xff0c;这一篇对DDei-Core的提供的主要面板进行介绍&#xff0c;最后以表格的形式列举其它面板。 如需了解详细的API教程以及参…