Hacker Newsnew | past | comments | ask | show | jobs | submitlogin

This is amazing! Please never ever use it in production.


I propose that developers are allowed to use it in production... so long as they do all the development work on a 9600 baud dialup with a VT102.


A few years ago, a submarine cable was knocked out, between our startup's MVP servers in Singapore AWS, and our networked factory stations in Asia.

In lieu of the submarine cable, something closer to a wet string was being routed over. It had such high latency and packet loss, that a watchdog timer I'd implemented on the stations was timing out.

Fortunately, the remote access we'd built into our stations (SSH and OpenVPN) still worked, albeit at slow speeds, like a 300 baud dialup, and crazy-high latency.

Having occasionally dealt with performance a bit like that as a kid, and knowing my way around Linux, it was like "I've been training my whole life for this moment."

So I just flexed the old command-line-and-editor-when-you-feel-every-byte-transmitted skill, and got the stations working, before the factory even knew about the submarine cable, saving our infinite-9s uptime.

It was nothing compared to what NASA does, but terminal animation effects would've ended both of our missions.


I'm very glad that TCP is so robust.

I'd take a solid 300 baud connection over a spotty cellular connection during most emergencies.

Having worked and played on flaky high-latency and low-throughput networks much of my life, I mostly visualize things in my head—as you likely mean by 'command-line-and-editor-when-you-feel-every-byte-transmitted'. Open a connection and queue your commands; wait for output. It works if you don't make any typos.

Preferably, when the connection is too slow or flaky (bad cellular), I make a local script and echo the script to be executed remotely to a file on the remote server, and then execute it with nohup - with the input to create the script and execute it coming from a pre-made file on my local machine redirected to SSH.

Bad cellular often works in bursts, in my experience. Also, redirect output to a file if needed.

This works nicely in situations where your connection may drop frequently for periods exceeding timeouts. On that note, keep ssh timeouts high. With really spotty cellular you might have the network drop for 5-15 minutes between reliable transmissions. SSH connections can stay alive nearly indefinitely if the timeouts allow for it and IP address don't change.


> local script [...] nohup [...] redirect output to a file

  mosh hostname -- screen -S philsnow
I don't think I've had to use this over a truly terrible connection, but mosh worked a treat a ~decade ago while tunneling through DNS from a cruise ship that charged exorbitant rates for wifi while underway, but which allowed unlimited DNS traffic.

> It works if you don't make any typos

mosh helps a bit with that too: you get local predictive echo of your keystrokes and you can't "recall" keystrokes but you can queue up backspaces to cover up your typos. Doesn't help where a single typo-ed keystroke is a hotkey that does something you didn't want, though.



If you ever find yourself needing to tunnel via DNS, try iodine: https://github.com/yarrick/iodine


Mosh looks handy. Thanks for sharing!


I did something similar once when something broke while I was on a plane. The plane wifi was blocking ssh (I HATE when they do this) so I opened up an existing digital ocean instance, sshed into my home computer from it via the web interface, then uploaded some large files from the home computer and did a kubectl apply. The latency was insane but luckily the file upload was fast since my home connection is fast.

It was fun to think about the path each packet was taking - from my laptop to the plane router, to a satellite, back to a digital ocean computer in the UK, to my home computer in NJ, and back. It wasn’t as bad when you think about the magic there.


Smart, and not something someone would realize if they'd been too insulated from how things work.

Regarding planes/cafes/guest/etc. WiFi, I now usually put any "emergency remote plumbing access" on port 443 (though usually not HTTPS), to reduce the likelihood of some random non-SPI ruleset blocking us in an emergency.


I think that by 2050, 443 will be the only port used by applications that require a non local connection, because the chance that some participant in the network has blocked any other port is simply too high.


Future generations will ask - “why does every packet header have this 2 byte reserved field with a fixed value of 01BB?”


Or setup a web ssh client and actually run HTTPS over port 443.


You can also proxy 443 out with ssh.


It would truly have been elite if you'd have to pull out Kermit and use that.

"line is ~300 baud but only transmitting 7 bit but we need to send this critical file.. which is in EBCDIC!"


