https://github.com/alebeck/boring Skip to content Navigation Menu Toggle navigation Sign in * Product + GitHub Copilot Write better code with AI + Security Find and fix vulnerabilities + Actions Automate any workflow + Codespaces Instant dev environments + Issues Plan and track work + Code Review Manage code changes + Discussions Collaborate outside of code + Code Search Find more, search less Explore + All features + Documentation + GitHub Skills + Blog * Solutions By size + Enterprise + Teams + Startups By industry + Healthcare + Financial services + Manufacturing By use case + CI/CD & Automation + DevOps + DevSecOps * Resources Topics + AI + DevOps + Security + Software Development + View all Explore + Learning Pathways + White papers, Ebooks, Webinars + Customer Stories + Partners * Open Source + GitHub Sponsors Fund open source developers + The ReadME Project GitHub community articles Repositories + Topics + Trending + Collections * Enterprise + Enterprise platform AI-powered developer platform Available add-ons + Advanced Security Enterprise-grade security features + GitHub Copilot Enterprise-grade AI features + Premium Support Enterprise-grade 24/7 support * Pricing Search or jump to... Search code, repositories, users, issues, pull requests... Search [ ] Clear Search syntax tips Provide feedback We read every piece of feedback, and take your input very seriously. [ ] [ ] Include my email address so I can be contacted Cancel Submit feedback Saved searches Use saved searches to filter your results more quickly Name [ ] Query [ ] To see all available qualifiers, see our documentation. Cancel Create saved search Sign in Sign up Reseting focus You signed in with another tab or window. Reload to refresh your session. You signed out in another tab or window. Reload to refresh your session. You switched accounts on another tab or window. Reload to refresh your session. Dismiss alert {{ message }} alebeck / boring Public * Notifications You must be signed in to change notification settings * Fork 10 * Star 358 The `boring` SSH tunnel manager License MIT license 358 stars 10 forks Branches Tags Activity Star Notifications You must be signed in to change notification settings * Code * Issues 3 * Pull requests 1 * Actions * Projects 0 * Security * Insights Additional navigation options * Code * Issues * Pull requests * Actions * Projects * Security * Insights alebeck/boring This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository. main BranchesTags Go to file Code Folders and files Name Name Last commit Last commit message date Latest commit History 53 Commits .github/workflows .github/ workflows assets assets cmd/boring cmd/boring examples examples internal internal .gitignore .gitignore LICENSE LICENSE README.md README.md TODO.md TODO.md build.sh build.sh go.mod go.mod go.sum go.sum View all files Repository files navigation * README * MIT license The boring tunnel manager Static Badge GitHub Release Go Report Card Static Badge A simple & reliable command line SSH tunnel manager. Screenshot Features * Ultra lightweight and fast * Local and remote tunnels * Compatible with SSH config and ssh-agent * Supports Unix sockets * Automatic reconnection * Human-friendly configuration via TOML Usage Usage: boring list,l List tunnels boring open,o [ ...] Open specified tunnel(s) boring close,c [ ...] Close specified tunnel(s) Configuration By default, boring reads its configuration from ~/.boring.toml. The configuration is a simple TOML file describing your tunnels: # simple tunnel [[tunnels]] name = "dev" local = "9000" remote = "localhost:9000" host = "dev-server" # automatically matches host against SSH config # example of an explicit host (no SSH config) [[tunnels]] name = "prod" local = "5001" remote = "localhost:5001" host = "prod.example.com" user = "root" identity = "~/.ssh/id_prod" # will try default ones if not set # ... more tunnels Currently, supported options are: name, local, remote, host, user, identity, port, and mode. host either describes a host which to match SSH configs to, or if no matches found, the actual hostname. mode can be 'local' for local or 'remote' for remote forwarding, default is 'local'. The location of the config file can be changed by setting the BORING_CONFIG environment variable. Installation Get one of the pre-built binaries from the releases page or build it yourself: git clone https://github.com/alebeck/boring && cd boring ./build.sh Currently only supports macOS and Linux. About The `boring` SSH tunnel manager Resources Readme License MIT license Activity Stars 358 stars Watchers 3 watching Forks 10 forks Report repository Releases 2 0.4.1 Latest Oct 6, 2024 + 1 release Languages * Go 99.7% * Shell 0.3% Footer (c) 2024 GitHub, Inc. Footer navigation * Terms * Privacy * Security * Status * Docs * Contact * Manage cookies * Do not share my personal information You can't perform that action at this time.