Go
Go is fully supported by Speedscale. Use this page for Go-specific proxy settings, TLS trust configuration, demo guidance, and the proxymock local workflow.
- Support matrix: Technology Support
- Shared proxymock proxy reference: Language Configuration
Kubernetes Sidecar
When Go runs with the Speedscale sidecar in forward or dual mode, the Go runtime must still send
outbound traffic to the sidecar. Set HTTP_PROXY and HTTPS_PROXY to http://127.0.0.1:4140 unless you
changed proxy-out-port.
If tls-out is enabled, trust and routing are separate concerns:
- routing:
HTTP_PROXYandHTTPS_PROXY - TLS trust:
SSL_CERT_FILEor the language-specific trust mechanism in your image
See Proxy Modes and TLS Support for the shared sidecar behavior.
Demo App
- Public demo: speedscale/mock-lab (
godirectory) - Stack: Go HTTP service that calls one downstream, the CNCF projects API at
https://demo-api.trafficreplay.com - Local run:
go run . - Quick validation:
./lab/tests/run_tests.sh --recording
This is the canonical public Go demo for the proxymock quickstart and local replay workflow.
proxymock
Use this path for the fastest Go first success on a developer workstation.
- 1. Install and initialize proxymock
brew install speedscale/tap/proxymock proxymock initUse browser sign-in by default. Use `proxymock init --api-key <your key>` only for CI or other headless environments.
- 2. Start recording
git clone https://github.com/speedscale/mock-lab cd mock-lab/go proxymock record -- go run .proxymock records the app while it starts the Go service as a child process.
- 3. Generate one real workflow
./lab/tests/run_tests.sh --recordingRun the test driver from the repo root. It drives the requests that become the exported production-style trace.
- 4. Stop the recording, then run with mocks
cd mock-lab/go proxymock mock -- go run .The mocked run should no longer need live outbound dependencies.
- 5. Replay the same traffic against a change
cd mock-lab/go proxymock replay --test-against http://localhost:8080Use replay as the regression check before shipping Go changes.
TLS Trust
Go usually respects SSL_CERT_FILE. See the shared Language Configuration page for the exact command and any OpenSSL-specific notes.