dev-resources.site
for different kinds of informations.
Changing an established SSH connection without disconnecting
Understanding SSH Escape Characters
Introduction
SSH (Secure Shell) is a widely used protocol for securing remote terminal sessions. When working with SSH, you may sometimes need to use escape characters to perform specific functions within an SSH session. Understanding how to use these escape characters effectively can significantly improve your SSH experience and troubleshooting capabilities. In this article, we'll explore what escape characters are, how to use them, and provide some practical examples to illustrate their utility.
What is an Escape Character?
An escape character is a special character that allows users to execute certain functions within an SSH session. By default, this character is the tilde ~
. To send a single tilde, you can either use ~~
or follow the tilde with any character other than the specified functions. The escape character must always be preceded by a newline to be interpreted correctly. You can change this character in configuration files using the EscapeChar
directive or on the command line with the -e
option.
Supported Escape Sequences
The following escape sequences are supported when the default tilde ~
is used:
Command Line Access with ~C
One of the most powerful escape sequences is ~C
, which opens a command line for adding port forwardings using the -L
, -R
, and -D
options. Basic help is also available with the -h
option. Here's how to use it:
- Type
Enter~C
(i.e., a capitalC
). -
Add your port forwarding command, such as:
-L localport:server:serverport
Replace
localport
,server
, andserverport
with your desired values, and then press Enter.
Practical Examples
Example 1: Adding a Port Forwarding
Imagine you need to access a web server running on a remote machine but want to forward it through a local port. You would use the ~C
command as follows:
Enter~C
-L 8080:localhost:80
Enter
This will forward the remote web server (port 80) to your local machine's port 8080.
Example 2: Terminating an SSH Session
If you need to quickly terminate your SSH session, you can use the escape sequence:
Enter~.
This sequence immediately closes the SSH connection.
Practical Considerations
- Timing: Choose the right moment to press Enter, as it will be immediately sent to the remote side and may trigger some action there. Do this when you are at a shell prompt with an empty command line.
-
International Keyboards: For internationalized keyboards where the tilde might be a dead key (e.g., pressing
~n
to generateñ
), it might be necessary to press SPACE after the tilde to generate a single tilde, i.e.,ENTER~SPACEC
. On Spanish/Latin American keyboard layouts, since there are no combined characters using tilde andC
, the space can be omitted.
Multiple Redirections
The SSH escape command line only accepts one command at a time. To enter multiple commands or redirections, you need to press the keyboard sequence again for each new command.
Enabling ~C
in SSH Client v9.2 and Later
For SSH client version 9.2 and later, the ~C
command line must be manually enabled using either the -o EnableEscapeCommandline=yes
option or by adding the EnableEscapeCommandline
option in your ~/.ssh/config
file.
The Fascination of Dynamic Port Forwarding
One of the most intriguing uses of SSH escape characters is the ability to insert port forwardings into already established SSH connections. This functionality, enabled by the ~C
escape sequence, allows for dynamic adjustment of port forwardings without the need to restart the SSH session.
Why It's Fascinating
This ability is especially valuable in situations where new requirements arise during an active session. Imagine you're connected to a remote server and suddenly need to forward a new port. Instead of terminating the session and starting over, you can seamlessly add the forwarding using the escape sequence.
Here’s a detailed example:
Example: Dynamic Port Forwarding
-
Establish an SSH Session:
ssh user@remotehost
-
Initiate Port Forwarding within the Session:
- Ensure you are at a shell prompt with an empty command line.
- Type
Enter~C
to open the escape command line. - Add the port forwarding command:
-L 3306:localhost:3306
- Press Enter.
This command dynamically forwards the remote server's port 3306 (typically used by MySQL) to your local machine's port 3306, allowing you to interact with the remote database as if it were local.
Security Considerations
While dynamic port forwarding is a powerful feature, it comes with security risks:
- Unauthorized Access: Be vigilant about who has access to use escape sequences, as they can potentially redirect sensitive ports.
- Monitoring: Actively monitor SSH sessions to detect any unauthorized or unusual activity.
-
Configuration Management: Secure your
~/.ssh/config
and related configuration files to prevent unauthorized changes.
By understanding and leveraging this feature with caution, you can significantly enhance the flexibility and functionality of your SSH sessions. Stay secure and make the most out of your SSH connections!
References
Featured ones: