I'm trying to get just port 80, 443 and SSH open on my Ubuntu VM. I'm running Docker which I think is what is causing port 21 and 5222 to be visible.
telnet HOST 21
Trying HOST...
Connected to HOST.
Escape character is '^]'.
sudo iptables --list --line-numbers -v
Chain INPUT (policy DROP 23 packets, 1878 bytes)
num pkts bytes target prot opt in out source destination
1 2013 350K ACCEPT all -- lo any anywhere anywhere
2 1063 614K ACCEPT all -- any any anywhere anywhere ctstate RELATED,ESTABLISHED
3 0 0 DROP all -- any any anywhere anywhere ctstate INVALID
4 1 60 ACCEPT tcp -- any any anywhere anywhere tcp dpt:ssh ctstate NEW,ESTABLISHED
5 28 1644 ACCEPT tcp -- any any anywhere anywhere multiport dports http,https ctstate NEW,ESTABLISHED
Chain FORWARD (policy DROP 0 packets, 0 bytes)
num pkts bytes target prot opt in out source destination
1 0 0 DOCKER-USER all -- any any anywhere anywhere
Chain OUTPUT (policy ACCEPT 43 packets, 3082 bytes)
num pkts bytes target prot opt in out source destination
1 2013 350K ACCEPT all -- any lo anywhere anywhere
2 816 236K ACCEPT all -- any any anywhere anywhere ctstate ESTABLISHED
3 0 0 ACCEPT tcp -- any any anywhere anywhere tcp spt:ssh ctstate ESTABLISHED
4 0 0 ACCEPT tcp -- any any anywhere anywhere multiport dports http,https ctstate ESTABLISHED
Chain DOCKER-USER (1 references)
num pkts bytes target prot opt in out source destination
1 0 0 RETURN all -- any any anywhere anywhere
sudo iptables-save
# Generated by iptables-save v1.6.1 on Sun Mar 3 05:57:34 2019
*nat
:PREROUTING ACCEPT [286:14463]
:INPUT ACCEPT [29:1704]
:OUTPUT ACCEPT [273:16843]
:POSTROUTING ACCEPT [273:16843]
:DOCKER - [0:0]
COMMIT
# Completed on Sun Mar 3 05:57:34 2019
# Generated by iptables-save v1.6.1 on Sun Mar 3 05:57:34 2019
*filter
:INPUT DROP [23:1878]
:FORWARD DROP [0:0]
:OUTPUT ACCEPT [43:3082]
:DOCKER-USER - [0:0]
-A INPUT -i lo -j ACCEPT
-A INPUT -m conntrack --ctstate RELATED,ESTABLISHED -j ACCEPT
-A INPUT -m conntrack --ctstate INVALID -j DROP
-A INPUT -p tcp -m tcp --dport 22 -m conntrack --ctstate NEW,ESTABLISHED -j ACCEPT
-A INPUT -p tcp -m multiport --dports 80,443 -m conntrack --ctstate NEW,ESTABLISHED -j ACCEPT
-A FORWARD -j DOCKER-USER
-A OUTPUT -o lo -j ACCEPT
-A OUTPUT -m conntrack --ctstate ESTABLISHED -j ACCEPT
-A OUTPUT -p tcp -m tcp --sport 22 -m conntrack --ctstate ESTABLISHED -j ACCEPT
-A OUTPUT -p tcp -m multiport --dports 80,443 -m conntrack --ctstate ESTABLISHED -j ACCEPT
-A DOCKER-USER -j RETURN
COMMIT
# Completed on Sun Mar 3 05:57:34 2019
# Generated by iptables-save v1.6.1 on Sun Mar 3 05:57:34 2019
*mangle
:PREROUTING ACCEPT [3829:1086443]
:INPUT ACCEPT [3617:1077407]
:FORWARD ACCEPT [0:0]
:OUTPUT ACCEPT [3380:702245]
:POSTROUTING ACCEPT [3380:702245]
COMMIT
# Completed on Sun Mar 3 05:57:34 2019
I've disabled docker service on startup and disabled it modifying iptables (but it still inserts DOCKER-USER).
Why can I still telnet to port 21 and 5222?