My roommate had a server running in our living room for a few months now. I became skeptical about how much it was actually being used, so I decided to check out the /var/log/auth.log file and count logins. After filtering out all the cron jobs, I immediately noticed a few suspicious lines:
May 2 18:56:29 Mc-server sshd[27075]: Invalid user angela from 58.30.236.115
May 2 18:56:29 Mc-server sshd[27075]: pam_unix(sshd:auth): check pass; user unknown
May 2 18:56:29 Mc-server sshd[27075]: pam_unix(sshd:auth): authentication failure; logname= uid=0 euid=0 tty=ssh ruser= rhost=58.30.236.115
May 2 18:56:30 Mc-server sshd[27075]: Failed password for invalid user angela from 58.30.236.115 port 58943 ssh2
Ok, um, I don't know of any Angelas who live in my house. Sketchy. I ran GeoIP on the IP address, and guess what? It's Chinese! Unless my roommate has more international connections than I suspected, this is quite unusual.
grep /var/log/auth.log 58.30.236.115 | wc
3807 52210 440164
Huh. Now we're talking about a small password cracking attempt. It turns out that we actually were attacked four times within a 24-hour period. Our logs only date back two days (they were cluttered with CRON entries), so we really don't know what happened before that.
Attack 1
06:16:01 to 06:34:42
From 119.161.145.206
20 attacks against 'root'
212 attacks against other accounts
Attack 2
09:09:26 to 09:10:25
From 125.208.5.78
11 attacks against 'root'
4 attacks against other accounts
Attack 3
17:10:09 to 18:56:30
From 58.30.236.115
576 attacks against 'root'
900 attacks against other accounts
Attack 4
22:49:55
from 125.88.105.43
A single attack without a valid authentication string. Perhaps trying to exploit some old vulnerability?
SUMMARY:
* A total of 1703 attempted logins
* 607 attempts made against 'root'
* 166 attempts made against 'admin'
* The other 930 attacks were made against 531 usernames that appear to have been chosen from English dictionaries
* They never correctly guessed an active username on the system (other than root and some common system names).
Just for good measure, in the end we brought the system offline and checked for any malware/rootkits. To no surprise, nothing suspicious was found.
So why did this happen to us? When the SSH server was setup it was put on the default port 22. This is just asking for trouble. Never ever do this. While we do not believe the system was ever compromised its just an invitation for problems.
What else do you learn from this? (#1) By default there is no notification system to warn you of suspicious activity. A cron job would be an easy fix. (#2) Never give default system accounts (especially "root") SSH access. This is the biggest target. (#3) Don't use port 22, or other common service ports, if practical.
Of course, there are far more things you can do to protect your SSH servers. These suggestions really only graze the surface and should get you started on a better configuration for your servers.