Nothing like typing in an ssh prompt and each time you press a button on the keyboard you have to wait a few seconds for the char to appear on the screen, because it has to go to the server and back first... that't the true "blind typing" :)))


I think my first action in a situation like that would be an attempt to install mosh from a local mirror.


That needs a binary to run on the remote host for protocol support, doesn't it? I wonder how long that'd take to get transferred and running, over as slow a link as it sounds like this was.


Since you can reach the host, presumably it has some kind of access to system updates / packages. In that case, ideally you paste a command like "sudo apt update && sudo apt install -y mosh\n" or something. You can even paste the newline at the same time and save a round-trip.


"from a local mirror" does not involve transferring the binary over the slow link.


It isn't perfectly clear even in the detailed description whether any other link was available, but I tend to suspect that if anything faster had been, then it would have been used in preference to the one that actually was.


It's a cable going between entire countries that got cut. Anything inside the country should still be full speed.

There is no link that could be used in preference. Any repo that the factory stations could access would be unusable by Singapore AWS. And any repo that Singapore AWS could access would be unusable by the factory stations. But the two ends of the link don't have to use the same repo.


TERM=dumb seems like a good idea in a situation like that.


How exactly did you get the stations working? Be specific.


"Be specific" sounds like a high-stakes interview, so I'd better answer. :)

* SITUATION: Factory reports MVP factory stations for pilot customer "not turning on" for the day, reason unknown.

* TASK: Get stations up in time for production line, so startup doesn't go out of business.

* ACTION: Determined cause was unexplained networking problem outside our control, and that was triggering some startup time checks. But that the stations were resilient enough that I could carefully edit the code on the stations to relax some timeouts, and enough packets were getting through that we might be able to operate anyway. After that worked for one station, carefully changed the remaining ones.

* RESULT: Factory stations worked for that production day, and our startup was therefore still in business. We were later advised of the submarine cable failure, and the factory acknowledged connectivity problems. Our internal post mortem discussions included why the newer boot code hadn't been installed, and revisiting backup connectivity options. From there, thanks to various early-startup engineering magic, and an exciting mix of good and bad luck, we eventually finished a year contract in a high-quality brand's factory production line successfully.

