mitogen/docs/history.rst

65 lines
2.8 KiB
ReStructuredText
Raw Normal View History

2016-08-12 19:07:04 +00:00
History And Future
==================
2016-08-14 00:17:03 +00:00
History
#######
The first version of econtext was written in late 2006 for use in an
infrastructure management program, however at the time I lacked the pragmatism
necessary for pushing my little design from concept to finished implementation.
I tired of it when no way could be found to unify every communication style
(*blocking execute function, asynchronous execute function, proxy
slave-of-slave context*) into one neat abstraction. That unification never
happened, but I'm no longer worried by it.
2016-08-14 00:17:03 +00:00
Every few years I would pick through the source code, especially after periods
of commercial work involving some contemporary infrastructure management
systems, none of which had nearly as neat an approach to running Python code
remotely, and suffered from shockingly beginner-level bugs such as failing to
report SSH diagnostic messages.
2016-08-14 00:17:03 +00:00
And every few years I'd put that code down again, especially since moving to an
OS X laptop where :py:func:`select.poll` was not available, the struggle to get
2016-08-14 15:33:09 +00:00
back on top seemed more hassle than it was worth.
2016-08-14 00:17:03 +00:00
That changed in 2016 during a quiet evening at home with a clear head and
nothing better to do, after a full day of exposure to Ansible's intensely
unbearable tendency to make running a 50 line Python script across a 1Gbit/sec
2016-08-14 15:33:09 +00:00
LAN feel like I were configuring a host on Mars. Poking through Ansible, I was
shocked to discover it writing temporary files everywhere, and uploading a
56KiB zip file apparently for every playbook step.
2016-08-14 00:17:03 +00:00
2016-08-14 00:52:37 +00:00
.. figure:: _static/wtf.gif
All contemporary Devops tooling
2016-08-14 00:37:56 +00:00
2016-08-14 00:17:03 +00:00
Searching around for something to play with, I came across my forgotten
``src/econtext`` directory and somehow in a few hours managed to squash most of
the race conditions and logic bugs that were preventing reliable operation,
write the IO and log forwarders, rewrite the module importer, move from
:py:func:`select.poll` to :py:func:`select.select`, and even refactor the
special cases out of the main loop.
2016-08-14 15:33:09 +00:00
So there you have it. As of writing :py:mod:`econtext.core` consists of 528
source lines, and those 528 lines have taken me almost a decade to write. I
2016-08-14 00:37:56 +00:00
have long had a preference for avoiding infrastructure work commercially, not
least for the inescapable depression induced by considering the wasted effort
2016-08-14 00:52:37 +00:00
across the world caused by universally horrific tooling. This is my small
contribution to a solution, I hope you find it useful.
2016-08-12 19:07:04 +00:00
Future
######
* Connect back using TCP and SSL.
* Python 3 support.
2016-08-14 00:37:56 +00:00
* Windows support via psexec or similar.
2016-08-14 01:31:15 +00:00
* Investigate cPickle safety and potentially replace it.
2016-08-12 20:41:10 +00:00
* Predictive import: reduce roundtrips by pipelining modules observed to
probably be requested in future.
2016-08-14 00:17:03 +00:00
* Provide a means for waiting on multiple
:py:class:`Channels <econtext.core.Channel>`.
* Comprehensive integration tests.