ftw.structlog


Nameftw.structlog JSON
Version 1.4.1 PyPI version JSON
download
home_pagehttps://github.com/4teamwork/ftw.structlog
SummaryStructured logging for Plone
upload_time2023-04-04 12:54:26
maintainer
docs_urlNone
author4teamwork AG
requires_python
licenseGPL2
keywords structured logging plone
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            ftw.structlog
=============

This package implements **structured request logging in Plone**.

It does so by writing logfiles (one per instance) that contain one JSON entry
per line for every request. That JSON entry contains all the information the
Z2 log provides, and more, in structured key/value pairs.


Installation
------------

- Install ``ftw.structlog`` by adding it to the list of eggs in your buildout.
  Then run buildout and restart your instance:

.. code:: ini

    [instance]
    eggs +=
        ftw.structlog

- Alternatively, add it as a dependency to your package's ``setup.py``.


Logged Information
------------------

Example entry:

.. code:: json

    {
      "bytes": 6875,
      "cient_ip": "127.0.0.1",
      "duration": 0.30268411636353,
      "host": "127.0.0.1",
      "method": "GET",
      "referer": "http:\/\/localhost:8080\/plone",
      "site": "plone",
      "status": 200,
      "timestamp": "2017-07-29T12:30:58.000750+02:00",
      "url": "http:\/\/localhost:8080\/plone\/my-page",
      "user": "john.doe",
      "user_agent": "Mozilla\/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit\/537.36 (KHTML, like Gecko) Chrome\/60.0.3112.113 Safari\/537.36",
      "view": "some_view"
    }


The logged JSON entry contains the following data:

+------------+---------------------------------------------------------------+
| key        | value                                                         |
+============+===============================================================+
| bytes      | Size of response body in bytes (``Content-Length``)           |
+------------+---------------------------------------------------------------+
| client_ip  | Host where the request originated from (respecting            |
|            | X-Forwarded-For)                                              |
+------------+---------------------------------------------------------------+
| duration   | Time spent in ZPublisher to handle request (time between      |
|            | ``IPubStart`` and ``IPubSuccess`` / ``IPubFailure`` )         |
+------------+---------------------------------------------------------------+
| host       | Deprecated. You should use ``client_ip`` instead.             |
+------------+---------------------------------------------------------------+
| method     | HTTP request method                                           |
+------------+---------------------------------------------------------------+
| referer    | Referer                                                       |
+------------+---------------------------------------------------------------+
| site       | Plone site ID                                                 |
+------------+---------------------------------------------------------------+
| status     | HTTP response status                                          |
+------------+---------------------------------------------------------------+
| timestamp  | Time when request was received (non-naive local time in ISO   |
|            | 8601, in the server's local timezone as determined by         |
|            | ``tzlocal``)                                                  |
+------------+---------------------------------------------------------------+
| url        | URL of the request (including query string if present)        |
+------------+---------------------------------------------------------------+
| user       | Username of the authenticated user, ``"Anonymous"`` otherwise |
+------------+---------------------------------------------------------------+
| user_agent | User-Agent                                                    |
+------------+---------------------------------------------------------------+
| view       | Name of the browser view or REST API endpoint  (see below)    |
+------------+---------------------------------------------------------------+


If ``SQLAlchemy`` is installed and integrated via ``z3c.saconfig``, SQL query
times will also be logged. For requests that perform SQL queries, there will
be an additional key ``sql_query_time`` containing the cumulative time of
all SQL queries during that request:

+----------------+----------------------------------------------------------------+
| key            | value                                                          |
+================+================================================================+
| sql_query_time | Cumulative time of all SQL queries during request (in seconds) |
+----------------+----------------------------------------------------------------+


Log Destinations
----------------

``ftw.structlog`` logs to a file by default, but can be configured to log to a
Fluentd / Fluent Bit instance instead.


Logging to file
^^^^^^^^^^^^^^^

By default, ``ftw.structlog`` will log to a local file with one JSON object
per line.

One logfile per Zope2 instance will be created, and its location and name
will be derived from the instance's eventlog path. If the instance's eventlog
path is ``var/log/instance2.log``, the JSON logfile's path will be
``var/log/instance2-json.log``.

**Note**: Because ``ftw.structlog`` derives its logfile name from the
eventlog path, an eventlog *must* be configured in ``zope.conf``, otherwise
``ftw.structlog`` will not log any requests and complain noisily through
the root logger.

When running tests in other projects, these errors can be muted by setting the
environment variable ``FTW_STRUCTLOG_MUTE_SETUP_ERRORS=true``.

Logging to Fluentd
^^^^^^^^^^^^^^^^^^

