• Vera (unregistered)

    Another thing the middleware evidently didn't handle: timeouts for processes that take too long to send a query.

  • (nodebb)

    A much more realistic version of this story would have had Frank retired, died, or moved to Australia while his software lived on. And of course he left no documentation, no source code, no nothing with Sally during his brief out-brief. By now Sally too is long gone and nobody even knows Frank's app is still running on some dusty box under a desk someplace.

  • AzureDiamond (unregistered)

    no timeout and crashing instead of killing the oldest connection is crazy even if the limit was like 1000. atp is just a matter of time before a client accidentally dos you

  • AzureDiamond (unregistered)

    no timeout and crashing instead of killing the oldest connection is crazy even if the limit was like 1000. atp is just a matter of time before a client accidentally dos you

  • DQ (unregistered)

    A program that runs for over a decade without issues and only crashes because some idiot uses it wrong? Does anybody have Frank's number? I'ld like to hire him.

  • (nodebb) in reply to DQ

    You mean Edgar. Frank was the person that took the middleware down.

  • Industrial Automation Engineer (unregistered)

    Operations on empty data-sets. If will succeed every time. I had a coworker who was challenged to bring down a validator in the test-environment. There were donuts involved. Developers grinned, they had tested against the most gruesome input strings. long, even longer, quotes, punctuation, even switching codepages. My coworker held up his finger, and after a moment of anticipation brought it down on the ENTER key. << crash >> They had sanitised against all the empty garbage one could input. But not against an empty string.

  • (nodebb)

    This is the real reason I read TDWTF . . . to learn what fsckups I might have in my code. Thanks, Frank.

  • (nodebb)

    One connection per thread, and blocking operations? What the ever-living fuck?

  • (nodebb)

    A TDWTF story with a happy ending! What is this sorcery?

  • (nodebb) in reply to Steve_The_Cynic

    One connection per thread, and blocking operations? What the ever-living fuck?

    This was old software and written in C. Seems obvious to me that he wrote his own listener. I've been teaching people since the mid 90's to have something like Microsoft Transaction Server (before the web days), IIS, Httpd, Node.js, or some other professionally-supported platform host your stuff. Edgar may have been competent, but he wasn't aware of the norms of the world he lived in and didn't use the tools available to him. Sounds like he needed a mentor or some training.

  • (nodebb) in reply to Jaime

    This was old software and written in C.

    So?!? Regardless of when you're writing this, nor of which language you're using, one thread per connection (and one connection per thread...) using blocking sockets has always been (and always will be) a disaster ready to happen. Properly structured code with non-blocking sockets (thread pool optional, and necessary only for handling more volume of simultaneous requests) really isn't hard, except for a few fiddly details about timers, especially about what happens if you cancel one when it's ready to tell you it has expired. Hint: the fine(1) folks who built boost::asio got those details almost as totally wrong as is conceivable.

    Sounds like he needed a mentor or some training.

    Indeed, and I'll admit to having had a very good mentor when I was learning about this stuff.

    (1) As usual, if I use this adjective when talking about people, it's hiding a fairly profound, and definitely unprintable, insult.

  • Kotarak (unregistered) in reply to Steve_The_Cynic

    Dude. This code was written waaaay before you were born. Back then Apache spawned a new process for each connection, let alone a new thread.

  • DQ (unregistered) in reply to miniragnarok

    You assume I like my work...

  • GreatGobo (unregistered)

    I have been John more than once...

    Once to add TSL 1.2 encryption to a C program developed in an odd framework that connected our Mainframe backend with Lotus Notes. The C compiler and framework was some old IBM think that went end of life in 1998 and did not work on anything but 32 bit machines.. This was in 2019.. Program still runs today, and we passed the security audit.

  • Duston (unregistered)

    "using blocking sockets" My guess is you're assuming they're using TCP/IP as the transport. Where I worked, we didn't get TN3270 support on the mainframe until 2003.

  • Tgape (unregistered) in reply to WTFGuy

    I respectfully disagree. While it's common to find the perpetrator to have passed on already, it's not unheard of for it to be someone still around. When there are multiple perpetrators in a story, it becomes increasingly likely that at least one is still around.

    It does feel like we have a highly streamlined troubleshooting story here, but that's usually the way these go. There isn't enough room in the editor buffer for anyone to write up a typical multi-perpetrator troubleshooting story. There's not even enough room for just the finger pointing of one of those stories in the shortest case, that is when none of the perpetrators are around to add their own finger pointing attempts.

Leave a comment on “The Middle(ware) Child”

Log In or post as a guest

Replying to comment #682183:

« Return to Article