Overview
Aptible offers Ephemeral SSH Sessions for accessing containers that are configured identically to App containers, making them ideal for managing consoles and running ad-hoc jobs. Unlike regular containers, ephemeral containers won’t be restarted when they crash. If your connection to Aptible drops, the remote Container will be terminated.Creating Ephemeral SSH Sessions
Ephemeral SSH Sessions can be created using theaptible ssh
command.
Ephemeral containers are not the same size as your App Container. By default, ephemeral containers are scaled to 1024 MB.
Terminating Ephemeral SSH Sessions
Manually Terminating
You can terminate your SSH sessions by closing the terminal session you spawned it in or exiting the container. It may take a bit of time for our API to acknowledge that the SSH session is shut down. If you’re running into Plan Limits trying to create another one, wait a few minutes and try again.
Expiration
SSH sessions will automatically terminate upon expiration. By default, SSH sessions will expire after seven days. Contact Aptible Support to reduce the default SSH session duration for Dedicated Stacks. Please note that this setting takes effect regardless of whether the session is active or idle. When you create a SSH session using
aptible ssh
, you’re logging in to an ephemeral container. You are not logging to one of your running app containers. This means that running commands like ps
won’t reflect what’s actually running in your App containers, and that files that exist in your App containers will not be present in the ephemeral session. Logging
If you process PHI or sensitive information in your app or database: it’s very likely that PHI will at some point leak in your SSH session logs. To ensure compliance, make sure you have the appropriate agreements in place with your logging provider before sending your SSH logs there. For PHI, you’ll need a BAA.
- You see the user’s input as well.
- If you’re prompting the user for a password using a safe password prompt that does not write back anything, nothing will be sent to the Log Drain either. That prevents you from leaking your passwords to your logging provider.
Metadata
For Log Drains that support embedding metadata in the payload (HTTPS Log Drains and Self-Hosted Elasticsearch Log Drains), the following keys are included:operation_id
: The ID of the Operation that resulted in the creation of this Ephemeral Session.operation_user_name
: The name of the user that created the Operation.operation_user_email
: The email of the user that created the Operation.APTIBLE_USER_DOCUMENT
: An expired JWT object with user information.