If the environment variable ``FLUENT_HOST`` is set, ``ftw.structlog`` will
log to that fluent host using the Fluentd Forward Protocol, instead of
logging to a local file. ``FLUENT_HOST`` (optional) allows to specify the
port, and defaults to 24224 if not set.

In order for ftw.structlog to use a proper tag for events logged to Fluentd,
the Pod namespace needs to be exposed in the ``KUBERNETES_NAMESPACE`` env var.

View Name
---------

An attempt is made to log the name of the invoked browser view or REST API
endpoint, so that requests to particular views can easily be grouped without
having to resort to URL string parsing.

However, this is intentionally limited, and aims to only handle the most
common and useful cases. It's also implemented in a way to not fill up logs
with too many diverse values for ``view``, by grouping together very
common requests (CSS and JS assets) under common names.

The following table gives an example of how names of different "views" are
logged:

+-------------------------------------------------+----------------------+
| View Type                                       | view                 |
+=================================================+======================+
| Regular browser view                            | 'some_view'          |
+-------------------------------------------------+----------------------+
| Regular browser view, published attributes      | 'some_view/attr'     |
+-------------------------------------------------+----------------------+
| plone.rest named services                       | '@actions'           |
+-------------------------------------------------+----------------------+
| plone.rest named services with path params      | '@users'             |
+-------------------------------------------------+----------------------+
| plone.rest unnamed GET/POST/...                 | 'context'            |
+-------------------------------------------------+----------------------+
| CSS                                             | 'portal_css'         |
+-------------------------------------------------+----------------------+
| JS                                              | 'portal_javascripts' |
+-------------------------------------------------+----------------------+
| Resources                                       | '++resource++'       |
+-------------------------------------------------+----------------------+
| Theme resources                                 | '++theme++'          |
+-------------------------------------------------+----------------------+


Links
-----

- Github: https://github.com/4teamwork/ftw.structlog
- Issues: https://github.com/4teamwork/ftw.structlog/issues
- Pypi: http://pypi.python.org/pypi/ftw.structlog
- Continuous integration: https://jenkins.4teamwork.ch/search?q=ftw.structlog


Copyright
---------

This package is copyright by `4teamwork <http://www.4teamwork.ch/>`_.

``ftw.structlog`` is licensed under GNU General Public License, version 2.

Changelog
=========


1.4.1 (2023-04-04)
------------------

- Fluentd logging: Use K8s namespace in tag. [lgraf]


1.4.0 (2023-02-01)
------------------

- Add support for logging to Fluentd. [lgraf]


1.3.1 (2020-05-19)
------------------

- SQL query logging: Be more defensive in trying to annotate a request
  that might not always be ready yet (e.g. during testing). [lgraf]


1.3.0 (2020-05-19)
------------------

- Log view name for browser views and REST API services.
  [deiferni, lukasg]


1.2.0 (2020-05-19)
------------------

- Track query execution time if SQLAlchemy is present. [lgraf]


1.1.0 (2019-01-11)
------------------

- DEPRECATED: The ``host`` field is deprecated. Instead, the newly introduced
  ``client_ip`` field should be used to get the client's IP address.
  [lgraf]

- Always log missing referer as empty string instead of ``null``.
  [lgraf]


1.0.1 (2017-09-03)
------------------

- Fail gracefully if eventlog config can't be found in order to derive
  log location from it. Instead of preventing instance startup, log a
  noticeable error message using the root logger.
  [lgraf]


1.0.0 (2017-09-03)
------------------

