SSH login: Keys vs Password

edited March 2024 in General

Assuming a really strong password is used, are keys really more secure than passwords for SSH login?

I have always used keys because it's more convenient but I was just wondering how keys are more secure as compared to an extremely strong password (say, 24 characters long comprising of multiple symbols, uppercase+lowercase alphabets and numbers all mixed up randomly)?

«1

Comments

  • The answer is inside you... but it is wrong =)

    "How miserable life is in the abuses of power..."
    F. Battiato ---

  • @AndrewL64 said:
    Assuming a really strong password is used, are keys really more secure than passwords for SSH login?

    I have always used keys because it's more convenient but I was just wondering how keys are more secure as compared to an extremely strong password (say, 24 characters long comprising of multiple symbols, uppercase+lowercase alphabets and numbers all mixed up randomly)?

    Tell me - you are using ROOT to login directly... If yes, you are safe with just a 8 char dictionary based password.

    /s

    Thanked by (1)chitree
  • AuroraZeroAuroraZero ModeratorHosting ProviderRetired

    Ehhh...uhhhh....hmmmm....ooohh...errrmmmm

    Thanked by (2)host_c Janevski

    Free Hosting at YetiNode | Cryptid Security | URL Shortener | LaunchVPS | ExtraVM | Host-C | In the Node, or Out of the Loop?

  • havochavoc OGContent WriterSenpai

    A random password of suitably long length is fine.

    Definitely weaker but at some point you're arguing between 1 million years to crack vs a 100 mllion years to crack. A distinction good for internet pissing contests but not much else

    The keys thing comes primarily because nobody actually uses 24 char true random. At that point you need to write it down & may as well use a key because you're basically doing a key in paper mode.

    Thanked by (1)skorous
  • @AndrewL64 said:
    Assuming a really strong password is used, are keys really more secure than passwords for SSH login?

    I have always used keys because it's more convenient but I was just wondering how keys are more secure as compared to an extremely strong password (say, 24 characters long comprising of multiple symbols, uppercase+lowercase alphabets and numbers all mixed up randomly)?

    Which are you going to adopt if you get completely different opinions between here and OGF? ;)

    If you're already using keys, for whatever reason, stick with it don't go back to just passwords. It has little to do practically with entropy or a "my key's longer than your key" debate, unless you're using stupidly short passwords, keys are simply more secure in the way they work, also as an adversary you need both the key material AND its password to unlock it, rather than just shoulder surfing or keylogging a password.

  • edited March 2024

    Yes, vastly.

    I'd say three major effects are in play: Entropy, guessability and 2FA aka Wrench Proofness

    Entropy in short means how much randomness is contained. More randomness basically means a higher number of computations to guess (bruteforce) your key. The difference in entropy between an ssh key and even an unusably long password is huge. Some examples:

    default 4096 bit RSA ssh key: 4096 bit of entropy lol
    The 24 character password RP8E;7-rB='a$emqz[^t6Qx,: 148.04 bits of entropy
    The 64 character password p4@8g'5%>s;f^NnG]VYKZ*2{a[Dh$j+JVh<Z#$94mD(@MT5a.qcu/>!Aaw&3B}8e : 417.24 bits of entropy

    Guessability: You probably did not choose a password of 24 completely random symbols - most likely it is based on something from your real life. This compromises your entropy HUGELY and is the basis of dictionary attacks. I cannot overstate how important this factor is. A ssh key is always based on completely random data and is thus removes this human factor completely.

    2FA aka 2 Factor Authentication: If you are compromised, you are not able to give someone else access without physical access to the ssh key data.
    This also covers inevitable mistakes like typing your password into the wrong window etc.
    Even if someone threatens you with a wrench, they won't get into your customers servers: https://xkcd.com/538/

    A personal note: In my experience, the standard for high security corporate settings, is a 6-8 word diceware password, AND a physical 2FA token like a Yubikey.

    I'm also disappointed in carlin0, localhost and AuroraZero wasting their time with sarcasm instead of making the effort to teach, or at least vocalize whatever criticism you have and stand behind your actions. Lazy and shameful.

  • There's also the whole process of how private and public keys work. Your private key, unlike your password, doesn't have to travel over the network.

    Thanked by (2)xvps carlin0
  • @IAmNix said:
    default 4096 bit RSA ssh key: 4096 bit of entropy lol
    The 24 character password RP8E;7-rB='a$emqz[^t6Qx,: 148.04 bits of entropy
    The 64 character password p4@8g'5%>s;f^NnG]VYKZ*2{a[Dh$j+JVh<Z#$94mD(@MT5a.qcu/>!Aaw&3B}8e : 417.24 bits of entropy

    I do not agree with this. I think my ssh root user with password toor is secure enough :p

    On a more serious note, what about those ed25519 keys? Why are people recommending them over RSA keys?

    Websites have ads, I have ad-blocker.

  • @AndrewL64 said:
    Assuming a really strong password is used, are keys really more secure than passwords for SSH login?

    I have always used keys because it's more convenient but I was just wondering how keys are more secure as compared to an extremely strong password (say, 24 characters long comprising of multiple symbols, uppercase+lowercase alphabets and numbers all mixed up randomly)?

    Did you know you can change the ssh port to something other then port 22 ? That should be the first change you do before worrying about passwords and RSA keys. Most attacks are just botnets trying random IP with common list of ports. If they see port 22 is not open, they'll try some other IPs. Unless you are under a targeted attack, your main concern should be not using dictionary/default passwords with easily guessable user (such as root) on a widely known port (22). Most of the hacks do not bypass passwords but attempt a zero day vulnerability attack when a bypass is found. Changing the port to a 5 digit port is usually enough to protect your server. If you want more protection, block root access and use a firewall with your IP whitelisted. If cannot, you can also use a two factor authentication on your ssh login.

    Websites have ads, I have ad-blocker.

  • @havoc said:
    The keys thing comes primarily because nobody actually uses 24 char true random.

    I do use passwords like 6oZlqXfveQYLkdjGPz7MECtP (just took this one from the generator with its "default" settings). Currently most of my passwords are about this length.

    Of course something like KeePass is necessary to store them.

    StorageAMD EPYC VDS (ref) up to 4TB NVMe & 10TB SAN disk / Big HDD VPS (ref) from $2.42/TB/month

  • 'Random' passwords are only random when they are generated/crafted.

    Once they are stored in password managers, they are just waiting to be leaked into someone's database/dictionary like other passwords.

    Koofr Cloud Storage: Lifetime Subscription (1TB) for $119.99 with coupon KOOFR40 [aff link]

  • @somik said:
    On a more serious note, what about those ed25519 keys? Why are people recommending them over RSA keys?

    I always thought ed25519 was "better" (it's what I use) so I went down a very tiny rabbit hole, copy/pasta from https://goteleport.com/blog/comparing-ssh-keys/:

    When it comes down to it, the choice is between RSA 2048/4096 and Ed25519 and the trade-off is between performance and compatibility. RSA is universally supported among SSH clients while EdDSA performs much faster and provides the same level of security with significantly smaller keys. Peter Ruppel puts the answer succinctly:

    The short answer to this is: as long as the key strength is good enough for the foreseeable future, it doesn't really matter. Because here we are considering a signature for authentication within an SSH session. The cryptographic strength of the signature just needs to withstand the current, state-of-the-art attacks.

    I also change my SSH port from 22 to whatever shuf -i 49152-65535 -n 1 gives me and use PermitRootLogin without-password (sometimes I need root for stuff that I've been unable to figure out using # usermod -aG sudo Lantern1368) and PasswordAuthentication no in my sshd_config.

    Diceware (using real dice) rules. It's my master password for my really really secure stuff. Yeah I wrote it down at first but once the muscle memory and brain memory kicked in and it became habit, it's in my head and nowhere else.

    Thanked by (2)wankel IAmNix

    Privacy is a human right.

  • @somik said:

    . Changing the port to a 5 digit port is usually enough to protect your server.

    I deem this as security through obscurity.
    Might as well keep the password "password" after that, right?

  • teamaccteamacc OGSenpai

    @somik said:

    @IAmNix said:
    default 4096 bit RSA ssh key: 4096 bit of entropy lol
    The 24 character password RP8E;7-rB='a$emqz[^t6Qx,: 148.04 bits of entropy
    The 64 character password p4@8g'5%>s;f^NnG]VYKZ*2{a[Dh$j+JVh<Z#$94mD(@MT5a.qcu/>!Aaw&3B}8e : 417.24 bits of entropy

    I do not agree with this. I think my ssh root user with password toor is secure enough :p

    On a more serious note, what about those ed25519 keys? Why are people recommending them over RSA keys?

    You should definitely upgrade your password to "hunter2"

    Thanked by (1)Wonder_Woman

    Hey teamacc. You're a dick. (c) Jon Biloh, 2020.

  • somiksomik OG
    edited March 2024

    @localhost said:

    @somik said:

    . Changing the port to a 5 digit port is usually enough to protect your server.

    I deem this as security through obscurity.
    Might as well keep the password "password" after that, right?

    How the hell did you know my server's root password? Now I have to change it... Think I'll change it to password123 :p

    Thanked by (1)localhost

    Websites have ads, I have ad-blocker.

  • edited March 2024

    @allnetstore said:
    Once they are stored in password managers, they are just waiting to be leaked into someones database/dictionary like other passwords.

    No. Password managers are generally safe and you should absolutely use them. Use a long diceware passphrase. Some alternatives I trust and use are Bitwarden and KeepassXC.

    (Password lists mostly come from hacked websites which didn't encrypt users passwords, or bruteforcing/dictionary-attacking weak passwords to decrypt them. All password managers encrypt your password for storage.)

    @Lantern1368 said:
    Diceware (using real dice) rules. It's my master password for my really really secure stuff. Yeah I wrote it down at first but once the muscle memory and brain memory kicked in and it became habit, it's in my head and nowhere else.

    Yeah :). Diceware is cool because it has high entropy, but in a way that is easy for humans to remember. Security People™ consider diceware to be more secure than a "random symbols" password, because you can actually memorize it - and thus don't leave password notes laying around :)

    @somik said:
    Changing the port to a 5 digit port is usually enough to protect your server.

    This is a very good tactic but absolutely not enough.

    @somik said:
    If you want more protection, block root access and use a firewall with your IP whitelisted. If cannot, you can also use a two factor authentication on your ssh login.

    This is good advice :) I suggest using reliable bastion hosts for this purpose - machines with static IP that you ssh -J bastion-host my-server each time. Note that SSH keys are still on your personal computer - the bastion is just an SSH proxy basically.

    @Wonder_Woman said:
    There's also the whole process of how private and public keys work. Your private key, unlike your password, doesn't have to travel over the network.

    Yeah - TIL that the server you SSH to can read your password in plain text. That means that just SSHing to the wrong machine, means you have compromised your password. Super easy mistake - and security is about removing possible compromising mistakes.

    Back to the OP topic: There is plenty of good advice in this thread :) But the benefit of an SSH key is that it is so extremely robust and trusted, that you can basically just setup a SSH key login, disable password login, and then be done.

  • @IAmNix said:

    @allnetstore said:
    Once they are stored in password managers, they are just waiting to be leaked into someones database/dictionary like other passwords.

    No. Password managers are generally safe and you should absolutely use them. Use a long diceware passphrase. Some alternatives I trust and use are Bitwarden and KeepassXC.

    (Password lists mostly come from hacked websites which didn't encrypt users passwords, or bruteforcing/dictionary-attacking weak passwords to decrypt them. All password managers encrypt your password for storage.)

    Careful, apps like Bitwarden and KeypassXC are 100% safe.
    There have been instances where there existed features/bugs allowing for retrieving stored passwords without knowing the masterpassword. (Example: Bitwarden Windows Client last year, masterpassword bypass if someone knew your windows password or something, exploiting the biometrics feature even if it was disabled).

    Every app is vulnerable. It's just a matter of time before someone finds holes in them. Or they add one alongside a new feature (be it unintentional or intentional). After the damage is done, your least problem will be finding the developers and arguing with them.

    Always use 2FA and on a sperate device. Protects you from any online threat. For physical protection your only option is to hire enough bodyguards you can fully trust. To prevent someone from raiding your house and forcing you to hand out everything.

    Me personally I still use Bitwarden, (Vaultwarden, via VPN, login only via YubiKey) + TOTP on a second phone.

  • My 5 char password never get hacked in the past 12 years or maybe 15 years.

    Why would you make everything complicated, maybe you are the one who will be locked by your safety box.

  • JabJab Senpai

    Isn't a key just a longer random password?
    /s

    Haven't bought a single service in VirMach Great Ryzen 2022 - 2023 Flash Sale.
    https://lowendspirit.com/uploads/editor/gi/ippw0lcmqowk.png

  • @IAmNix said:
    Yeah - TIL that the server you SSH to can read your password in plain text. That means that just SSHing to the wrong machine, means you have compromised your password. Super easy mistake - and security is about removing possible compromising mistakes.

    This is exactly why I get totally furious when I see people get the message "Warning: Remote Host Identification Has Changed" and simply continue connecting.
    This is also why I have made it a habit to connect to ip or only use DNS servers I trust, since DNS is pretty easy to hijack.

  • @Jab said:
    Isn't a key just a longer random password?
    /s

    No, but this is a common misconception. If you are using passwords the server must know your password (or a hash thereof) to be able to authenticate you. This means that if the server is compromised so is your password. As linked above, there are ways to get the password in plain text if you control the server.
    When using keys your private key never leaves the client and the server does not have it nor need it. Data encrypted with your public key (which is the key the server have) can only be read by you, the owner of the private key.

    It is two very different ways of authentication, it is not just a long password saved in a file.

    Thanked by (4)wankel Jab skorous IAmNix
  • JabJab Senpai

    @rcy026 said:

    @Jab said:
    Isn't a key just a longer random password?
    /s

    No, but this is a common misconception. If you are using passwords the server must know your password (or a hash thereof) to be able to authenticate you. This means that if the server is compromised so is your password. As linked above, there are ways to get the password in plain text if you control the server.
    When using keys your private key never leaves the client and the server does not have it nor need it. Data encrypted with your public key (which is the key the server have) can only be read by you, the owner of the private key.

    It is two very different ways of authentication, it is not just a long password saved in a file.

    https://www.urbandictionary.com/define.php?term=/S

    Thanked by (1)rcy026

    Haven't bought a single service in VirMach Great Ryzen 2022 - 2023 Flash Sale.
    https://lowendspirit.com/uploads/editor/gi/ippw0lcmqowk.png

  • @rcy026 said:

    @Jab said:
    Isn't a key just a longer random password?
    /s

    No, but this is a common misconception. If you are using passwords the server must know your password (or a hash thereof) to be able to authenticate you. This means that if the server is compromised so is your password. As linked above, there are ways to get the password in plain text if you control the server.
    When using keys your private key never leaves the client and the server does not have it nor need it. Data encrypted with your public key (which is the key the server have) can only be read by you, the owner of the private key.

    It is two very different ways of authentication, it is not just a long password saved in a file.

    Thanks for taking the time to explain the difference, despite the opening clearly marked as sarcasm, for the benefit of the thread starter and future readers of this thread!

    Thanked by (1)IAmNix
  • Currentmonthcurrentyear that's the password if you force people change their password every month. 😆
    If you can, force them use key.

    In many cases it's okay to use a strong password for your own logins if you know what you're doing. It's secure enough if you are ready to wipe your server when it's hacked. If you don't want to wipe your server never, then use key.

    Filen.io - use this link to signup and we both get extra 10GB free.
    https://filen.io/r/4d472d5cdb57f6663621a251065e0b51

  • @Jab said:

    @rcy026 said:

    @Jab said:
    Isn't a key just a longer random password?
    /s

    No, but this is a common misconception. If you are using passwords the server must know your password (or a hash thereof) to be able to authenticate you. This means that if the server is compromised so is your password. As linked above, there are ways to get the password in plain text if you control the server.
    When using keys your private key never leaves the client and the server does not have it nor need it. Data encrypted with your public key (which is the key the server have) can only be read by you, the owner of the private key.

    It is two very different ways of authentication, it is not just a long password saved in a file.

    https://www.urbandictionary.com/define.php?term=/S

    Sorry, completely missed that and did not know about the /s switch. You learn something new every day, thanks. :smile:
    Hopefully my explanation was useful for someone else. :smile:

    Thanked by (1)IAmNix
  • @Jab said:

    @rcy026 said:

    @Jab said:
    Isn't a key just a longer random password?
    /s

    No, but this is a common misconception. If you are using passwords the server must know your password (or a hash thereof) to be able to authenticate you. This means that if the server is compromised so is your password. As linked above, there are ways to get the password in plain text if you control the server.
    When using keys your private key never leaves the client and the server does not have it nor need it. Data encrypted with your public key (which is the key the server have) can only be read by you, the owner of the private key.

    It is two very different ways of authentication, it is not just a long password saved in a file.

    https://www.urbandictionary.com/define.php?term=/S

    So people now a days require to be told that something is sarcasm? Just 15 years back, people would know how to properly use sarcasm and you dont have to tell/flag it so both you and the reader knows it is sarcasm.

    Example:

    Just using a longer password instead. I am sure your server wont get hacked :lol:

    Websites have ads, I have ad-blocker.

  • skorousskorous OGSenpai

    @rcy026 said:

    @Jab said:

    @rcy026 said:

    @Jab said:
    Isn't a key just a longer random password?
    /s

    No, but this is a common misconception. If you are using passwords the server must know your password (or a hash thereof) to be able to authenticate you. This means that if the server is compromised so is your password. As linked above, there are ways to get the password in plain text if you control the server.
    When using keys your private key never leaves the client and the server does not have it nor need it. Data encrypted with your public key (which is the key the server have) can only be read by you, the owner of the private key.

    It is two very different ways of authentication, it is not just a long password saved in a file.

    https://www.urbandictionary.com/define.php?term=/S

    Sorry, completely missed that and did not know about the /s switch. You learn something new every day, thanks. :smile:
    Hopefully my explanation was useful for someone else. :smile:

    I missed it too. This is why I always do it like a proper tag with an open and close around the statement. :P

  • edited March 2024

    IAmNix said:
    [..] the benefit of an SSH key is that it is so extremely robust and trusted, that you can basically just setup a SSH key login, disable password login, and then be done.

    And the recent xz backdoor affecting SSH shows that my advice was flawed, and security is never as simple as a single step :)

  • @somik said: So people now a days require to be told that something is sarcasm? Just 15 years back, people would know how to properly use sarcasm and you dont have to tell/flag it so both you and the reader knows it is sarcasm.

    The Onion fuming af at this comment right now.

  • @AndrewL64 said:

    @somik said: So people now a days require to be told that something is sarcasm? Just 15 years back, people would know how to properly use sarcasm and you dont have to tell/flag it so both you and the reader knows it is sarcasm.

    The Onion fuming af at this comment right now.

    LOL! I guess people are getting dumber just as devices are getting smarter. AI takeover wont be far off now! :lol:

    Websites have ads, I have ad-blocker.

Sign In or Register to comment.