基于Cloudflare Workers 搭建 Docker Hub 镜像加速
简介
基于 Cloudflare Workers
搭建 Docker Hub
镜像加速服务。
- 1、首先注册一个
Cloudflare
账号。 - 2、
Coludflare
账号下域名的一级域名,推荐万网注册一个top
域名,再转移到Coludflare
。 - 3、
Cloudflare Workers
免费账号有次数限制,每天调用10W
次,即每分钟1000
次。
步骤
登录 Cloudflare
地址:https://dash.cloudflare.com/
创建 Workers
- 点击
Workers 和 Pages
菜单栏; - 在
概述
页面点击创建
按钮,进入创建应用程序
页面; - 点击
创建 Worker
按钮,填入你的项目名称(例如:docker-hub
),点击保存
按钮,再点击完成
按钮;
编辑 Workers 代码
点击 编辑代码
按钮,就会进入编辑器,在此进行编辑 worker.js
和 docker.html
文件。
默认只有4个文件,因此需要手动添加1个docker.html
文件。
包含文件如下:
- package-lock.json
- package.json
- worker.js
- wrangler.toml
- docker.html
注:点击左侧
文件
图标,可展开文件目录。
编辑 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 <<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://jcebing.com" target="_blank">访问博客 jcebing.com</a></p>
</div>
</body>
</html>
保存部署并配置触发器
上述两个文件的代码保存后,选择 部署
-> 保存并部署
。
点击左上角的项目连接,配置触发器。(自定义域名访问)
注:如果不小心点击了保存按钮后,无法点击部署,可以在 部署页面当中,选择部署版本。
自定义域名访问
- 点击
设置
进入触发器
选项。 - 点击
添加自定义域
后,填写你的域名(例如:docker-hub.xxxxx.top
),即可用你的域名来直接访问 Docker镜像代理。
本文是原创文章,采用 CC BY-NC-ND 4.0 协议,完整转载请注明来自 玄冰小窝
评论
匿名评论
隐私政策
你无需删除空行,直接评论以获取最佳展示效果