Fixing Docker and Firewalld Conflict After Power Outage
If you’re running Docker on a Linux system with firewalld (common on Fedora, CentOS, RHEL), you might encounter a frustrating issue after power outages or unexpected system reboots. Docker containers that were working perfectly suddenly become inaccessible, and you see warnings about “xtables contention” in your logs.
The Problem: Docker Stops Working After Power Fluctuation
After a system reboot due to power issues, you might notice:
- Docker containers are running but not accessible from the network
- Docker daemon logs show warnings like:
dockerd: time="..." level=warning msg="xtables contention detected"
- Manual workarounds involve disabling Docker’s iptables functionality
- You have to manually add firewall rules for every Docker port
Understanding the Root Cause
The issue occurs because both Docker and firewalld try to manage iptables rules, leading to conflicts. When the system reboots unexpectedly, the timing of service startup can cause this contention.
The Temporary (But Problematic) Fix
Many online solutions suggest disabling Docker’s iptables management entirely:
echo '{"iptables": false}' | sudo tee /etc/docker/daemon.json
sudo systemctl restart docker
While this stops the warnings, it creates a new problem: you now have to manually manage all Docker port forwarding through firewalld. Every time you start a new container with exposed ports, you need to add firewall rules manually.
The Permanent Solution: Proper Integration
Instead of disabling iptables, we can configure Docker and firewalld to work together harmoniously.
Step 1: Configure Docker Properly
Update your Docker daemon configuration (/etc/docker/daemon.json
):
{
"iptables": true,
"userland-proxy": false,
"experimental": false
}
Key settings:
"iptables": true
- Allows Docker to manage its own iptables rules"userland-proxy": false
- Reduces resource usage and potential conflicts"experimental": false
- Ensures stability
Step 2: Configure Firewalld for Docker
Configure firewalld to work with Docker by adding the Docker bridge interface to the trusted zone:
# Add Docker bridge to trusted zone
sudo firewall-cmd --permanent --zone=trusted --add-interface=docker0
# Enable masquerading for Docker zone (optional but recommended)
sudo firewall-cmd --permanent --zone=docker --add-masquerade
# Reload firewall configuration
sudo firewall-cmd --reload
Step 3: Restart Docker Service
Apply the changes by restarting Docker:
sudo systemctl restart docker
How This Solution Works
- Docker manages its own iptables rules for container networking and port forwarding
- Firewalld trusts the Docker bridge interface, allowing unrestricted container communication
- No more manual port rules - Docker automatically handles port exposure
- Proper network isolation is maintained while allowing container functionality
Verification Steps
After applying the solution, verify everything is working:
- Check Docker status:
sudo systemctl status docker
- Verify firewalld configuration:
sudo firewall-cmd --zone=trusted --list-all
- Test container accessibility:
# Replace with your container's exposed port curl http://localhost:8080
- Check Docker iptables rules:
sudo iptables-save | grep DOCKER
Benefits of This Approach
- Automatic port management - No manual firewall rules needed
- System stability - Eliminates iptables contention warnings
- Future-proof - New containers work automatically
- Security maintained - Proper network isolation
- No ongoing maintenance - Set it and forget it
Troubleshooting Common Issues
If Docker Fails to Start
Check Docker logs for specific errors:
sudo journalctl -u docker -f
If Containers Still Aren’t Accessible
Verify your Docker network configuration:
docker network ls
docker ps --format "table \t"
Emergency Rollback
If needed, you can temporarily revert to the manual approach:
echo '{"iptables": false}' | sudo tee /etc/docker/daemon.json
sudo systemctl restart docker
Conclusion
Power outages and unexpected reboots don’t have to mean hours of troubleshooting Docker networking issues. By properly configuring the integration between Docker and firewalld, you can ensure your containers remain accessible and your system stays stable.
This solution has been tested on Fedora Linux but should work on any systemd-based distribution using firewalld. The key is allowing both services to do what they do best while preventing conflicts through proper zone configuration.
Have you encountered this issue? Share your experience in the comments below!
This article was written based on real-world troubleshooting experience. If you found it helpful, consider sharing it with others who might be facing similar Docker networking issues.
Did you find this useful?
I'm always happy to help! You can show your support and appreciation by Buying me a coffee (I love coffee!).