this post was submitted on 16 Feb 2024
715 points (97.7% liked)

Programmer Humor

32710 readers
1030 users here now

Post funny things about programming here! (Or just rant about your favourite programming language.)

Rules:

founded 5 years ago
MODERATORS
 
you are viewing a single comment's thread
view the rest of the comments
[–] [email protected] 3 points 11 months ago (4 children)

What is a good firewall that can also block ports published with docker? I'd need it to run on the same host.

[–] [email protected] 3 points 11 months ago (1 children)

Ufw should work, jus ufw block/limit/allow port number

[–] [email protected] 2 points 11 months ago (1 children)

I remember trying with ufw and the docker ports were still open. Iirc I've read somewhere that docker and ufw both use the same underlying software, so ufw cannot block docker (IP tables?)

[–] [email protected] 1 points 11 months ago (1 children)

Hmm, not sure. I know with docker you can "mock" ports for the container, where the port the container sees is different than the port on the system. Maybe you can do something with that?

[–] [email protected] 1 points 11 months ago

I can configure the containers in ways that don't require ports to be published for the real network, but that's always possible. It would still be nice to have a firewall that can block even those containers that try to publish their ports to the whole (real) network.

[–] [email protected] 2 points 11 months ago (2 children)

UFW does work with Docker, but requires some tweaking. IIRC you have to disallow Docker to modify IPTables and then add a rule to forward all traffic to the Docker network of your choice. It's a little finicky but works.

[–] [email protected] 1 points 11 months ago (1 children)

But…why?

Project Calico is designed for segmenting network traffic between kubernetes workloads.

Right tool for the job.

Also if you are a Fortinet shop, supposedly you can manage rules with FortiManager. I haven’t tried that yet but it looks really cool.

[–] [email protected] 1 points 11 months ago

I was specifically talking about Docker+UFW. Of course the possibilities are endless.

[–] [email protected] 1 points 11 months ago (1 children)

Interesting, I might have to read up on that next time. Thanks

[–] tux7350 1 points 11 months ago

I ran into this same situation, this repo helped me solve it.

https://github.com/chaifeng/ufw-docker#solving-ufw-and-docker-issues

[–] Crack0n7uesday 1 points 11 months ago* (last edited 11 months ago) (1 children)

You want a virtual firewall. Is this for profit or just your science project because that's going to change the answer. You might hate me, but I'm still gonna say it, Cisco....

[–] [email protected] 1 points 11 months ago

For my homelab, and I'll only host OSS

[–] [email protected] 1 points 11 months ago (1 children)

Are your Docker containers connecting to the network (eg using ipvlan or macvlan)? The default bridge network driver doesn't expose the container publicly unless you explicitly expose a port. If you don't expose a port, the Docker container is only accessible from the host, not from any other system on the network.

[–] [email protected] 1 points 11 months ago (1 children)

They are Only in my docker bridge networks and have a few published ports

[–] [email protected] 1 points 11 months ago (1 children)

If you don't want the Docker container to be accessible from other systems then just don't publish the port.

[–] [email protected] 1 points 11 months ago

Yeah of course, that's what I'm doing anyways, but the purpose of a firewall would be defense in depth, even is something were to be published, the firewall got it.