Date: Tue, 19 Jan 2010 09:52:15 +0000 From: Daniel Bye <freebsd-questions@slightlystrange.org> To: freebsd-questions@freebsd.org Subject: Re: /etc/hosts.deniedssh Message-ID: <20100119095215.GJ3611@catflap.slightlystrange.org> In-Reply-To: <201001190222.03539.oloringr@gmail.com> References: <201001182239.20153.david@vizion2000.net> <201001190222.03539.oloringr@gmail.com>
next in thread | previous in thread | raw e-mail | index | archive | help
On Tue, Jan 19, 2010 at 02:22:03AM +0200, Ed Jobs wrote: > On Tuesday 19 January 2010 00:39, David Southwell wrote: > > Examples from hosts.deniedssh > > I seem to be on the receiving end of a concerted series of unsuccessful > > break in attacks on one of our systems. One small part of the attack > has > > resulted in over 2000 entries in our hosts.deniedssh file in less than 1 > > hour. > > > > I would be interested in any comments on the small example shown > below and > > any advice. > > > > Thanks in advance > > > > David > <snip> > > 2k entries are too much indeed. Really? wc -l /etc/hosts.deniedssh 12476 /etc/hosts.deniedssh Unless you mean specifically that a couple thousand in an hour is a lot, which I'd agree with, but wouldn't necessarily worry about it. > are you running ssh on port 22? > if yes, (and your users are ok with it) you can change it to another port. No, don't do that. Instead, consider using public key authentication and disabling password authentication. There are also various settings you can tweak to control the number of unsuccessful login attempts you are prepared to tolerate from an address in a predefined interval. sshd_config(5) will show you the way. Additionally, put all your permitted ssh users in a new group, and set the sshd config option AllowGroups. Better yet, as others have suggested, filter with a firewall - if you use pf, you can leverage your /etc/hosts.deniedssh file by using it to populate a pf table. You will need to configure DenyHosts to not resolve ip addresses, and then you can put these in /etc/pf.conf: table <denyhosts> persist file "/etc/hosts.deniedssh" block in log quick on $ext_if from <denyhosts> to any (Be sure to put these in suitable places. I don't have examples of using ipf or ipfw, but I'm sure they can handle it just as well.) DenyHosts provides a plugin system that allows you to run an arbitrary command upon addition or purging of an address. I use it to reload my pf <denyhosts> table so I can be reasonably sure that the firewall's opinion of whom to block is congruent with what DenyHosts thinks. A simple `pfctl -t denyhosts -T reload -f /etc/hosts.deniedssh' should be sufficient in either case, but you can get as fancy as you like. > or maybe, temporary disable ssh login and use cron to enable it again in > some time in the future. I would recommend against this, on the grounds that there may be a real administrative need to connect to the server during this dark period. With no ssh service until cron does its thing, you have no way of getting in, which makes me far more nervous than people knocking at my ssh port... Dan -- Daniel Bye _ ASCII ribbon campaign ( ) - against HTML, vCards and X - proprietary attachments in e-mail / \
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20100119095215.GJ3611>