7.7 KiB
G14 Provider Node
G14 is the current HWLAB DEV/PROD source and k3s/GitOps runtime truth, and it remains a UniDesk provider node for staging other infrastructure workloads. Its UniDesk provider id is G14; the local UniDesk worktree is /root/unidesk, and the native k3s kubeconfig is /etc/rancher/k3s/k3s.yaml.
G14's long-lived k3s control bridge is k3sctl-adapter-g14, a UniDesk direct service outside the k3s fault domain. It listens on the G14 host loopback port 127.0.0.1:4266 and is registered separately from the D601 k3sctl-adapter, so G14 infrastructure services can be built and tested without taking over user services that still run on D601.
For Code Queue and non-HWLAB CI/CD migration preparation, G14 uses native k3s labels unidesk.ai/node-id=G14 and unidesk.ai/provider-id=G14. The G14 Code Queue manifests src/components/microservices/k3sctl-adapter/k3s/code-queue.g14.k8s.yaml and src/components/microservices/k3sctl-adapter/k3s/code-queue.g14.k3s.json are candidate staging artifacts only until an explicit production cutover is approved. Non-HWLAB production Code Queue, CI/CD and user-service execution must remain on D601 while D601 is carrying those services.
HWLAB DEV/PROD Runtime
G14 hosts the current HWLAB DEV runtime in native k3s namespace hwlab-dev, and the same node/GitOps line is the HWLAB PROD target unless a newer HWLAB repo rule says otherwise. The canonical G14 HWLAB source workspace is /root/hwlab on branch G14, with origin set to git@github.com:pikasTech/HWLAB.git; HWLAB source edits, CI/CD/GitOps script changes, render work, manual polling and runtime validation must be done from that workspace through UniDesk SSH passthrough. Do not use /root/HWLAB, /home/ubuntu/hwlab, /workspace/hwlab, D601 workspace or a master-server checkout as persistent HWLAB source truth. G14-local details are mirrored on the node in /root/docs/hwlab-g14-workspace.md.
The standard entry forms are:
tran G14:/root/hwlab script -- git status --short --branch
tran G14 apply-patch < patch.diff
tran G14:k3s kubectl get pods -n hwlab-dev
G14:k3s is the only supported k3s route form. Do not use ssh G14 k3s ...; the first token must locate the distributed target, and the following tokens must be the operation.
The G14 HWLAB runtime boundary is:
- Current DEV public endpoints are
http://74.48.78.17:17666/andhttp://74.48.78.17:17667/health/live. D60116666/16667is legacy/migration evidence only. - Keep HWLAB Services as
ClusterIPunless a repo-owned G14 GitOps rule explicitly exposes them. Public exposure should stay in the approved G14 edge/proxy path, not ad hoc NodePort or local port-forward. - Use a G14-local PostgreSQL instance such as
hwlab-g14-postgresand a G14-localhwlab-cloud-api-dev-dbSecret for cloud-api durable runtime tests. Do not copy D601 database credentials. - Use only G14-local Codex auth material and k8s Secrets authorized for HWLAB on G14; do not copy D601 or production auth material by hand.
- Set
HWLAB_CLOUD_API_PORT=6667explicitly in the G14 cloud-api Deployment. Kubernetes otherwise injects aHWLAB_CLOUD_API_PORT=tcp://...Service environment variable that breaks the Node port parser. HWLAB_PUBLIC_ENDPOINTand health/live evidence must describe the G14 endpoint, not the old D601 production endpoint.- Do not run HWLAB repository
check, Playwright/browser smoke, image builds or other heavy validation on the master server. Run those through G14/root/hwlab, G14 k3s/Tekton, or another explicitly approved external execution plane. - Manual device-agent experiments for real hardware must be standalone resources in
hwlab-devsuch asdevice-agent-71-freqand must not patch existing HWLAB Deployments, Services, ArgoCD Applications, FRP, CD desired-state or public frontend routing unless a separate HWLAB change authorizes it. - A D601 Windows
hwlab-gatewaymay connect outbound to G14 DEV cloud-api as an external host bridge for Keil/serial/workspace access. That bridge does not make D601 the HWLAB runtime truth; it is only a hardware access provider behind the G14 device-agent/cloud-api path.
After the G14-local database is provisioned, run the HWLAB migration CLI only against the G14 DEV database with explicit non-production confirmations:
kubectl -n hwlab-dev exec deploy/hwlab-cloud-api -- \
node /app/cmd/hwlab-cloud-api/migrate.mjs \
--apply --confirm-dev --confirmed-non-production
Healthy G14 HWLAB runtime means the main Deployments and StatefulSets are Ready, cloud-api and edge-proxy return /health/live with status=ok, durable runtime checks pass, and the public G14 DEV endpoints report the expected revision. For a device-agent smoke, health also requires the standalone device-agent Service to answer in-cluster and the D601 Windows gateway session/resource/capability to be visible through G14 cloud-api.
Node-Local VPN Proxy
G14 has a node-local VPN/proxy stack for infrastructure bootstrap and recovery downloads:
- Primary mixed HTTP/SOCKS proxy:
127.0.0.1:10808. - Backup Hysteria2 HTTP proxy:
127.0.0.1:11809. - Backup Hysteria2 SOCKS5 proxy:
127.0.0.1:11808. - Operator-only local details remain on G14 under
/root/docs/vpn-proxy-ops.md; subscription URLs, node credentials and GUI database contents must not be copied into the UniDesk repository.
The G14 host persists this proxy configuration in these local files:
/etc/profile.d/unidesk-g14-proxy.shexportsHTTP_PROXY,HTTPS_PROXY,ALL_PROXY, lowercase aliases andNO_PROXYfor new login shells. SetUNIDESK_G14_DISABLE_PROXY=1before shell startup to opt out./root/.npmrcpins npmproxy,https-proxy,noproxyand retry settings for root-side bootstrap commands./root/.gitconfigpins root Git HTTP/HTTPS proxy settings./root/.docker/config.jsonpins Docker client proxy settings for commands and build contexts that honor Docker client proxy configuration./etc/systemd/system/docker.service.d/proxy.confpins Docker daemon pull proxy settings. Updating this drop-in requiressystemctl daemon-reloadand a Docker restart before the active daemon sees the newNO_PROXY; do not restart Docker while G14 provider-gateway, k3s bootstrap or image builds are in flight unless that interruption is intentional.
The NO_PROXY list must include localhost, the main server, private LAN ranges, k3s pod/service CIDRs, Kubernetes service domains and the loopback registry so that k3s, 127.0.0.1:5000, Kubernetes API access and UniDesk control paths do not route through the VPN proxy.
The primary proxy can be used for G14 target-side image bootstrap when Docker Hub, npm, GitHub or Playwright downloads are unreliable through direct network or provider-gateway WS egress. For Docker build steps that use 127.0.0.1, build with host networking so the build container reaches the host proxy:
docker build --network host \
--build-arg HTTP_PROXY=http://127.0.0.1:10808 \
--build-arg HTTPS_PROXY=http://127.0.0.1:10808 \
--build-arg ALL_PROXY=socks5h://127.0.0.1:10808 \
--build-arg http_proxy=http://127.0.0.1:10808 \
--build-arg https_proxy=http://127.0.0.1:10808 \
--build-arg all_proxy=socks5h://127.0.0.1:10808 \
...
The backup proxy uses HTTP_PROXY=http://127.0.0.1:11809, HTTPS_PROXY=http://127.0.0.1:11809 and ALL_PROXY=socks5h://127.0.0.1:11808.
This proxy is not a replacement for UniDesk runtime egress. k3s workloads such as Code Queue must still use the cataloged g14-provider-egress-proxy Kubernetes Service and g14-tcp-egress-gateway for normal runtime access to PostgreSQL, OA Event Flow and external APIs. The node-local VPN proxy is allowed only for G14 host-side bootstrap, image build, cache prewarm or recovery steps, and those steps should record the proxy choice in issue or deployment evidence.