From b3782ae780ead434066d1773d964f56d932a20b1 Mon Sep 17 00:00:00 2001 From: lixd Date: Fri, 14 Jun 2024 09:03:06 +0800 Subject: [PATCH] modify --- .gitignore | 3 +- README.md | 1 + src/help.html | 141 ++++++++++++++++++++++++++++++++++++++++++++++++++ src/index.js | 27 +++++++--- wrangler.toml | 16 +++--- 5 files changed, 171 insertions(+), 17 deletions(-) create mode 100644 src/help.html diff --git a/.gitignore b/.gitignore index 6356189cb..ea8c64012 100644 --- a/.gitignore +++ b/.gitignore @@ -213,4 +213,5 @@ dist # and uncomment the following lines # .pnp.* -# End of https://www.toptal.com/developers/gitignore/api/yarn \ No newline at end of file +# End of https://www.toptal.com/developers/gitignore/api/yarn +.idea \ No newline at end of file diff --git a/README.md b/README.md index 06b4adced..f2f15e0da 100644 --- a/README.md +++ b/README.md @@ -7,6 +7,7 @@ > If you're looking for proxy for helm, maybe you can try [cloudflare-helm-proxy](https://github.com/ciiiii/cloudflare-helm-proxy). ## Deploy +[![Deploy to Cloudflare Workers](https://deploy.workers.cloudflare.com/button)](https://deploy.workers.cloudflare.com/?url=https://github.com/lixd/cloudflare-docker-proxy) 1. fork this project 2. modify the link of the above button to your fork url diff --git a/src/help.html b/src/help.html new file mode 100644 index 000000000..d88c908e6 --- /dev/null +++ b/src/help.html @@ -0,0 +1,141 @@ + + + + + + 镜像使用说明 + + + + +
+

镜像使用说明

+ + GitHub + +
+
+
+

为了加速 Docker 镜像拉取,你可以使用以下命令设置 registry mirror:

+
sudo tee /etc/docker/daemon.json <<EOF
+{
+    "registry-mirrors": ["https://{{host}}"]
+}
+EOF
+# 配置完后需要重启 Docker 服务
+sudo systemctl restart docker
+
+

使用该代理从不同的镜像仓库拉取镜像,请参考以下命令:

+

+# docker pull nginx:latest
+docker pull docker.{{host}}/library/nginx:latest  # 拉取 Docker 官方镜像
+
+# docker pull quay.io/coreos/etcd:latest
+docker pull quay.{{host}}/coreos/etcd:latest  # 拉取 Quay 镜像
+
+# docker pull gcr.io/google-containers/busybox:latest
+docker pull gcr.{{host}}/google-containers/busybox:latest  # 拉取 GCR 镜像
+
+# docker pull k8s.gcr.io/pause:latest
+docker pull k8s-gcr.{{host}}/pause:latest  # 拉取 k8s.gcr.io 镜像
+
+# docker pull registry.k8s.io/pause:latest
+docker pull k8s.{{host}}/pause:latest  # 拉取 registry.k8s.io 镜像
+
+# docker pull ghcr.io/github/super-linter:latest
+docker pull ghcr.{{host}}/github/super-linter:latest  # 拉取 GitHub 容器镜像
+
+# docker pull docker.cloudsmith.io/public/repo/image:latest
+docker pull cloudsmith.{{host}}/public/repo/image:latest  # 拉取 Cloudsmith 镜像
+
+

为了避免 Worker 用量耗尽,你可以手动 pull 镜像然后 re-tag 之后 push 至本地镜像仓库。

+
+
+ + + + diff --git a/src/index.js b/src/index.js index e61d67dce..8f74b06ed 100644 --- a/src/index.js +++ b/src/index.js @@ -1,3 +1,5 @@ +import DOCS from './help.html' + addEventListener("fetch", (event) => { event.passThroughOnException(); event.respondWith(handleRequest(event.request)); @@ -7,16 +9,16 @@ const dockerHub = "https://registry-1.docker.io"; const routes = { // production - "docker.libcuda.so": dockerHub, - "quay.libcuda.so": "https://quay.io", - "gcr.libcuda.so": "https://gcr.io", - "k8s-gcr.libcuda.so": "https://k8s.gcr.io", - "k8s.libcuda.so": "https://registry.k8s.io", - "ghcr.libcuda.so": "https://ghcr.io", - "cloudsmith.libcuda.so": "https://docker.cloudsmith.io", + "docker.lixd.xyz": dockerHub, + "quay.lixd.xyz": "https://quay.io", + "gcr.lixd.xyz": "https://gcr.io", + "k8s-gcr.lixd.xyz": "https://k8s.gcr.io", + "k8s.lixd.xyz": "https://registry.k8s.io", + "ghcr.lixd.xyz": "https://ghcr.io", + "cloudsmith.lixd.xyz": "https://docker.cloudsmith.io", // staging - "docker-staging.libcuda.so": dockerHub, + "docker-staging.lixd.xyz": dockerHub, }; function routeByHosts(host) { @@ -42,6 +44,15 @@ async function handleRequest(request) { } ); } + // return docs + if (url.pathname === "/") { + return new Response(DOCS, { + status: 200, + headers: { + "content-type": "text/html" + } + }); + } const isDockerHub = upstream == dockerHub; const authorization = request.headers.get("Authorization"); if (url.pathname == "/v2/") { diff --git a/wrangler.toml b/wrangler.toml index 17f18f5fb..bba9196f2 100644 --- a/wrangler.toml +++ b/wrangler.toml @@ -13,13 +13,13 @@ TARGET_UPSTREAM = "https://registry-1.docker.io" [env.production] name = "cloudflare-docker-proxy" routes = [ - { pattern = "docker.libcuda.so", custom_domain = true }, - { pattern = "quey.libcuda.so", custom_domain = true }, - { pattern = "gcr.libcuda.so", custom_domain = true }, - { pattern = "k8s-gcr.libcuda.so", custom_domain = true }, - { pattern = "k8s.libcuda.so", custom_domain = true }, - { pattern = "ghcr.libcuda.so", custom_domain = true }, - { pattern = "cloudsmith.libcuda.so", custom_domain = true }, + { pattern = "docker.lixd.xyz", custom_domain = true }, + { pattern = "quay.lixd.xyz", custom_domain = true }, + { pattern = "gcr.lixd.xyz", custom_domain = true }, + { pattern = "k8s-gcr.lixd.xyz", custom_domain = true }, + { pattern = "k8s.lixd.xyz", custom_domain = true }, + { pattern = "ghcr.lixd.xyz", custom_domain = true }, + { pattern = "cloudsmith.lixd.xyz", custom_domain = true }, ] [env.production.vars] @@ -28,7 +28,7 @@ TARGET_UPSTREAM = "" [env.staging] name = "cloudflare-docker-proxy-staging" -route = { pattern = "docker-staging.libcuda.so", custom_domain = true } +route = { pattern = "docker-staging.lixd.xyz", custom_domain = true } [env.staging.vars] MODE = "staging"