I thought I had fixed the IPv6 connectivity issues on ComSSA's IRC server, as I was
happily connected from a local shell on the server. Yesterday, when trying to
connect from a Linux box at home, I realised that connections from external
addresses were timing out — even though
netstat showed Hybrid was
listening properly on both addresses! I suppose it was time to dig a little
deeper. What could go wrong?
It turned out, to my surprise, that we were running Hybrid 7.2.2, the same version provided by Debian Wheezy at the moment. The latest upstream version as of today is 8.1.13, so I took the route of trying to compile that to see if the IPv6 problems were addressed in the many versions between.
After wrangling around a bit with a broken installation that had an inconsistent directory layout, reading INSTALL a second time, and realising that you must set a specific prefix for autoconf that isn't the default, I got it working. Hybrid 8 is, as you would expect, a major change from version 7, and sadly that meant I had to rewrite the configuration file from scratch, with a bit of hunting to find the new equivalents of changed directives.
./configure --prefix=/usr/local/ircd make -j4 make install chown -Rv irc:irc /usr/local/ircd/etc /usr/local/ircd/var
I was finally, for the first time, able to connect from home over both IPv4 and IPv6. With that preliminary testing on an alternate port range done, ensuring that the server linking worked, and that the new IRCd did indeed fix the problem, I swapped it in.
This time, I was as careful as I could to minimise downtime with consecutive executions of the old and new init scripts. I had learned the hard way only a day earlier that stopping the server, frantically messing with configuration files, then starting a new daemon is a bad idea, and definitely annoys users.
nano /usr/local/ircd/etc/ircd.conf # change listening ports from 1666x to 666x /etc/init.d/ircd-hybrid stop && ./ircd reload
Immediately afterwards, I had to leave for several hours to help with renovations. Then I came back at the end of the day, feeling completely deflated upon seeing that the same symptoms had resurfaced. I tried adding another, higher range of ports to concurrently listen on, and they, like the testing port range, worked. The lower, normal IRC ports continued to time out external connections over IPv6.
$ for i in 22.214.171.124 2001:470:7c85::1; do for j in 36669 6669; do > nc -vvz $i $j; done; done # note: using netcat-openbsd not netcat-traditional Connection to 126.96.36.199 36669 port [tcp/*] succeeded! Connection to 188.8.131.52 6669 port [tcp/*] succeeded! Connection to 2001:470:7c85::1 36669 port [tcp/*] succeeded! nc: connect to 2001:470:7c85::1 port 6669 (tcp) failed: Connection timed out
That had me stumped. Surely Hurricane Electric wouldn't resort to the
practice of blocking common ports of "vulnerable" services like SMTP and IRC? I
avoided that troubling idea and looked for other options. A few hours later,
I couldn't let go of the thought that the tunnel was indeed the point of
failure. If a service is shown as listening on
netcat would almost always work?
At the lowest point in my essentially fruitless troubleshooting efforts, I
actually pulled up a terminal to watch
strace output of the
running daemon, and noticed that no connection was being seen on the side of
the IRC server, when a normal IRC port over IPv6 was attempted. One thing I did
notice is that the latest version of Hybrid still has the bug where listening
on both wildcard addresses (
::) will have
the second one fail with
EADDRINUSE. I suppose I could dig into
the source, and report a bug if necessary.
Searching for answers, I found some confused and perhaps irate users, which led me to an official source on the matter, confirming my suspicions. Due to past abuse and attacks, tunnels need to be on an IPv6 Sage certified Tunnelbroker account to have common IRC ports unblocked. Fancy terminology aside, this essentially means filling out a few dozen technical quiz questions about IPv6 provided by Hurricane Electric in what I'd imagine is an advocacy effort to increase awareness of the protocol among technical users.
Already having completed the IPv6 Sage process on my personal account, doing
so again was a breeze. Sadly I rushed into destroying and creating a new
tunnel, assuming it was necessary, before realising that there is an explicit
opt-in required in the advanced tunnel configuration. As such, the address of
ling.comssa.org.au has changed from
Full of regret at wasting so many hours compiling and configuring Hybrid 8, I yielded and swapped the server back to its initial configuration and into the warm, comforting realm of the official Debian package. My sole consolation is in the fact that ComSSA's IRC server is now truly dual stack.
While I've definitely learned a lot over the last two days, especially in the field of setting up and running Hybrid, the biggest lessons here are actually to stop rushing, think about all of the components that could possibly be involved, and avoid tying yourself so tightly to one "solution" that you spend days solving a problem that should take hours at most.