zlacker

Ask HN: Is Connecting via SSH Risky?

submitted by atrevb+(OP) on 2026-02-05 03:56:25 | 9 points 16 comments
[source] [links] [go to bottom]

I have been managing websites for a while and usually utilize SSH connections to login to, deploy code to, and otherwise remotely access the hosting servers.

I was recently informed that a client I work with considers that a legal risk.

If the SSH connection is set to disallow passwords and only authorize via SSH keys, how big of a risk is this?

replies(9): >>phren0+31 >>robert+w5 >>rl3+u6 >>verdve+N6 >>speleo+O6 >>tim-td+z8 >>xhanah+E9 >>bigstr+Ag >>_Chief+2D
1. phren0+31[view] [source] 2026-02-05 04:05:53
>>atrevb+(OP)
Compared to what?
replies(2): >>DamonH+d1 >>atrevb+A1
◧◩
2. DamonH+d1[view] [source] [discussion] 2026-02-05 04:08:08
>>phren0+31
Indeed.
◧◩
3. atrevb+A1[view] [source] [discussion] 2026-02-05 04:12:52
>>phren0+31
They seem to be okay w/ only HTTP ports being open on the server (80, 443). They "found that open ports can lead to cyber claims".
replies(2): >>bedige+Y6 >>wolvol+cj
4. robert+w5[view] [source] 2026-02-05 04:57:47
>>atrevb+(OP)
How else would you do it?
replies(1): >>muppet+0f
5. rl3+u6[view] [source] 2026-02-05 05:08:59
>>atrevb+(OP)
Best practices usually call for not exposing the SSH endpoints to the public internet. The principal risk is vulnerabilities in the underlying SSH server implementation. Historically, critical flaws that can compromise you are few and far between. However, these days AI is already starting to become adept at reverse engineering.

If you must, you'd typically use a bastion host that's configured just for the purpose of handing inbound SSH connections, and is locked down to a maximal degree. It then routes SSH traffic to your other machines internally.

I'd argue that model is outdated though, and the prevailing preference is putting SSH behind the firewall on internal networks. Think Wireguard, Tailscale, service meshes, and so on.

With AWS, restricting SSH ports via security groups to just your IP is simple and goes a long way.

replies(1): >>Msurro+8m
6. verdve+N6[view] [source] 2026-02-05 05:12:53
>>atrevb+(OP)
Runs counter to my understanding, I'd ask for clarification and find support material to show your approach is safer.

Treat it as a teaching moment for them

7. speleo+O6[view] [source] 2026-02-05 05:12:57
>>atrevb+(OP)
If your private key has a good passphrase and is suitably encrypted, say with ed25519, then that's probably as good as you can do other than physically going into work and storing everything in your head :-) Politely ask the client to suggest what they consider would be a suitable alternative. I also setup git hooks to prevent accidentally checking in private keys or passwords into git or other version control systems. And if I'm travelling into or from work I also encrypt some stuff just in case I have a problem and the laptop is stolen.
◧◩◪
8. bedige+Y6[view] [source] [discussion] 2026-02-05 05:14:27
>>atrevb+A1
That's like saying that open bottles lead to alcoholism.
9. tim-td+z8[view] [source] 2026-02-05 05:30:21
>>atrevb+(OP)
They probably mean leaving ssh open to all ips. Take a look at your auth failure logs to see the thousands of daily attempts to compromise your server using default passwords. Most of those are low effort and low risk. Sometimes the bots will try password stuffing. Disabling password auth in sshd config is good practice. Fail2ban also helps block repeated attempts like that.

There’s also the risk of a zero day RCE vulnerability in ssh (though I’ve not seen one in the 20 years I’ve been paying attention )

I tend to not expose ssh to the world and log in with some other method to pass the perimeter (VPN, IP whitelist, tailscale) and the ssh from inside.

10. xhanah+E9[view] [source] 2026-02-05 05:39:46
>>atrevb+(OP)
ditto to everything here. If you really want to you can also change the port to something random to avoid bot spam. but you shouldn't have SSH accessible directly from the internet anyway.

If you are using only keys, make sure they are managed, tracked, securely stored and backed up. The last thing you want is to have a machine die that has the only private key for your environment.

◧◩
11. muppet+0f[view] [source] [discussion] 2026-02-05 06:33:36
>>robert+w5
Wireguard and Telnet ;)
12. bigstr+Ag[view] [source] 2026-02-05 06:49:35
>>atrevb+(OP)
SSH is not at all risky if you disable password authentication. There's essentially zero chance that someone guesses your private key, though you might get annoyed with all the login failures spamming your logs. Fail2ban helps with that if you care, though I don't personally bother these days.
◧◩◪
13. wolvol+cj[view] [source] [discussion] 2026-02-05 07:15:12
>>atrevb+A1
"Cyber claims" sounds like someone who doesn't have a clue what they are talking about.

But yeah putting it behind some kind of VPN is advisable if anything because of all the driveby nuisance attacks on ipv4.

◧◩
14. Msurro+8m[view] [source] [discussion] 2026-02-05 07:43:58
>>rl3+u6
But doesn’t your argument that the principal risk [with ssh] is vulnerabilities also apply to the alternatives you say is best practice? Firewalling off ssh (but not http(s)) has the risk of vulns in the FW software. Tailscale, wireguard etc also has the risk of vulns in that software?

So what’s the difference in risk of ssh software vulns and other software vulns?

Also, another point of view is that vulnerabilities are not very high on the risk ladder. Weak passwords, password reuse etc are far greater risks. So, the alternatives to ssh you suggest are all reliant on passwords but ssh, in the case, is based on secure keys and no passwords. Should “best practices” not include this perpective?

replies(1): >>rl3+8p
◧◩◪
15. rl3+8p[view] [source] [discussion] 2026-02-05 08:12:46
>>Msurro+8m
Good defense is layered.

For vulnerabilities, complexity usually equals surface area. WireGuard was created with simplicity in mind.

>So, the alternatives to ssh you suggest are all reliant on passwords but ssh, in the case, is based on secure keys and no passwords.

WireGuard is key-based. I highly suggest reading its whitepaper:

https://www.wireguard.com/papers/wireguard.pdf

16. _Chief+2D[view] [source] 2026-02-05 10:02:42
>>atrevb+(OP)
> If the SSH connection is set to disallow passwords and only authorize via SSH keys, how big of a risk is this

low risk, do this. Keys (ed25519,4096 rsa) are impractical to brute force. However I'd also recommend:

- use a different port than 22 (add your .ssh/config for easier UX if needed) - port 22 can get incredibly noisy with tons of bots probing

- disable passwordAuth, disable PermitRootLogin - use a normal user with sudo for your ssh

- consider a vpn please - I use tailscale, but I hear headscale is good - then use UFW to only allow SSH from the tailscale network (I generally allow all network on tailscale). Tailscale wrote a guide on this here [1]

- do not add and forget authorized_keys from machines you arent using

- I'm especially worried about how people keep giving Clawdbot/Openclaw access to all their machines, key auth means the machine is authorized on your server

- For new servers I often just add all my public keys to them (github lists all your keys at github.com/GH_USERNAME.keys

1: https://tailscale.com/docs/how-to/secure-ubuntu-server-with-...

[go to top]