No technical wizardry in the immediate story, but a lot of various smart things we'd done proactively (including triaging what we did and didn't spend precious overextended time on), plus some luck (and of course the fact that some Internet infrastructure heroes' work had them routing any packets at all)... all came together... and got us through a freak failure of a submarine cable we'd never heard of, which could've ended our startup right there.

(Details on Action, IIRC: Assumed command of the incident, and activated Astronaut Mode manner. Attempted to remote access, and found network very poor. Alerted factory of network problem in their connectivity to AWS Singapore, but they initially thought there was no problem. Could tell there was some very spotty connectivity problems (probably including using `mtr-tiny`), so focused troubleshooting stations on that assumption. Realized how the station would behave in this situation, and that the boot-ish checks for various network connectivity were probably timing out. Or, less likely, there could be a bug in handling the exceptional situation. Investigating, very slowly due to poor Internet, found that the stations didn't have the current version of the boot code, which would've reported diagnostics better on the station display, so factory personnel might see it and tell us. Using `vi`, made careful, minimal changes to the timeouts directly on one station, in the old version of the the code on there (in either Python or Bash; I forget). Restarted station, and it worked. Carefully did the same to the other stations. Everything worked, and other parts of the station software had been done smart enough that they could cope with the production day's demands. Despite the poor connectivity, and the need to do network requests for each production item that passed through the station, before it could move on.)


I love the five point order-esque style, warms my military heart


Is it me reading it wrong or are you using two "startup" meanings in sentences very close to each other?


I realized that, and so tried to say "boot" for one of the term senses, but missed an occurrence, which might've made it even more confusing.


I actually am getting a VT320 soon that I hope to be able to use for my terminal at work. I'll run these over it if I remember.


It won't work. It assumes 24-bit colour support, even if you have `TERM=vt320` or something else without it.


Damn, just a programming oversight? You don't need colors to get a lot of these effects. Maybe I'll fork it.


There’s a —no-color argument.

Example: ls | tte —no-color slide

I’ll add environment variable checks to the todo list.


It can work we just need brave soul to make it client side.


These are beautiful.

What I'd really like to see is this supported in the terminal emulator itself as an idle mode, i.e. don't run this in the buffer directly, but rather as a second buffer. This could function like a "screen saver". Once you interact, your primary terminal would be fully restored.


As long as readability wasn’t affected though.


s/fully/gradually/

I’d love some of these effects to fade in/out within live terminal sessions.


You do not know how my production looks like. I _will_ use it in production!


You work on screensavers?


Don’t we all?

https://xkcd.com/722/


Please use this to reboot Trade Wars 2002.


BBS Doors! I knew this reminded me of something (in a good way).


LORD


100% Gimmie some Red Dragon.


Oddly enough, I was just thinking about that sort of thing...


Please do use it in demoscene productions. We need more textmode demos.


It would be great for the startup screens of terminal games.


Agreed. It's not nearly as battle-tested as key operations tooling like `sl` and `gti`.


I was thinking about how fun it would be to add this my Python CLI [0] I made for launching Fedora CoreOS locally with QEMU for testing ignition, but with a flag that is turned off by default. Using the burn effect in TTE when launching a VM with my CLI would be so cool.

This instantly reminded me about Ansible and how it annoyed me that ANSIBLE_NOCOWS had to be enabled to disable the default output of Ansible with cowsay [1].

[0]: https://github.com/quickvm/bupy

[1]: https://github.com/ansible/ansible/issues/10530


Hot damn, I have to respect the author for shutting down any attempt to make him give in to the pressure.

All these serious enterprise people worried about their cows, but then they do install ‘cowsay’ on their systems xD


The people complaining probably don't have the authority to remove it from the base image they're forced to use, unfortunately.


How serious can your enterprise be if they install cowsay on their base image?


How serious it is, and how seriously the people who make decisions take it, are if not strictly orthogonal then certainly not guaranteed to closely correlate.


it's not a matter of seriousness, if you install all the packages, cowsay gets picked up in the mix


On a further tangent, that reminds me of two of my favorite things to install on a Linux system, ponysay and ascii-pony/systempony. I set each of my systems to a different character to show on bash logins with systempony (WSL instances included)

https://github.com/erkin/ponysay

https://blog.yjl.im/2016/01/ascii-pony-systempony-screenshot...


A while back I install ponysay on one of my servers, and put fortune | ponysay in the .bashrc, so I get a quip from a random mlp pony whenever I log in. Brightens my day a little


It'd be good if it recognised https://no-color.org/ and just didn't do anything. Or maybe replaced with <cool effect removed here>

Maybe it does, I didn't check.


It does have a --no-color flag.

That being said, there are some environment variables that could be referenced. I'll add this one to the list for a future update.


What if I want colors, but not animations?


Who wants to actually read text anyway.


Idk I wouldn’t mind one or two of these as loading screens or something.


What CLI tools have a slow enough boot to require a loading screen? I'm sure there are some but...

The only one that comes to mine for me is FileBot[0] - and if the loading screen made it take ANY additional time, I'd be annoyed.

[0] https://www.filebot.net/


Deployment scripts are what come to mind for me. I wouldn’t mind a cool loading screen that highlighted problem nodes in the burning font or something when I deploy to dev / test / hell, maybe even prod.


Anything that downloads from somewhere, eg rsync, wget, package managers, etc.

Anything that compresses or decompresses archives, like gzip/gunzip, tar, etc.

Anything that performs longer running recursive disk activities, like du, find, etc

I’m sure there are plenty more scenarios I haven’t thought of. Though to be clear, I definitely don’t want to see this as a default enabled option in any of these.


If things are working well, they are automated and I rarely see the real time output.

If I’m looking at real time output, it’s because I’m doing something manually because something isn’t working the way it’s supposed to, and I’m in no mood for anything that doesn’t help me understand and address the issue.

This work is impressive. I love it. For some reason I really like “printer.” I’d be all about it for games or toys. But too many tools for real work try to do cute Unicode things or fancy colors or animations. I don’t need it on anything I will ever have to develop or troubleshoot, personally. After the first lengthy wait for a broken container to come up, I’m well over the colorful attitude.


I deliberately mentioned stuff that people are likely to manually run on local and healthy systems. But yeah, I agree with you that the novelty of this stuff wares off quickly.

An example of this done well would be ‘pacman’ package manager where an Easter egg can be enabled to turn the progress bar into a little Pac-Man gobbling pills. It’s not there by default, but it can be enabled if you know how.

Personally, I’m in the same camp as yourself where I’d prefer our tools didn’t have all this cutesy stuff. But people like us seem to be a dying breed.


It could be cool for GUI programs, when run from a terminal, to show a terminal loading screen parallel to the gui loading screen. Totally unnecessary, but cool.


Not for booting but for processing (downloading files, processing a directory, waiting for an api, etc)


As a developer-only tool, I’m sure most of my coworkers would love the attention to details.


I actually love it.


As a product engineer, I'd love the attention to detail much more when placed toward changes that improve my ability to sustain velocity, than when toward changes that actively cut against that.


No. I still sometimes need to use a TTY over MOSH over a satellite connection.

No.


In the old days, some software would actually check the terminal's baud rate (which you can see with 'stty') and behave differently on slow links. For example, vi would restrict itself to fewer lines of the screen so that drawing a new page didn't take as long.

Although I don't know if much software does it, that should still be possible to do it, so these animations could theoretically be auto-disabled on slow links. (And you could manually override the baud rate in your mosh terminal if necessary since it doesn't really have any other effect in a virtual terminal, not like when using an actual serial port, I mean.)


It shouldn't matter, should it? Mosh keeps the state and only sends the differences. You would miss most of the animations, and there would be the overhead of sending the colouring escape codes (a few percent extra), but other than that, it wouldn't be any slower than an unanimated version that I can see.


> ./myfancytool -nofx -doingbusiness -pwn "the_ops"


Challenge accepted.


But if you do, include emoji animations


I'd love to use it while teaching.


all my run books use this


Uh, we accidentally shipped it as our fintech startup screen.


Why not?


Imagine that the CLI tool you use most often every day - a compiler, a package manager, like that - adds animations like these in common operations. Now you have to wait for the animation to finish before you can continue your work. How do you feel about that?


It’s trivial to add in a keypress that short circuits the animation. God, this website is full of the grumpiest people on the planet.


It's not grumpy to prefer function over form in a tool. People optimize for different things. GP's comment is reasonable; they're optimizing for something different than you.


Those of us who live in the terminal do it because it's the fastest, most convenient option, not because it's pretty or to appear 1337. Animations like these get in the way. Cool project, but I would never use it.


I actually did some color animations to status bar of build tool I created while ago. In my opinion this distracted enough to make build feel faster

Edit: popular example of less invasive animations would be new docker cli, (pulling, buildx build)


Yeah. Animations covering time that'd be spent either way I see no problem with, so long as it's obvious the time would be spent either way. Animations that waste my time, not so much.

Better than either, of course, would be effort spent on speeding up the build in the first place. I realize that's less fun, though.

In general, the critical development path is not a place to thoughtlessly add friction.


Also, I don't want to even imagine how it would look on a SSH connection.


?? Why would I imagine that? What does this have to do with using animations in production? What you are saying is "how would you feel about using animations in inappropriate places?"


> What does this have to do with using animations in production? What you are saying is "how would you feel about using animations in inappropriate places?"

Production will always be an inappropriate place. QED.


Of course it would be obnoxious.

As an "about" screen, or in a opt-in funny theme why not !


The idea that anyone would use this during "common operations" is laughable, but as one offs during specific operations, maybe.


> The idea that anyone would use this during "common operations" is laughable

It's been a while since I dared assume anything at all was so obviously absurd that no one could ever think to do it - not least since significant portions of my career to date have consisted of cleaning up after people who had.


Prod should be as robust and straightforward as possible; no distractions, no noise, no extra overhead. This is neat, but not useful, and it adds distractions and delays.




Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: