Read or watch:
s explained in the web stack debugging guide concept page, telnet
is a very good tool to check if sockets are open with telnet IP PORT
. For example, if you want to check if port 22
is open on web-02
:
sylvain@ubuntu$ telnet web-02.holberton.online 22
Trying 54.89.38.100...
Connected to web-02.holberton.online.
Escape character is '^]'.
SSH-2.0-OpenSSH_6.6.1p1 Ubuntu-2ubuntu2.8
Protocol mismatch.
Connection closed by foreign host.
sylvain@ubuntu$
We can see for this example that the connection is successful: Connected to web-02.holberton.online
.
Now let’s try connecting to port 2222
:
sylvain@ubuntu$ telnet web-02.holberton.online 2222
Trying 54.89.38.100...
^C
sylvain@ubuntu$
We can see that the connection never succeeds, so after some time I just use ctrl+c
to kill the process.
This can be used not just for this exercise, but for any debugging situation where two pieces of software need to communicate over sockets.
Note that the school network is filtering outgoing connections (via a network-based firewall), so you might not be able to interact with certain ports on servers outside of the school network. To test your work on web-01
, please perform the test from outside of the school network, like from your web-02 server
. If you SSH into your web-02
server, the traffic will be originating from web-02
and not from the school’s network, bypassing the firewall.
Containers on demand cannot be used for this project (Docker container limitation)
Be very careful with firewall rules! For instance, if you ever deny port 22/TCP
and log out of your server, you will not be able to reconnect to your server via SSH
, and we will not be able to recover it. When you install UFW
, port 22
is blocked by default, so you should unblock it immediately before logging out of your server.
0. Block all incoming traffic but
Let’s install the ufw
firewall and setup a few rules on web-01
.
Requirements:
- The requirements below must be applied to
web-01
(feel free to do it onlb-01
andweb-02
, but it won’t be checked) - Configure
ufw
so that it blocks all incoming traffic, except the following TCP ports:22
(SSH)443
(HTTPS SSL)80
(HTTP)
- Share the
ufw
commands that you used in your answer file
Firewalls can not only filter requests, they can also forward them.
Requirements:
- Configure
web-01
so that its firewall redirects port8080/TCP
to port80/TCP
. - Your answer file should be a copy of the
ufw
configuration file that you modified to make this happen Terminal inweb-01
:
root@03-web-01:~# netstat -lpn
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 2473/nginx
tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN 978/sshd
tcp6 0 0 :::80 :::* LISTEN 2473/nginx
tcp6 0 0 :::22 :::* LISTEN 978/sshd
udp 0 0 0.0.0.0:68 0.0.0.0:* 594/dhclient
udp 0 0 0.0.0.0:54432 0.0.0.0:* 594/dhclient
udp6 0 0 :::32563 :::* 594/dhclient
Active UNIX domain sockets (only servers)
Proto RefCnt Flags Type State I-Node PID/Program name Path
unix 2 [ ACC ] SEQPACKET LISTENING 7175 433/systemd-udevd /run/udev/control
unix 2 [ ACC ] STREAM LISTENING 6505 1/init @/com/ubuntu/upstart
unix 2 [ ACC ] STREAM LISTENING 8048 741/dbus-daemon /var/run/dbus/system_bus_socket
unix 2 [ ACC ] STREAM LISTENING 8419 987/acpid /var/run/acpid.socket
root@03-web-01:~#
root@03-web-01:~# grep listen /etc/nginx/sites-enabled/default
listen 80 default_server;
listen [::]:80 default_server ipv6only=on;
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
# listen 8000;
# listen somename:8080;
# listen 443;
root@03-web-01:~#
- My web server
nginx
is only listening on port80
netstat
shows that nothing is listening on8080
Terminal in web-02
:
ubuntu@03-web-02:~$ curl -sI web-01.holberton.online:80
HTTP/1.1 200 OK
Server: nginx/1.4.6 (Ubuntu)
Date: Tue, 07 Mar 2017 02:14:41 GMT
Content-Type: text/html
Content-Length: 612
Last-Modified: Tue, 04 Mar 2014 11:46:45 GMT
Connection: keep-alive
ETag: "5315bd25-264"
Accept-Ranges: bytes
ubuntu@03-web-02:~$ curl -sI web-01.holberton.online:8080
HTTP/1.1 200 OK
Server: nginx/1.4.6 (Ubuntu)
Date: Tue, 07 Mar 2017 02:14:43 GMT
Content-Type: text/html
Content-Length: 612
Last-Modified: Tue, 04 Mar 2014 11:46:45 GMT
Connection: keep-alive
ETag: "5315bd25-264"
Accept-Ranges: bytes
ubuntu@03-web-02:~$
I use curl to query web-01.holberton.online
, and since my firewall is forwarding the ports, I get a HTTP 200
response on port 80/TCP
and also on port 8080/TCP
.