How to open ports in Linux?

We might try to start with the firewall definition which is needed to fulfil understanding of "port-vocabulary". Firewall is software or firmware that enforces a set of rules about what data packets will be allowed to enter or leave a network. It is in charge of managing Allow and Deny rules for ports.

Accordingly to the topic of this guide we would like to open ports in Linux distributions such as Ubuntu or CentOS. Both distros allow to configure it with different set of tools (firewalls packages) but with the same results.

 

Tools that we will be using:

    • UFW

    • Firewalld

 

Let’s have a look at the Ubuntu scenario first:

 

 

This distribution contains preinstalled service UFW(Uncomplicated Firewall) by default. It simplifies the whole configuration and it is user-friendly for every person.

 

Check the service status with standard systemctl command:

$ sudo systemctl status ufw 

 

Enable UFW with enable command:

$ sudo ufw enable

 

Syntax to open specific TCP port:

$ sudo ufw allow (port)/tcp

 

for example:

$ sudo ufw allow 53/tcp

 

Syntax supports also names which reffer to specific ports:

$ sudo ufw allow https

 

To allow incoming tcp and udp packet on port 21, enter:

$ sudo ufw allow 21

 

Example for specific IP Address:

$ sudo ufw allow from 190.34.21.113 to any port

 

Let’s check the configuration:

$ sudo ufw status verbose

 

Command displays a provisional table with three columns:

Explanations:

    • To – describes the particular protocol

    • Action – tells us whether it is allowed or denied

    • From – It says about the source e.g anywhere or one ip address like presented above

 

It’s time for CentOS already:

 

Firewalld is more advanced tool which uses zones in its configuration. They are responsible for taking care of some area, or one “attached” network interface.

 

Firewalld is frontend controller for iptables used to implement persistent network traffic rules.

Let’s take a look for a bunch of commands that elaborate with firewalld.

 

1. Start our service with stardand systemctl command:

$ sudo systemctl start firewalld

 

Enable it:

$ sudo systemctl enable firewalld

 

This command informs us about state of service. It may only display two sentences: “running” or “no running”

$ sudo firewall-cmd --state

 

Default zone is public. In this short tutorial we will not be changing it, but if you would like to then use this commands:

$ sudo firewall-cmd --set-default-zone=work

 

Let’s try to add tcp traffic on port 1112:

$ sudo firewall-cmd --zone=public --add-port=1112/tcp --permanent

 

TO reload and get those changes applied instantly we have to reload the firewalld state.

$ sudo firewall-cmd --reload

 

We may obtain a readable review of our new rule with listing command:

 

 

To allow a ssh connection on specific Ipv4 we have to use syntax with “rich rule”

$ sudo firewall-cmd --zone=public --add-rich-rule 'rule family="ipv4"
source address="192.168.13.44" port port=22 protocol=tcp accept'

That’s the quick tutorial for firewalld.

Hint:

 Firewall is the default package for CentOS to manage incoming and outcoming traffic. If the UFW seems more preferable for you may install those packages too.