In my linux machine, I have 10 network interfaces available like eth0, eth0.67, eth0.70, eth0.97 etc,.
When i run the command nc 160.48.249.170 22
to check, i get like below:
root@icon:~# nc 160.48.249.170 22
SSH-2.0-OpenSSH_8.2
In my system, eth0.97 is having inet as 160.48.249.170
. So here SSH is listening on interface eth0.97.
Similar to above, SSH is listening on all available 10 interfaces. How to disable or enable one particular interface to listen on SSH?
In /etc/ssh/sshd_config
, below was the configuration
#Port 22
#AddressFamily any
#ListenAddress 0.0.0.0
#ListenAddress ::
But i changed as below to listen only one interface and restarted ssh.
#Port 22
#AddressFamily any
ListenAddress 160.48.199.186
#ListenAddress ::
But after above change also, ssh is listening on all interfaces
Best Answer
I would proceed as follows:
Modify your sshd configuration:
/etc/ssh/sshd_config
.ListenAddress
. By default, it's commented out (#ListenAddress
).Configure your Firewall if applicable
Additionally, I would restrict SSH access using the system-firewall, I assume that you use UFW, but this should work with any firewall.
sudo ufw default deny incoming
(Note, that this blocks EVERYTHING, so make sure that you won't lose your connection to the server!)sudo ufw allow OpenSSH on eno0
(Instead ofOpenSSH
you can also use your port, e.g.22
)You could also tinker around with
/etc/host.deny
and/etc/hosts.allow
but I'm not sure if you can define rules on interface level.As I saw, that you already did step 1, and it didn't help you, I'd assume, that you didn't restart ssh correctly. Note that there are two different services:
ssh.service
sshd.service
The "difference" is explained here.
Maybe, there's something messed up. When you check the status of your server, you can see, since when it is running. So make sure, that your server really got restarted. (Note that I have an Alias for
status
tosudo systemctl status
)You can also test your SSH configruation using
sudo sshd -t -f /etc/ssh/sshd_config
. If there is no error, it won't complain and give no output.Edit
I would like to refer here to @Martin's comment. It would be smart to look in
/etc/ssh/sshd_config.d/
for other configuration files that might influence the behavior.Whether the directory is taken into account can be seen from the line
Include /etc/ssh/sshd_config.d/*.conf
(should be at the top) in /etc/ssh/sshd_config. (This should be the default)Note: The path can also be different. For example,
Include /etc/ssh/example/example.conf
would also include this file if the line is in sshd_conf.