savvii / ssh-tunnel
Small library to create an SSH tunnel, for example for MySQL
Installs: 1 531
Dependents: 0
Suggesters: 0
Security: 0
Stars: 4
Watchers: 4
Forks: 2
Open Issues: 0
pkg:composer/savvii/ssh-tunnel
Requires
- php: >=8.0
Requires (Dev)
- phpmd/phpmd: ^2.13
- phpstan/phpstan: ^1.9
- squizlabs/php_codesniffer: ^3.7
This package is auto-updated.
Last update: 2025-10-18 04:22:40 UTC
README
Small library to create a SSH Tunnel
Example usage:
use Savvii\SshTunnel\SshTunnel; $tunnel = new SshTunnel( sshUsername: 'myuser', sshHost: 'jumpserver.example.com', sshPort: 22, bindHost: 'remote-db-host.local.lan', bindPort: 3306 ); $db = new PDO( sprintf( "mysql:host=%s;port=%d", $tunnel->localAddress, $tunnel->localPort ) );
When the PHP script ends or the SshTunnel object is destroyed the SSH tunnel is disconnected.
Warning
When you create the object but let it go out of scope, by default the SSH tunnel will be cleaned up. This will not work:
function connect(): void { $tunnel = new SshTunnel(...); } connect(); // At this point the SSH tunnel is disconnected because $tunnel went out of scope.
This will work:
function connect(): void { return new SshTunnel(...); } $tunnel = connect(); // At this point the SSH tunnel works.
If you are creating the SshTunnel object in the constructor of a class, make sure to store it in a class property,
to make it not go out of scope when the constructor is finished.
Requirements
- Linux, MacOS or FreeBSD
- PHP 8.0 or greater
- PHP functions proc_open,proc_close,proc_terminateandproc_get_statusenabled
- Binary ssh
- Binary lsof, used by default but can be skipped.
- Binary nc, used by default but can be skipped.