Ssh-agent single sign-on configuration, agent forwarding & agent protocol (2024)

The ssh-agent is a helper program that keeps track of users' identity keys and their passphrases. The agent can then use the keys to log into other servers without having the user type in a password or passphrase again. This implements a form of single sign-on (SSO).

The SSH agent is used for SSH public key authentication. It uses SSH keys for authentication. Users can create SSH keys using the ssh-keygen command and install them on servers using the ssh-copy-id command.

Contents

Starting ssh-agent Adding SSH keys to the Agent SSH Agent Forwarding Running ssh-agent Further Reading

Starting ssh-agent

On most Linux systems, ssh-agent is automatically configured and run at login, and no additional actions are required to use it. However, an SSH key must still be created for the user.

If ssh-agent is not automatically started at login, it can be started manually with the command

eval `ssh-agent`

The ssh-agent command outputs commands to set certain environment variables in the shell. The commands output by default are compatible with /bin/sh and /bin/bash. To output commands for the C-shell (/bin/csh or /bin/tcsh), add -c.

The easiest way to check is to check the value of the SSH_AGENT_SOCK environment variable. If it is set, then the agent is presumably running. It can be checked by

echo $SSH_AGENT_SOCK

Also, to allow key-based logins to servers, public key authentication must be enabled on the server. In OpenSSH it is enabled by default. It is controlled by the PubkeyAuthentication option in sshd_config.

Adding SSH keys to the Agent

By default, the agent uses SSH keys stored in the .ssh directory under the user's home directory. The ssh-add command is used for adding identities to the agent. In the simplest form, just run if without argument to add the default files ~/.ssh/id_rsa, .ssh/id_dsa, ~/.ssh/id_ecdsa, ~/.ssh/id_ed25519, and ~/.ssh/identity. Otherwise, give it the name of the private key file to add as an argument.

The following command will list private keys currently accessible to the agent:

ssh-add -l

SSH Agent Forwarding

Furthermore, the SSH protocol implements agent forwarding, a mechanism whereby an SSH client allows an SSH server to use the local ssh-agent on the server the user logs into, as if it was local there. When the user uses an SSH client on the server, the client will try to contact the agent implemented by the server, and the server then forwards the request to the client that originally contacted the server, which further forwards it to the local agent. This way, ssh-agent and agent forwarding implement single sign-on that can progress transitively.

A wonderful feature of the single sign-on provided by SSH is that it works independent of organizational boundaries and geography. You can easily implement single sign-on to servers on the other side of the world, in cloud services, or at customer premises. No central coordination is needed.

To use agent forwarding, the ForwardAgent option must be set to yes on the client (see ssh_config) and the AllowAgentForwarding option must be set to yes on the server (see sshd_config).

Ssh-agent single sign-on configuration, agent forwarding & agent protocol (1)

Running ssh-agent

The ssh-agent command is usually run from initialization scripts at login, such as from /etc/X11/Xsession.d/90x11-common_ssh-agent on Linux Mint LMDE. Alternatively, any user can configure it to be run from, e.g., the user's ~/.xsession file or ~/.profile.

The agent outputs environment variable settings that this puts in place. The SSH_AUTH_SOCK environment variable is set to point to a unix-domain socket used for communicating with the agent, and the SSH_AGENT_PID environment variable is set to the process ID of the agent. To get the environment variables set in the user's shell environment, the agent is usually run with something like the following:

eval `ssh-agent`

The ssh-agent command accepts the following options:

-a bind_address

Forces to bind the Unix domain socket to the given file path, instead of the default socket.

-c

Forces generation of C-shell commands on stdout. By default the shell is automatically detected.

-d

Enables debug mode.

-E fingerprint_hash Specifies which algorithm to use for generating SSH key fingerprints. Valid values include md5 and sha256.

-k

Kills the currently running agent.

-s

Forces generation of Bourne shell (/bin/sh) commands on stdout. By default the shell is automatically detected.

-t life

Specifies a maximum number of seconds that identities are kept in the agent. The value is in seconds, but can be suffixed by m for minutes, h for hours, d for days, and w for weeks. Without this option, the agent keeps the keys in its memory as long as it runs. This can be overridden when running the ssh-add command.

Further Reading

Ssh-agent single sign-on configuration, agent forwarding & agent protocol (2)

Ssh-agent single sign-on configuration, agent forwarding & agent protocol (2024)
Top Articles
Pets & Parasites: The Pet Owner's Parasite Resource
Reasons to Keep Your Tech Serial Numbers Private
Jack Doherty Lpsg
Hometown Pizza Sheridan Menu
Chicago Neighborhoods: Lincoln Square & Ravenswood - Chicago Moms
What spices do Germans cook with?
What are Dietary Reference Intakes?
Find All Subdomains
Dr Klabzuba Okc
Palace Pizza Joplin
Uvalde Topic
Zoebaby222
Simple Steamed Purple Sweet Potatoes
2135 Royalton Road Columbia Station Oh 44028
1Win - инновационное онлайн-казино и букмекерская контора
Housework 2 Jab
Leeks — A Dirty Little Secret (Ingredient)
Nene25 Sports
Justified Official Series Trailer
Slope Tyrones Unblocked Games
Craigslist Free Stuff Santa Cruz
Costco Great Oaks Gas Price
Metro Pcs.near Me
Universal Stone Llc - Slab Warehouse & Fabrication
Lisas Stamp Studio
How many days until 12 December - Calendarr
Pocono Recird Obits
Johnnie Walker Double Black Costco
Rapv Springfield Ma
Best Laundry Mat Near Me
Was heißt AMK? » Bedeutung und Herkunft des Ausdrucks
Ofw Pinoy Channel Su
Lehpiht Shop
Amici Pizza Los Alamitos
Old Peterbilt For Sale Craigslist
The Best Carry-On Suitcases 2024, Tested and Reviewed by Travel Editors | SmarterTravel
Missouri State Highway Patrol Will Utilize Acadis to Improve Curriculum and Testing Management
Ursula Creed Datasheet
Unveiling Gali_gool Leaks: Discoveries And Insights
Satucket Lectionary
Fatal Accident In Nashville Tn Today
Online-Reservierungen - Booqable Vermietungssoftware
Ucla Basketball Bruinzone
The Jazz Scene: Queen Clarinet: Interview with Doreen Ketchens – International Clarinet Association
Wood River, IL Homes for Sale & Real Estate
Used Sawmill For Sale - Craigslist Near Tennessee
Latina Webcam Lesbian
Mikayla Campinos Alive Or Dead
Bluebird Valuation Appraiser Login
Latest Posts
Article information

Author: Geoffrey Lueilwitz

Last Updated:

Views: 5571

Rating: 5 / 5 (80 voted)

Reviews: 87% of readers found this page helpful

Author information

Name: Geoffrey Lueilwitz

Birthday: 1997-03-23

Address: 74183 Thomas Course, Port Micheal, OK 55446-1529

Phone: +13408645881558

Job: Global Representative

Hobby: Sailing, Vehicle restoration, Rowing, Ghost hunting, Scrapbooking, Rugby, Board sports

Introduction: My name is Geoffrey Lueilwitz, I am a zealous, encouraging, sparkling, enchanting, graceful, faithful, nice person who loves writing and wants to share my knowledge and understanding with you.