For further actions, you may consider blocking this person and/or reporting abuse
The Most Contextual AI Development Assistant
Our centralized storage agent works on-device, unifying various developer tools to proactively capture and enrich useful materials, streamline collaboration, and solve complex problems through a contextual understanding of your unique workflow.
👥 Ideal for solo developers, teams, and cross-company projects
Read next
data:image/s3,"s3://crabby-images/52c36/52c367d41ab0a79f052d3616447d1b831bf50ea6" alt="arsalanmee profile image"
Top 20 JavaScript Interview Questions for 2025
Arsalan Mlaik -
data:image/s3,"s3://crabby-images/fa557/fa557e93e2cc63a11f9fc7e344ad7872c73c91dd" alt="arbythecoder profile image"
Day 37: Using Kustomize to Manage Kubernetes Configurations
Arbythecoder -
data:image/s3,"s3://crabby-images/db406/db406086b6d3b4d24e532d41c59ec30a818f0b8d" alt="respect17 profile image"
Learning Java Together: A Fun Journey into Coding Basics 👩🏼💻📚!
Kudzai Murimi -
data:image/s3,"s3://crabby-images/55b0a/55b0acce999b2501809e70fa0302c8f3bddc8d9b" alt="jps27cse profile image"
Mastering Higher-Order Functions in JavaScript
Jack Pritom Soren -
Top comments (2)
For the average five-year-old:
It's a way to tell computers what to do, even if they're very far away.
For the super genius five-year-old who somehow knows a lot about computers:
It's a protocol for securely connecting to a command line shell (think CMD) on a computer over a network (LAN/Internet/...). You need a server program running on the remote and a client program on your local device. You authenticate with your remote username and either your password or (preferably) your private key (a topic for another ELI5) and are greeted by the same command-line interface as if you were sitting in front of the computer with a keyboard and monitor plugged into it.
So I hear you want to access your Linux/BSD/Unix server, but don't want to be in that data center where it's at. Why don't we do this then?
You remember how HTTPS works, right? Two pairs of keys, a public-private set, on each server and they exchange keys at time of connection, right?
Same deal, but once the connection has encryption, it sets up not a regular request but a set of "channels". One channel is used to control all the others. Another channel is used... for your terminal session on that server.
If you tell SSH to, it can add more channels for more sessions, or use those channels to transfer files (like FTP). It recently can transfer TCP/IP or Ethernet traffic over those channels as well -- an on-demand, ad-hoc VPN.
You can also tell SSH to use a pre-shared set of keys instead of a username and password for those channels. Or ask again for a second password like a Yubikey code.
Where does this all come from? The guys over at OpenBSD, who also make LibreSSL.