Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rpgreen/apilogs
Easy logging and debugging for Amazon API Gateway and AWS Lambda Serverless APIs
https://github.com/rpgreen/apilogs
api api-gateway aws aws-apigateway aws-lambda cloudwatch-logs gateway lambda logging
Last synced: 2 days ago
JSON representation
Easy logging and debugging for Amazon API Gateway and AWS Lambda Serverless APIs
- Host: GitHub
- URL: https://github.com/rpgreen/apilogs
- Owner: rpgreen
- License: other
- Created: 2016-09-07T17:27:47.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2019-11-13T21:28:36.000Z (about 5 years ago)
- Last Synced: 2025-01-12T17:08:42.305Z (9 days ago)
- Topics: api, api-gateway, aws, aws-apigateway, aws-lambda, cloudwatch-logs, gateway, lambda, logging
- Language: Python
- Homepage:
- Size: 1.39 MB
- Stars: 254
- Watchers: 10
- Forks: 18
- Open Issues: 1
-
Metadata Files:
- Readme: README.rst
- Changelog: CHANGELOG
- License: COPYING
Awesome Lists containing this project
README
apilogs
=======``apilogs`` is a fork of the excellent `awslogs `_ project with specific customizations suited to querying and streaming logs for
Serverless APIs using `Amazon API Gateway `_ and `AWS Lambda `_.Simply provide an API Gateway API ID and Stage name and `apilogs` will automatically aggregate log events from all log streams for your API Gateway API as well as all Lambda function log streams attached to your API.
Installation/Running
-------
$ pip install apilogsi.e. stream logs for your Serverless API:
$ apilogs get --api-id xyz123 --stage prod --watchGrep for errors one hour ago using credentials from AWS CLI profile "myprofile":
$ apilogs get --api-id xyz123 --stage test2 --profile myprofile --aws-region us-east-1 --start='2h ago' --end='1h ago' | grep "ERROR".. image:: https://github.com/rpgreen/apilogs/blob/master/media/apilogs-screenshot.png
Features
--------* Aggregate logs from across streams.
- Aggregate all streams in a group.
- Aggregate streams matching a regular expression.* Colored output.
- Highlight found text in logs
* List existing groups- ``$ apilogs groups``
* List existing streams
- ``$ apilogs streams /var/log/syslog``
* Watch logs as they are created
- ``$ apilogs get /var/log/syslog ALL --watch``
* Human-friendly time filtering:
- ``--start='23/1/2015 14:23'``
- ``--start='2h ago'``
- ``--start='2d ago'``
- ``--start='2w ago'``
- ``--start='2d ago' --end='1h ago'``* Retrieve event metadata:
- ``--timestamp`` Prints the creation timestamp of each event.
- ``--ingestion-time`` Prints the ingestion time of each event.Options
-------* ``apilogs groups``: List existing groups
* ``apilogs streams GROUP``: List existing streams withing ``GROUP``
* ``apilogs get GROUP [STREAM_EXPRESSION]``: Get logs matching ``STREAM_EXPRESSION`` in ``GROUP``.- Expressions can be regular expressions or the wildcard ``ALL`` if you want any and don't want to type ``.*``.
**Note:** You need to provide to all these options a valid AWS region using ``--aws-region`` or ``AWS_REGION`` env variable.
Time options
-------------While querying for logs you can filter events by ``--start`` ``-s`` and ``--end`` ``-e`` date.
* By minute:
- ``--start='2m'`` Events generated two minutes ago.
- ``--start='1 minute'`` Events generated one minute ago.
- ``--start='5 minutes'`` Events generated five minutes ago.* By hours:
- ``--start='2h'`` Events generated two hours ago.
- ``--start='1 hour'`` Events generated one hour ago.
- ``--start='5 hours'`` Events generated five hours ago.* By days:
- ``--start='2d'`` Events generated two days ago.
- ``--start='1 day'`` Events generated one day ago.
- ``--start='5 days'`` Events generated five days ago.* By weeks:
- ``--start='2w'`` Events generated two week ago.
- ``--start='1 week'`` Events generated one weeks ago.
- ``--start='5 weeks'`` Events generated five week ago.* Using specific dates:
- ``--start='23/1/2015 12:00'`` Events generated after midday on the 23th of January 2015.
- ``--start='1/1/2015'`` Events generated after midnight on the 1st of January 2015.
- ``--start='Sat Oct 11 17:13:46 UTC 2003'`` You can use detailed dates too.Note, for time parsing awslogs uses `dateutil `_.
* All previous examples are applicable for ``--end`` ``-e`` too.
Filter options
----------------You can use ``--filter-pattern`` if you want to only retrieve logs which match one CloudWatch Logs Filter pattern.
This is helpful if you know precisely what you are looking for, and don't want to download the entire stream.For example, if you only want to download only the report events from a Lambda stream you can run::
$ apilogs get my_lambda_group --filter-pattern="[r=REPORT,...]"
Full documentation of how to write patterns: http://docs.aws.amazon.com/AmazonCloudWatch/latest/DeveloperGuide/FilterAndPatternSyntax.html
Contribute
-----------* Fork the repository on GitHub.
* Write a test which shows that the bug was fixed or that the feature works as expected.- Use ``tox`` command to run all the tests in all locally available python version.
* Send a pull request and bug the maintainer until it gets merged and published. :).
For more instructions see `TESTING.rst`.
Helpful Links
-------------* http://aws.amazon.com/cloudwatch/
* http://boto.readthedocs.org/en/latest/ref/logs.html
* http://docs.aws.amazon.com/AmazonCloudWatch/latest/DeveloperGuide/cloudwatch_limits.htmlHow to provide AWS credentials to apilogs
------------------------------------------Although, the most straightforward thing to do might be use ``--aws-access-key-id`` and ``--aws-secret-access-key`` or ``--profile``, this will eventually become a pain in the ass.
* If you only have one ``AWS`` account, my personal recommendation would be to configure `aws-cli `_. ``apilogs`` will use those credentials if available.
* If you have multiple ``AWS`` accounts or you don't want to setup ``aws-cli``, I would recommend you to use `envdir `_ in order to make ``AWS_ACCESS_KEY_ID`` and ``AWS_SECRET_ACCESS_KEY`` available to ``apilogs``.