For the past few months, I’ve been working a lot with clustered VMs (wink wink ;)). Over and over again, I would run into this scenario:

  • For each node in the cluster:
    • SSH into node 1
    • Fire vim and update a file
    • Restart services and test changes

This cycle gets old pretty quickly. I was chatting about this problem over lunch, when one of my coworkers introduced me to the most excellent CSSHX

CSSHX is a perl-based cluster SSH tool for Mac OSX. It’s very straightforward to use, you just call, passing the [email protected]:PORT of each server in your cluster:

With that command, CSSHX will open 3 terminals (one per server), and a master terminal. Anything you type in the master terminal will be automatically typed on all the other terminals. Simple, and effective.

If you have a series of clusters you interact with a lot, CSSHX also supports using a configuration file (it defaults to /etc/cluster). Every line of the file has to follow this format ‘name [email protected]:PORT [email protected]:PORT [email protected]:PORT…’. You can have as many lines as you want.

If your /etc/cluster looks like this:

You could control the dogfood cluster like this:

csshx dogfood

One drawback I’ve found is that, when connecting to new servers, the ‘clustered terminals’ fail to connect when SSH prompts to accept a new server ssh key. As a workaround, I connect to each server directly once, accept the host key, and then use CSSHX for any future connections.

Hope it helps!

Build a stride bot in seconds with glitch

After a few months on beta, Stride's developer API is finally open [to the world](https://blog.stride.com/custom-apps-all-aboard-strides-...… Continue reading

Change email in your commit history

Published on July 16, 2017

Automate your lights with openHAB and Alexa

Published on December 10, 2016