This commit is contained in:
@@ -51,18 +51,12 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
set -euo pipefail
|
set -euo pipefail
|
||||||
|
|
||||||
# 0) 强校验 Secret 是否非空
|
# 0) Secret 非空
|
||||||
if [ -z "${V2RAY_JSON:-}" ]; then
|
[ -n "${V2RAY_JSON:-}" ] || { echo "V2RAY_JSON is empty"; exit 1; }
|
||||||
echo "ERROR: V2RAY_JSON is empty or not set." >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# 1) 写配置
|
# 1) 先在 runner 容器里修正端口(可选但推荐)
|
||||||
mkdir -p "${GITHUB_WORKSPACE}/v2ray"
|
mkdir -p "${GITHUB_WORKSPACE}/v2ray"
|
||||||
printf '%s' "$V2RAY_JSON" > "${GITHUB_WORKSPACE}/v2ray/config.json"
|
printf '%s' "$V2RAY_JSON" > "${GITHUB_WORKSPACE}/v2ray/config.json"
|
||||||
command -v jq >/dev/null 2>&1 && jq . "${GITHUB_WORKSPACE}/v2ray/config.json" >/dev/null
|
|
||||||
|
|
||||||
# 2) 强制端口为 11080/18080(与 BuildKit http_proxy 保持一致)
|
|
||||||
if command -v jq >/dev/null 2>&1; then
|
if command -v jq >/dev/null 2>&1; then
|
||||||
jq --argjson sp "$SOCKS_PORT" --argjson hp "$HTTP_PORT" \
|
jq --argjson sp "$SOCKS_PORT" --argjson hp "$HTTP_PORT" \
|
||||||
'.inbounds |= map(
|
'.inbounds |= map(
|
||||||
@@ -73,31 +67,33 @@ jobs:
|
|||||||
> "${GITHUB_WORKSPACE}/v2ray/config.tmp" && mv "${GITHUB_WORKSPACE}/v2ray/config.tmp" "${GITHUB_WORKSPACE}/v2ray/config.json"
|
> "${GITHUB_WORKSPACE}/v2ray/config.tmp" && mv "${GITHUB_WORKSPACE}/v2ray/config.tmp" "${GITHUB_WORKSPACE}/v2ray/config.json"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# 3) 容器内可见性检查(注意:去掉了 ,z)
|
# 2) base64 编码(兼容不同 base64 实现)
|
||||||
docker run --rm \
|
if base64 --help 2>&1 | grep -q -- '-w'; then
|
||||||
--network host \
|
CONF_B64="$(base64 -w0 < "${GITHUB_WORKSPACE}/v2ray/config.json")"
|
||||||
--mount type=bind,src=${GITHUB_WORKSPACE}/v2ray,dst=/etc/v2ray,readonly \
|
else
|
||||||
--entrypoint sh \
|
CONF_B64="$(base64 < "${GITHUB_WORKSPACE}/v2ray/config.json" | tr -d '\n')"
|
||||||
v2fly/v2fly-core:latest \
|
fi
|
||||||
-lc 'echo "== inside container =="; ls -l /etc/v2ray; echo "---"; head -n2 /etc/v2ray/config.json || true'
|
|
||||||
|
|
||||||
# 4) 启动(注意:去掉了 ,z)
|
# 3) 启动容器:用 entrypoint 写入配置再 exec v2ray;不再做 bind-mount
|
||||||
docker rm -f v2ray-client >/dev/null 2>&1 || true
|
docker rm -f v2ray-client >/dev/null 2>&1 || true
|
||||||
docker run -d --name v2ray-client \
|
docker run -d --name v2ray-client \
|
||||||
--network host \
|
--network host \
|
||||||
--mount type=bind,src=${GITHUB_WORKSPACE}/v2ray,dst=/etc/v2ray,readonly \
|
-e CONF_B64="${CONF_B64}" \
|
||||||
v2fly/v2fly-core:latest \
|
v2fly/v2fly-core:latest \
|
||||||
run -c /etc/v2ray/config.json
|
sh -lc 'set -euo pipefail;
|
||||||
|
mkdir -p /etc/v2ray;
|
||||||
|
printf "%s" "$CONF_B64" | base64 -d > /etc/v2ray/config.json;
|
||||||
|
exec v2ray run -c /etc/v2ray/config.json'
|
||||||
|
|
||||||
# 5) 健康检查 + 日志
|
# 4) 健康检查 + 日志打印
|
||||||
sleep 1
|
sleep 1
|
||||||
if [ "$(docker inspect -f '{{.State.Running}}' v2ray-client 2>/dev/null)" != "true" ]; then
|
if [ "$(docker inspect -f '{{.State.Running}}' v2ray-client 2>/dev/null)" != "true" ]; then
|
||||||
echo "== v2ray-client exited; logs =="
|
echo "== v2ray-client exited; logs =="
|
||||||
docker logs v2ray-client || true
|
docker logs v2ray-client || true
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
echo "v2ray-client is running."
|
||||||
|
|
||||||
docker inspect -f '{{range .Mounts}}{{println .Type " " .Source "->" .Destination}}{{end}}' v2ray-client
|
|
||||||
|
|
||||||
|
|
||||||
- name: Build Docker Image (host network; no Dockerfile change)
|
- name: Build Docker Image (host network; no Dockerfile change)
|
||||||
|
|||||||
Reference in New Issue
Block a user