- Initial implementation
  [lgraf]
            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/4teamwork/ftw.structlog",
    "name": "ftw.structlog",
    "maintainer": "",
    "docs_url": null,
    "requires_python": "",
    "maintainer_email": "",
    "keywords": "structured logging plone",
    "author": "4teamwork AG",
    "author_email": "mailto:info@4teamwork.ch",
    "download_url": "https://files.pythonhosted.org/packages/fc/75/7bf18c1983048f5a6cf84a34ea59e7795627a92c31d18a997faa4df8d6d6/ftw.structlog-1.4.1.tar.gz",
    "platform": null,
    "description": "ftw.structlog\n=============\n\nThis package implements **structured request logging in Plone**.\n\nIt does so by writing logfiles (one per instance) that contain one JSON entry\nper line for every request. That JSON entry contains all the information the\nZ2 log provides, and more, in structured key/value pairs.\n\n\nInstallation\n------------\n\n- Install ``ftw.structlog`` by adding it to the list of eggs in your buildout.\n  Then run buildout and restart your instance:\n\n.. code:: ini\n\n    [instance]\n    eggs +=\n        ftw.structlog\n\n- Alternatively, add it as a dependency to your package's ``setup.py``.\n\n\nLogged Information\n------------------\n\nExample entry:\n\n.. code:: json\n\n    {\n      \"bytes\": 6875,\n      \"cient_ip\": \"127.0.0.1\",\n      \"duration\": 0.30268411636353,\n      \"host\": \"127.0.0.1\",\n      \"method\": \"GET\",\n      \"referer\": \"http:\\/\\/localhost:8080\\/plone\",\n      \"site\": \"plone\",\n      \"status\": 200,\n      \"timestamp\": \"2017-07-29T12:30:58.000750+02:00\",\n      \"url\": \"http:\\/\\/localhost:8080\\/plone\\/my-page\",\n      \"user\": \"john.doe\",\n      \"user_agent\": \"Mozilla\\/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit\\/537.36 (KHTML, like Gecko) Chrome\\/60.0.3112.113 Safari\\/537.36\",\n      \"view\": \"some_view\"\n    }\n\n\nThe logged JSON entry contains the following data:\n\n+------------+---------------------------------------------------------------+\n| key        | value                                                         |\n+============+===============================================================+\n| bytes      | Size of response body in bytes (``Content-Length``)           |\n+------------+---------------------------------------------------------------+\n| client_ip  | Host where the request originated from (respecting            |\n|            | X-Forwarded-For)                                              |\n+------------+---------------------------------------------------------------+\n| duration   | Time spent in ZPublisher to handle request (time between      |\n|            | ``IPubStart`` and ``IPubSuccess`` / ``IPubFailure`` )         |\n+------------+---------------------------------------------------------------+\n| host       | Deprecated. You should use ``client_ip`` instead.             |\n+------------+---------------------------------------------------------------+\n| method     | HTTP request method                                           |\n+------------+---------------------------------------------------------------+\n| referer    | Referer                                                       |\n+------------+---------------------------------------------------------------+\n| site       | Plone site ID                                                 |\n+------------+---------------------------------------------------------------+\n| status     | HTTP response status                                          |\n+------------+---------------------------------------------------------------+\n| timestamp  | Time when request was received (non-naive local time in ISO   |\n|            | 8601, in the server's local timezone as determined by         |\n|            | ``tzlocal``)                                                  |\n+------------+---------------------------------------------------------------+\n| url        | URL of the request (including query string if present)        |\n+------------+---------------------------------------------------------------+\n| user       | Username of the authenticated user, ``\"Anonymous\"`` otherwise |\n+------------+---------------------------------------------------------------+\n| user_agent | User-Agent                                                    |\n+------------+---------------------------------------------------------------+\n| view       | Name of the browser view or REST API endpoint  (see below)    |\n+------------+---------------------------------------------------------------+\n\n\nIf ``SQLAlchemy`` is installed and integrated via ``z3c.saconfig``, SQL query\ntimes will also be logged. For requests that perform SQL queries, there will\nbe an additional key ``sql_query_time`` containing the cumulative time of\nall SQL queries during that request:\n\n+----------------+----------------------------------------------------------------+\n| key            | value                                                          |\n+================+================================================================+\n| sql_query_time | Cumulative time of all SQL queries during request (in seconds) |\n+----------------+----------------------------------------------------------------+\n\n\nLog Destinations\n----------------\n\n``ftw.structlog`` logs to a file by default, but can be configured to log to a\nFluentd / Fluent Bit instance instead.\n\n\nLogging to file\n^^^^^^^^^^^^^^^\n\nBy default, ``ftw.structlog`` will log to a local file with one JSON object\nper line.\n\nOne logfile per Zope2 instance will be created, and its location and name\nwill be derived from the instance's eventlog path. If the instance's eventlog\npath is ``var/log/instance2.log``, the JSON logfile's path will be\n``var/log/instance2-json.log``.\n\n**Note**: Because ``ftw.structlog`` derives its logfile name from the\neventlog path, an eventlog *must* be configured in ``zope.conf``, otherwise\n``ftw.structlog`` will not log any requests and complain noisily through\nthe root logger.\n\nWhen running tests in other projects, these errors can be muted by setting the\nenvironment variable ``FTW_STRUCTLOG_MUTE_SETUP_ERRORS=true``.\n\nLogging to Fluentd\n^^^^^^^^^^^^^^^^^^\n\nIf the environment variable ``FLUENT_HOST`` is set, ``ftw.structlog`` will\nlog to that fluent host using the Fluentd Forward Protocol, instead of\nlogging to a local file. ``FLUENT_HOST`` (optional) allows to specify the\nport, and defaults to 24224 if not set.\n\nIn order for ftw.structlog to use a proper tag for events logged to Fluentd,\nthe Pod namespace needs to be exposed in the ``KUBERNETES_NAMESPACE`` env var.\n\nView Name\n---------\n\nAn attempt is made to log the name of the invoked browser view or REST API\nendpoint, so that requests to particular views can easily be grouped without\nhaving to resort to URL string parsing.\n\nHowever, this is intentionally limited, and aims to only handle the most\ncommon and useful cases. It's also implemented in a way to not fill up logs\nwith too many diverse values for ``view``, by grouping together very\ncommon requests (CSS and JS assets) under common names.\n\nThe following table gives an example of how names of different \"views\" are\nlogged:\n\n+-------------------------------------------------+----------------------+\n| View Type                                       | view                 |\n+=================================================+======================+\n| Regular browser view                            | 'some_view'          |\n+-------------------------------------------------+----------------------+\n| Regular browser view, published attributes      | 'some_view/attr'     |\n+-------------------------------------------------+----------------------+\n| plone.rest named services                       | '@actions'           |\n+-------------------------------------------------+----------------------+\n| plone.rest named services with path params      | '@users'             |\n+-------------------------------------------------+----------------------+\n| plone.rest unnamed GET/POST/...                 | 'context'            |\n+-------------------------------------------------+----------------------+\n| CSS                                             | 'portal_css'         |\n+-------------------------------------------------+----------------------+\n| JS                                              | 'portal_javascripts' |\n+-------------------------------------------------+----------------------+\n| Resources                                       | '++resource++'       |\n+-------------------------------------------------+----------------------+\n| Theme resources                                 | '++theme++'          |\n+-------------------------------------------------+----------------------+\n\n\nLinks\n-----\n\n- Github: https://github.com/4teamwork/ftw.structlog\n- Issues: https://github.com/4teamwork/ftw.structlog/issues\n- Pypi: http://pypi.python.org/pypi/ftw.structlog\n- Continuous integration: https://jenkins.4teamwork.ch/search?q=ftw.structlog\n\n\nCopyright\n---------\n\nThis package is copyright by `4teamwork <http://www.4teamwork.ch/>`_.\n\n``ftw.structlog`` is licensed under GNU General Public License, version 2.\n\nChangelog\n=========\n\n\n1.4.1 (2023-04-04)\n------------------\n\n- Fluentd logging: Use K8s namespace in tag. [lgraf]\n\n\n1.4.0 (2023-02-01)\n------------------\n\n- Add support for logging to Fluentd. [lgraf]\n\n\n1.3.1 (2020-05-19)\n------------------\n\n- SQL query logging: Be more defensive in trying to annotate a request\n  that might not always be ready yet (e.g. during testing). [lgraf]\n\n\n1.3.0 (2020-05-19)\n------------------\n\n- Log view name for browser views and REST API services.\n  [deiferni, lukasg]\n\n\n1.2.0 (2020-05-19)\n------------------\n\n- Track query execution time if SQLAlchemy is present. [lgraf]\n\n\n1.1.0 (2019-01-11)\n------------------\n\n- DEPRECATED: The ``host`` field is deprecated. Instead, the newly introduced\n  ``client_ip`` field should be used to get the client's IP address.\n  [lgraf]\n\n- Always log missing referer as empty string instead of ``null``.\n  [lgraf]\n\n\n1.0.1 (2017-09-03)\n------------------\n\n- Fail gracefully if eventlog config can't be found in order to derive\n  log location from it. Instead of preventing instance startup, log a\n  noticeable error message using the root logger.\n  [lgraf]\n\n\n1.0.0 (2017-09-03)\n------------------\n\n- Initial implementation\n  [lgraf]",
    "bugtrack_url": null,
    "license": "GPL2",
    "summary": "Structured logging for Plone",
    "version": "1.4.1",
    "split_keywords": [
        "structured",
        "logging",
        "plone"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "fc757bf18c1983048f5a6cf84a34ea59e7795627a92c31d18a997faa4df8d6d6",
                "md5": "5e6ad5586b414b09146d02f5a65bbd90",
                "sha256": "9f7d3fda8f450b1abc15abdb0ec592efcc3f846aad3691cbf78f8ab94dc3ad2d"
            },
            "downloads": -1,
            "filename": "ftw.structlog-1.4.1.tar.gz",
            "has_sig": false,
            "md5_digest": "5e6ad5586b414b09146d02f5a65bbd90",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 25788,
            "upload_time": "2023-04-04T12:54:26",
            "upload_time_iso_8601": "2023-04-04T12:54:26.541353Z",
            "url": "https://files.pythonhosted.org/packages/fc/75/7bf18c1983048f5a6cf84a34ea59e7795627a92c31d18a997faa4df8d6d6/ftw.structlog-1.4.1.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-04-04 12:54:26",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "github_user": "4teamwork",
    "github_project": "ftw.structlog",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "lcname": "ftw.structlog"
}
        
Elapsed time: 0.05844s