Tool to run ecs execute command in Python and in AWS Lambda. Of course, locally you can do this via the session manager plugin, but it you want to do it in lambda, it is a bit more complex.
- Run simple commands or full scripts.
- Pass arguments into those scripts.
- Get output back in python.
Here are some of the current limitations.
- Testing shell is present, but still must be completed.
- Still needs started really.
- Need to mock away the websocket bits.
- This documentation.
pip install interloper
For starters, one must enable ECS exec.
./interloper.py [event]
Note
If cmd is given in the event, the cmd_handler is used.
Otherwise, the script_handler is used.
You can import and use the provided handlers for simple operations.
from interloper import cmd_handler... Actually, that should be sufficient. Just set the handler to main.cmd_handler or whatever your module is called in place of main.
from interloper import script_handlerThen create an interloper.sh that suits your needs.
Consider needing to generate heap dumps and thread dumps from java containers. You could do so with the following.
#!/usr/bin/env sh
cleanup () {
rm -rf /tmp/dumps
mkdir -p /tmp/dumps
}
verify_awscli () {
if which aws >/dev/null
then
echo "awscli found; proceeding"
return 0
else
echo "awscli not found; can't proceed"
return 1
fi
}
verify_jattach () {
if which jattach >/dev/null
then
echo "jattach found; proceeding"
return 0
else
echo "jattach not installed; installing"
if which apk >/dev/null
then
apk add --no-cache jattach --repository http://dl-cdn.alpinelinux.org/alpine/edge/community/
return 0
else
echo "apk not found; can't proceed"
return 1
fi
fi
}
cleanup
case "$1" in
heap)
if verify_jattach; then jattach $(pgrep java) dumpheap /tmp/dumps/heap.hprof; fi
if verify_awscli; then aws s3 cp /tmp/dumps/heap.hprof s3://"$2"; fi
;;
threads)
if verify_jattach; then jattach $(pgrep java) threaddump > /tmp/dumps/threads; fi
if verify_awscli; then aws s3 cp /tmp/dumps/threads s3://"$2"; fi
;;
*)
echo "usage: $0 {heap|threads} {key}"
esacimport logging
import time
import interloper
LOG = logging.getLogger()
LOG.setLevel(logging.INFO)
def lambda_handler(event: dict, context) -> None:
LOG.debug("event received: %s", event)
input = interloper.Input(**event)
key = "{}/{}/{}-{}".format(input.cluster, input.task, input.cmd, int(time.time()))
if input.cmd == "heap":
key += ".hprof"
output = interloper.Interloper(
input.task, cluster=input.cluster, container=input.container
).script("dumper.sh", [input.cmd, key])
LOG.info(output)