Introducing Netshoot: A Powerful Network Troubleshooting Tool for Docker
Networking issues can be a real headache, especially when dealing with containerized applications. Whether it’s latency, routing problems, DNS resolution, firewall issues, or incomplete ARPs, network problems can significantly degrade application performance. Fortunately, there’s a powerful tool that can help you troubleshoot and resolve these issues: netshoot.
What is Netshoot?
Netshoot is a Docker container equipped with a comprehensive set of networking troubleshooting tools. It’s designed to help you diagnose and fix Docker and Kubernetes networking issues. With a proper understanding of how Docker and Kubernetes networking works and the right tools, you can troubleshoot and resolve these networking issues more effectively.
Understanding Network Namespaces
Before diving into the usage of netshoot, it’s essential to understand a key concept: Network Namespaces. Network namespaces provide isolation of the system resources associated with networking. Docker uses network and other types of namespaces (pid,mount,user, etc.) to create an isolated environment for each container. Everything from interfaces, routes, and IPs is completely isolated within the network namespace of the container.
The cool thing about namespaces is that you can switch between them. You can enter a different container’s network namespace, perform some troubleshooting on its network stack with tools that aren’t even installed on that container. Additionally, netshoot can be used to troubleshoot the host itself by using the host’s network namespace. This allows you to perform any troubleshooting without installing any new packages directly on the host or your application’s package.
Using Netshoot with Docker
Container’s Network Namespace
If you’re having networking issues with your application’s container, you can launch netshoot with that container’s network namespace like this:
$ sudo docker run -it --net container:<container_name> nicolaka/netshoot
Host’s Network Namespace
If you think the networking issue is on the host itself, you can launch netshoot with that host’s network namespace:
$ sudo docker run -it --net host nicolaka/netshoot
Network’s Network Namespace
If you want to troubleshoot a Docker network, you can enter the network’s namespace using nsenter. This is explained in the nsenter section below.
Using Netshoot with Docker Compose
You can easily deploy netshoot using Docker Compose using something like this:
version: "3.6" services: tcpdump: image: nicolaka/netshoot depends_on: - nginx command: tcpdump -i eth0 -w /data/nginx.pcap network_mode: service:nginx volumes: - $PWD/data:/data nginx: image: nginx:alpine ports: - 80:80
Included Packages
Netshoot includes a wide range of powerful tools for network troubleshooting. Here’s a list of the included packages along with a brief description of each:
- apache2-utils: Utilities for web server benchmarking and server status monitoring.
- bash: A popular Unix shell.
- bind-tools: Tools for querying DNS servers.
- bird: Internet routing daemon.
- bridge-utils: Utilities for configuring the Linux Ethernet bridge.
- busybox-extras: Provides several stripped-down Unix tools in a single executable.
- conntrack-tools: Tools for managing connection tracking records.
- curl: Tool for transferring data with URL syntax.
- dhcping: Tool to send DHCP requests to DHCP servers.
- drill: Tool similar to dig.
- ethtool: Tool for displaying and changing NIC settings.
- file: Tool to determine the type of a file.
- fping: Tool to ping multiple hosts.
- grpcurl: Command-line tool for interacting with gRPC servers.
- iftop: Displays bandwidth usage on an interface.
- iperf: Tool for measuring TCP and UDP bandwidth performance.
- iperf3: A newer version of iperf.
- iproute2: Collection of utilities for controlling TCP/IP networking.
- ipset: Tool to manage IP sets.
- iptables: User-space utility program for configuring the IP packet filter rules.
- iptraf-ng: Network monitoring tool.
- iputils: Set of small useful utilities for Linux networking.
- ipvsadm: Utility to administer the IP Virtual Server services.
- jq: Lightweight and flexible command-line JSON processor.
- libc6-compat: Compatibility libraries for glibc.
- liboping: C library to generate ICMP echo requests.
- ltrace: A library call tracer.
- mtr: Network diagnostic tool.
- net-snmp-tools: Set of SNMP management tools.
- netcat-openbsd: Networking tool known as the “Swiss army knife” of networking.
- nftables: Successor to iptables.
- ngrep: Network packet analyzer.
- nmap: Network exploration tool and security scanner.
- nmap-nping: Packet generation and response analysis tool.
- nmap-scripts: Scripts for nmap.
- openssl: Toolkit for the Transport Layer Security (TLS) and Secure Sockets Layer (SSL) protocols.
- py3-pip: Package installer for Python.
- py3-setuptools: Python Distutils Enhancements.
- scapy: Packet manipulation tool.
- socat: Relay for bidirectional data transfer.
- speedtest-cli: Command-line interface for testing internet bandwidth.
- openssh: OpenSSH client and server.
- strace: System call tracer.
- tcpdump: Packet analyzer.
- tcptraceroute: Traceroute implementation using TCP packets.
- tshark: Network protocol analyzer.
- util-linux: Miscellaneous system utilities.
- vim: Highly configurable text editor.
- git: Distributed version control system.
- zsh: Unix shell.
- websocat: Simple WebSocket client.
- swaks: Swiss Army Knife for SMTP.
- perl-crypt-ssleay: Perl module for OpenSSL.
- perl-net-ssleay: Perl module for using OpenSSL.
With this extensive set of tools, netshoot is a powerful ally in diagnosing and resolving network issues in your Docker and Kubernetes environments. Whether you’re dealing with latency, routing problems, DNS resolution, firewall issues, or incomplete ARPs, netshoot has the tools you need to troubleshoot and fix these issues.
If you’re interested in trying out netshoot for yourself, you can find the project on GitHub at https://github.com/nicolaka/netshoot. It’s a powerful tool that can help you troubleshoot and resolve network issues in your Docker and Kubernetes environments.
Serving Static Files with Docker and Darkhttpd
In this blog post, we’ll explore how to use Docker and the lightweight HTTP server, Darkhttpd, to serve static files. This setup is particularly useful when you need a simple web server for sharing files or hosting a static website. We’ll also discuss how to use a reverse proxy like Traefik to route external traffic to the Darkhttpd service.
Docker Compose Configuration
Below is the docker-compose.yml file that defines the Darkhttpd service:
version: '3.3' services: darkhttpd: image: p3terx/darkhttpd container_name: darkhttpd restart: unless-stopped volumes: - './site:/www:ro' entrypoint: ["/darkhttpd","/www"] networks: your_network: ipv4_address: your_ipv4_address networks: your_network: external: name: your_network_name
Here’s a brief overview of the configuration:
- The image field specifies the Docker image to use for the service.
- The container_name field sets the name of the container.
- The restart field configures the restart policy for the container.
- The volumes field defines the volume mounts for the service.
- The entrypoint field overrides the default entrypoint of the image.
- The networks field specifies the networks that the service is connected to.
Setting Up the Service
- Create a directory named site in the same directory as the docker-compose.yml file. Place the static files you want to serve in this directory.
- Replace your_network, your_ipv4_address, and your_network_name in the docker-compose.yml file with the appropriate values for your setup.
- Run the following command to start the Darkhttpd service:
docker-compose up -d
- Access the static files by navigating to the IP address specified in the docker-compose.yml file.
Using a Reverse Proxy
To route external traffic to the Darkhttpd service, you can use a reverse proxy like Traefik. Configure the reverse proxy to forward requests to the IP address specified in the docker-compose.yml file.
Conclusion
Using Docker and Darkhttpd to serve static files is a simple and efficient solution for sharing files or hosting a static website. By adding a reverse proxy, you can easily route external traffic to the Darkhttpd service. This setup is ideal for scenarios where you need a lightweight web server without the overhead of a full-fledged web server like Apache or Nginx.
Enhancing SSH Security with StealthSSHAccess
In today’s interconnected world, maintaining the security of your server infrastructure is paramount. One critical point of vulnerability is the SSH (Secure Shell) service, which allows remote administration of servers. Despite using a non-default port, many administrators still find their servers bombarded with brute-force and denial-of-service attacks. To address this challenge, I’ve developed a solution called StealthSSHAccess.
The Problem
Attackers often employ brute force attacks to gain unauthorized access to servers via SSH. Even if you’ve changed the default SSH port, determined attackers can still discover the new port and target it. These attacks can lead to service disruption, unauthorized data access, and potential breaches of sensitive information.
The Solution: StealthSSHAccess
StealthSSHAccess is an innovative approach to managing remote SSH access while mitigating the risks associated with brute-force attacks. Let’s delve into how it works and why it’s an effective solution:
Dynamic Access Control
StealthSSHAccess takes a dynamic and personalized approach to SSH access control. It operates as a smart gateway between potential attackers and your SSH service. Here’s a simplified breakdown of how it functions:
- Monitoring for Intent: Instead of directly exposing the SSH port, StealthSSHAccess monitors a non-SSH TCP port for connection attempts. Attackers, unaware of this, can’t target the SSH port directly.
- Capture and Response: When an attempt is made on the monitored port, StealthSSHAccess captures the IP address of the requester. This initial connection attempt fails, serving as a signal of intent to access SSH.
- Secure Access Window: Based on this signal, StealthSSHAccess temporarily opens the SSH port exclusively for the captured IP address. This allows for a secure connection from that specific source.
- Time-Bound Access: Access is granted for a predetermined duration. If SSH access isn’t established within this timeframe, the port is automatically closed for that specific IP. This tightens the window of exposure and bolsters security.
- Automatic Closure: If the port remains unused during the allowed time, StealthSSHAccess automatically revokes access and closes the port. A continuous monitoring mechanism controls this process.
Benefits and Features
1. Enhanced Security: By hiding the SSH port from attackers, StealthSSHAccess reduces the attack surface and minimizes exposure to potential threats.
2. Selective Accessibility: With StealthSSHAccess, you control who gains access by simply attempting a connection to a specific port. This provides an additional layer of security.
3. Minimal Configuration: Implementing StealthSSHAccess is easy thanks to its Docker-based deployment. This means you can integrate it seamlessly into your existing system.
4. Persistence Across Restarts: StealthSSHAccess ensures continuity by persisting IP timer information across service interruptions or restarts. This keeps the system aware of pending access requests.
Getting Started with StealthSSHAccess
To deploy StealthSSHAccess, follow these steps:
- Requirements: Ensure you have Docker and Docker Compose installed.
- Configuration: Set up environment variables using the provided .env file. Customize parameters like LOGLEVEL, IFACE, PORT_TO_MONITOR, and more to match your environment.
- Building and Running: Build the images using docker-compose build, and then launch the services with docker-compose up -d.
- Data Persistence: IP timer data is stored in the ./data directory, so make sure it’s writable by the Docker user.
- Security Note: Be aware that these services run with privileged access due to their interaction with the system’s network configuration. Understand the security implications before deployment.
Conclusion
In the ongoing battle against cybersecurity threats, StealthSSHAccess stands as a beacon of innovative protection for your servers. By intelligently managing SSH access and responding dynamically to legitimate requests, this solution offers heightened security without sacrificing convenience. Whether you’re an administrator or a security-conscious user, consider integrating StealthSSHAccess into your infrastructure to safeguard your servers from the persistent threats of the digital landscape.
To explore the project, access the source code, and learn more about its implementation, visit the StealthSSHAccess GitHub repository. Remember, security is a journey, and with StealthSSHAccess, you’re taking a proactive step toward a more resilient and secure server environment.
Implementing Per-Domain DNS Configuration in macOS Using Resolver Configuration Files
In macOS, managing network traffic is essential for a robust and secure IT infrastructure. The operating system allows users to have a granular level of control over Domain Name System (DNS) settings, improving network functionality. Today’s post will walk through setting up per-domain DNS configuration on macOS using resolver configuration files.
Adding a DNS Rule Per Domain
MacOS has a powerful feature that allows you to specify DNS servers for individual domains. This is accomplished by creating resolver configuration files in the /etc/resolver/ directory. Each file in this directory corresponds to a domain and specifies the DNS servers to be used for that domain.
Let’s add a DNS rule for the “ymbihq.local” domain:
- Open Terminal.
- Use the sudo command to create a new file in the /etc/resolver/ directory with the same name as your domain:
sudo bash -c 'echo "nameserver 10.0.0.1" > /etc/resolver/ymbihq.local'
This command will create a new resolver file named ymbihq.local and adds a line specifying 10.0.0.1 as the nameserver. As a result, all DNS queries for “ymbihq.local” will be resolved by the DNS server at the IP address 10.0.0.1.
Reviewing DNS Rules
To verify that the resolver configuration file was created successfully and to review its content, use the cat command:
cat /etc/resolver/ymbihq.local
This will output the contents of the ymbihq.local file, which should look like this:
# Sample output:
nameserver 10.0.0.1
This confirms that the DNS server for the “ymbihq.local” domain has been set to 10.0.0.1.
Removing a DNS Rule
If you need to remove a DNS rule, you can simply delete the corresponding resolver configuration file. Use the rm command for this:
sudo rm /etc/resolver/ymbihq.local
After running this command, your macOS system will no longer have a custom DNS server set for the “ymbihq.local” domain, and it will default to using your standard DNS servers.
By creating and managing resolver configuration files, you can precisely control your DNS settings on a per-domain basis. This powerful feature of macOS allows you to optimize your network to fit your specific needs.
Implementing Per-Domain DNS Configuration in Windows Using PowerShell
The subtitle could be something like: Mastering DNS Client NRPT Rules with PowerShell
In today’s post, we will be looking at a compact, but powerful, the chunk of PowerShell code that allows us to interact with DNS Client Name Resolution Policy Table (NRPT) rules on a Windows machine. The commands in this code allow us to add, review, and remove rules, giving us control over the direction of our DNS traffic.
Adding a DNS Client NRPT Rule
Let’s take a look at the first command:
# add a Windows rule for ymbihq.local domain
Add-DnsClientNrptRule -Namespace ".ymbihq.local" -NameServers "10.0.0.1"
This command uses the Add-DnsClientNrptRule cmdlet to add a new rule for the “.ymbihq.local” namespace. The -Namespace parameter specifies the domain name for the rule, and the -NameServers parameter specifies the IP address of the DNS server that should be used for queries within this namespace.
In this instance, we’re setting a rule for any DNS queries under the “.ymbihq.local” domain to be resolved by the DNS server at the IP address 10.0.0.1. This can be especially useful in an enterprise environment where you have custom internal domains to be resolved by specific DNS servers.
Reviewing DNS Client NRPT Rules
After adding a rule, it’s essential to verify it. We can do this using the Get-DnsClientNrptRule command:
# get the list of rules<br><code>Get-DnsClientNrptRule
This command lists all the NRPT rules currently set on the machine. It will output the unique identifiers, names, namespaces, and other details for each rule. Here’s a sample output:
# Sample output:
Name : {A7CCF814-7492-4019-9FB1-27F61327AE93}
Version : 2
Namespace : {.ymbihq.local}
IPsecCARestriction :
DirectAccessDnsServers :
DirectAccessEnabled : False
DirectAccessProxyType :
DirectAccessProxyName :
DirectAccessQueryIPsecEncryption :
DirectAccessQueryIPsecRequired :
NameServers : 10.0.0.1
DnsSecEnabled : False
DnsSecQueryIPsecEncryption :
DnsSecQueryIPsecRequired :
DnsSecValidationRequired :
NameEncoding : Disable
DisplayName :
Comment :
From this output, you can see various properties of the rule we’ve just added for the “.ymbihq.local” namespace, such as its unique identifier (Name) and the nameserver it’s associated with (NameServers).
Removing a DNS Client NRPT Rule
The final part of this block of code is dedicated to rule removal:
# remove the rule
Remove-DnsClientNrptRule -Name "{A7CCF814-7492-4019-9FB1-27F61327AE93}"
Here, we use the Remove-DnsClientNrptRule cmdlet with the -Name parameter followed by the unique identifier of the rule we wish to remove. After running this command, PowerShell will prompt you for confirmation before deleting the rule.
The process looks like this:
Confirm
Removing NRPT rule for namespace .ymbihq.local with
DAEnable: Disabled,
DnsSecValidationRequired: Disabled,
NameEncoding: Disable
NameServers: 10.0.0.1
Do you want to continue?
[Y] Yes [N] No
Avui ja n’he fet 20
Aprofito aquesta entrada per comentar una nova efemèride s’ha produït avui mateix. Ja que després de 46 anys menys dos dies he visitat de nou l’hospital on vaig néixer. Aquest cop per fer-me unes radiografies a les cervicals. Qui ho havia de dir?