ulogger


Nameulogger JSON
Version 3.0.0 PyPI version JSON
download
home_pagehttps://github.com/spotify/ulogger
SummaryMicro logging library
upload_time2023-12-01 21:37:10
maintainerLynn Root
docs_urlNone
authorLynn Root
requires_python
licenseApache 2.0
keywords logging
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage
            # ulogger

[![Build Status](https://github.com/spotify/ulogger/actions/workflows/main.yml/badge.svg)](https://github.com/spotify/ulogger/actions/workflows/main.yml) [![Test Coverage](https://codecov.io/github/spotify/ulogger/branch/master/graph/badge.svg)](https://codecov.io/github/spotify/ulogger)

A micro Python logging library.

Supported handlers:

* stream (stdout)
* syslog
* [stackdriver](https://cloud.google.com/logging/) (_optional_)

## Requirements

* Python 3.7. Tests also pass on Python 3.8.  PyPy support has been removed due to upstream issues with the grpcio module.
* Support for Linux & OS X

## To Use

    ```sh
    (env) $ pip install ulogger
    # To use the stackdriver handler, you need to specify an extra dependency:
    (env) $ pip install "ulogger[stackdriver]"
    ```

    ```python
    import logging
    from ulogger import setup_logging

    # one handler
    setup_logging('my_program', 'INFO', ['syslog'])

    # multiple handlers
    setup_logging('my_program', 'INFO', ['syslog', 'stream'])

    # use a different logging facility for syslog (default 16/LOG_LOCAL0)
    setup_logging('my_program', 'INFO', ['syslog'], facility=1)
    setup_logging('my_program', 'INFO', ['syslog'], facility=logging.handlers.SysLogHandler.LOG_USER)

    # then log messages normally
    logging.info('ohai')
    ```

To just setup a specific handler, e.g. Syslog:

    ```python
    import logging
    from ulogger import syslog

    logger = logging.getLogger('my_logger')
    handler = syslog.get_handler('my_program')
    logger.addHandler(handler)
    ```

To setup a Syslog handler with a specific address:

    ```python
    import logging
    from ulogger import syslog

    logger = logging.getLogger('my_logger')

    syslog_addr = ('10.99.0.1', 9514)  # (host, port) tuple
    # if just a host is given, the default port 514 is used
    syslog_addr = ('localhost', None)  # (host, port)
    # filepath is supported
    syslog_addr = '/dev/log'

    handler = syslog.get_handler('my_program', address=syslog_addr)

    # env vars are also supported, but will be overwritten if `address` is explicitly given
    os.environ['SYSLOG_HOST'] = 'localhost'
    os.environ['SYSLOG_PORT'] = 325
    handler = syslog.get_handler('my_program')

    # TCP & UDP are supported
    proto = 1  # TCP
    proto = socket.SOCK_STREAM  # TCP
    proto = 2  # UDP - default
    proto = socket.SOCK_DGRAM  #  UDP - default

    handler = syslog.get_handler('my_program', address=syslog_addr, proto=proto)
    logger.addHandler(handler)
    ```

### Formatting

#### Default

The default date format for all handlers is the following: `'%Y-%m-%dT%H:%M:%S'` (example `2017-11-02T09:51:33.792`).

The default log format is slightly different depending on the handler you select:

##### Stream Handler Log Format

    ```python
    '%(asctime)s.%(msecs)03dZ <PROGNAME> (%(process)d) %(levelname)s: %(message)s'
    ```

Example:

    ```text
    2017-11-02T09:51:33.792Z my_awesome_program (63079) INFO: Beginning awesome program v3.
    ```

##### Syslog Handler Log Format on Linux

    ```python
    '%(asctime)s.%(msecs)03dZ <PROGNAME> (%(process)d): %(message)s'
    ```

Example:

    ```text
    2017-11-02T09:51:33.792Z my_awesome_program (63079): Beginning awesome program v3.
    ```

##### Syslog Handler Log Format on OS X

    ```python
    '<PROGNAME> (%(process)d): %(message)s'
    ```

Example:

    ```text
    Aug 25 13:00:51 my-host.example.net my_awesome_program (63079): Beginning awesome program v3.
    ```

**NOTE**: Default syslog on OS X appends the date and hostname to the log record.

##### Stackdriver Handler Log Format

    ```python
    '%(asctime)s.%(msecs)03d <HOST> <PROGNAME> (%(process)d): %(message)s'
    ```

Example:

    ```text
    2017-11-02T19:00:55.850 my-gcp-host my_awesome_program (63079): Beginning awesome program v3"
    ```

#### Custom

To add your custom log and/or date formatter:

    ```python
    import logging
    from ulogger import setup_logging

    log_fmt = '%(created)f %(levelno)d %(message)s'
    log_date_fmt = '%Y-%m-%dT%H:%M:%S'

    setup_logging('my_program', 'INFO', ['syslog'], log_fmt, log_date_fmt)
    ```

## Development

For development and running tests, your system must have all supported versions of Python installed. We suggest using [pyenv](https://github.com/yyuu/pyenv).

### Setup

    ```sh
    $ git clone git@github.com:spotify/ulogger.git && cd ulogger
    # make a virtualenv
    (env) $ pip install -r dev-requirements.txt
    ```

### Running tests

To run the entire test suite:

    ```sh
    # outside of the virtualenv
    # if tox is not yet installed
    $ pip install tox
    $ tox
    ```

If you want to run the test suite for a specific version of Python:

    ```sh
    # outside of the virtualenv
    $ tox -e py37
    ```

To run an individual test, call `pytest` directly:

    ```sh
    # inside virtualenv
    (env) $ pytest tests/test_syslog.py
    ```

## Code of Conduct

This project adheres to the [Open Code of Conduct][code-of-conduct]. By participating, you are expected to honor this code.

[code-of-conduct]: https://github.com/spotify/code-of-conduct/blob/master/code-of-conduct.md

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/spotify/ulogger",
    "name": "ulogger",
    "maintainer": "Lynn Root",
    "docs_url": null,
    "requires_python": "",
    "maintainer_email": "lynn@spotify.com",
    "keywords": "logging",
    "author": "Lynn Root",
    "author_email": "lynn@spotify.com",
    "download_url": "https://files.pythonhosted.org/packages/c8/14/f680f77d277050bc223d6a46b4f7d6a9d9ae5807f0d03ae8eb112a3df223/ulogger-3.0.0.tar.gz",
    "platform": null,
    "description": "# ulogger\n\n[![Build Status](https://github.com/spotify/ulogger/actions/workflows/main.yml/badge.svg)](https://github.com/spotify/ulogger/actions/workflows/main.yml) [![Test Coverage](https://codecov.io/github/spotify/ulogger/branch/master/graph/badge.svg)](https://codecov.io/github/spotify/ulogger)\n\nA micro Python logging library.\n\nSupported handlers:\n\n* stream (stdout)\n* syslog\n* [stackdriver](https://cloud.google.com/logging/) (_optional_)\n\n## Requirements\n\n* Python 3.7. Tests also pass on Python 3.8.  PyPy support has been removed due to upstream issues with the grpcio module.\n* Support for Linux & OS X\n\n## To Use\n\n    ```sh\n    (env) $ pip install ulogger\n    # To use the stackdriver handler, you need to specify an extra dependency:\n    (env) $ pip install \"ulogger[stackdriver]\"\n    ```\n\n    ```python\n    import logging\n    from ulogger import setup_logging\n\n    # one handler\n    setup_logging('my_program', 'INFO', ['syslog'])\n\n    # multiple handlers\n    setup_logging('my_program', 'INFO', ['syslog', 'stream'])\n\n    # use a different logging facility for syslog (default 16/LOG_LOCAL0)\n    setup_logging('my_program', 'INFO', ['syslog'], facility=1)\n    setup_logging('my_program', 'INFO', ['syslog'], facility=logging.handlers.SysLogHandler.LOG_USER)\n\n    # then log messages normally\n    logging.info('ohai')\n    ```\n\nTo just setup a specific handler, e.g. Syslog:\n\n    ```python\n    import logging\n    from ulogger import syslog\n\n    logger = logging.getLogger('my_logger')\n    handler = syslog.get_handler('my_program')\n    logger.addHandler(handler)\n    ```\n\nTo setup a Syslog handler with a specific address:\n\n    ```python\n    import logging\n    from ulogger import syslog\n\n    logger = logging.getLogger('my_logger')\n\n    syslog_addr = ('10.99.0.1', 9514)  # (host, port) tuple\n    # if just a host is given, the default port 514 is used\n    syslog_addr = ('localhost', None)  # (host, port)\n    # filepath is supported\n    syslog_addr = '/dev/log'\n\n    handler = syslog.get_handler('my_program', address=syslog_addr)\n\n    # env vars are also supported, but will be overwritten if `address` is explicitly given\n    os.environ['SYSLOG_HOST'] = 'localhost'\n    os.environ['SYSLOG_PORT'] = 325\n    handler = syslog.get_handler('my_program')\n\n    # TCP & UDP are supported\n    proto = 1  # TCP\n    proto = socket.SOCK_STREAM  # TCP\n    proto = 2  # UDP - default\n    proto = socket.SOCK_DGRAM  #  UDP - default\n\n    handler = syslog.get_handler('my_program', address=syslog_addr, proto=proto)\n    logger.addHandler(handler)\n    ```\n\n### Formatting\n\n#### Default\n\nThe default date format for all handlers is the following: `'%Y-%m-%dT%H:%M:%S'` (example `2017-11-02T09:51:33.792`).\n\nThe default log format is slightly different depending on the handler you select:\n\n##### Stream Handler Log Format\n\n    ```python\n    '%(asctime)s.%(msecs)03dZ <PROGNAME> (%(process)d) %(levelname)s: %(message)s'\n    ```\n\nExample:\n\n    ```text\n    2017-11-02T09:51:33.792Z my_awesome_program (63079) INFO: Beginning awesome program v3.\n    ```\n\n##### Syslog Handler Log Format on Linux\n\n    ```python\n    '%(asctime)s.%(msecs)03dZ <PROGNAME> (%(process)d): %(message)s'\n    ```\n\nExample:\n\n    ```text\n    2017-11-02T09:51:33.792Z my_awesome_program (63079): Beginning awesome program v3.\n    ```\n\n##### Syslog Handler Log Format on OS X\n\n    ```python\n    '<PROGNAME> (%(process)d): %(message)s'\n    ```\n\nExample:\n\n    ```text\n    Aug 25 13:00:51 my-host.example.net my_awesome_program (63079): Beginning awesome program v3.\n    ```\n\n**NOTE**: Default syslog on OS X appends the date and hostname to the log record.\n\n##### Stackdriver Handler Log Format\n\n    ```python\n    '%(asctime)s.%(msecs)03d <HOST> <PROGNAME> (%(process)d): %(message)s'\n    ```\n\nExample:\n\n    ```text\n    2017-11-02T19:00:55.850 my-gcp-host my_awesome_program (63079): Beginning awesome program v3\"\n    ```\n\n#### Custom\n\nTo add your custom log and/or date formatter:\n\n    ```python\n    import logging\n    from ulogger import setup_logging\n\n    log_fmt = '%(created)f %(levelno)d %(message)s'\n    log_date_fmt = '%Y-%m-%dT%H:%M:%S'\n\n    setup_logging('my_program', 'INFO', ['syslog'], log_fmt, log_date_fmt)\n    ```\n\n## Development\n\nFor development and running tests, your system must have all supported versions of Python installed. We suggest using [pyenv](https://github.com/yyuu/pyenv).\n\n### Setup\n\n    ```sh\n    $ git clone git@github.com:spotify/ulogger.git && cd ulogger\n    # make a virtualenv\n    (env) $ pip install -r dev-requirements.txt\n    ```\n\n### Running tests\n\nTo run the entire test suite:\n\n    ```sh\n    # outside of the virtualenv\n    # if tox is not yet installed\n    $ pip install tox\n    $ tox\n    ```\n\nIf you want to run the test suite for a specific version of Python:\n\n    ```sh\n    # outside of the virtualenv\n    $ tox -e py37\n    ```\n\nTo run an individual test, call `pytest` directly:\n\n    ```sh\n    # inside virtualenv\n    (env) $ pytest tests/test_syslog.py\n    ```\n\n## Code of Conduct\n\nThis project adheres to the [Open Code of Conduct][code-of-conduct]. By participating, you are expected to honor this code.\n\n[code-of-conduct]: https://github.com/spotify/code-of-conduct/blob/master/code-of-conduct.md\n",
    "bugtrack_url": null,
    "license": "Apache 2.0",
    "summary": "Micro logging library",
    "version": "3.0.0",
    "project_urls": {
        "Homepage": "https://github.com/spotify/ulogger"
    },
    "split_keywords": [
        "logging"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "27fd22cf870147ac302500880c132633817c405ca05e1a8db2e68b853cf1c343",
                "md5": "f79c85755f5fb18cdf383f6d80cd0853",
                "sha256": "3cc570e86a19546a01e154c0682bf3a8e38a97e085996acd9c01bf88b17dc442"
            },
            "downloads": -1,
            "filename": "ulogger-3.0.0-py2.py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "f79c85755f5fb18cdf383f6d80cd0853",
            "packagetype": "bdist_wheel",
            "python_version": "py2.py3",
            "requires_python": null,
            "size": 14967,
            "upload_time": "2023-12-01T21:37:08",
            "upload_time_iso_8601": "2023-12-01T21:37:08.270079Z",
            "url": "https://files.pythonhosted.org/packages/27/fd/22cf870147ac302500880c132633817c405ca05e1a8db2e68b853cf1c343/ulogger-3.0.0-py2.py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "c814f680f77d277050bc223d6a46b4f7d6a9d9ae5807f0d03ae8eb112a3df223",
                "md5": "bd9a9804eebe14b901fe85058839f4de",
                "sha256": "7ef36641d429efb406afb3bdbfa9f75000d9ae87c2ede044ac6059f99fc512b6"
            },
            "downloads": -1,
            "filename": "ulogger-3.0.0.tar.gz",
            "has_sig": false,
            "md5_digest": "bd9a9804eebe14b901fe85058839f4de",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 17569,
            "upload_time": "2023-12-01T21:37:10",
            "upload_time_iso_8601": "2023-12-01T21:37:10.002047Z",
            "url": "https://files.pythonhosted.org/packages/c8/14/f680f77d277050bc223d6a46b4f7d6a9d9ae5807f0d03ae8eb112a3df223/ulogger-3.0.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-12-01 21:37:10",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "spotify",
    "github_project": "ulogger",
    "travis_ci": false,
    "coveralls": true,
    "github_actions": true,
    "requirements": [],
    "tox": true,
    "lcname": "ulogger"
}
        
Elapsed time: 0.21051s