當前位置: 首頁>>代碼示例>>Python>>正文


Python logging.SentryHandler方法代碼示例

本文整理匯總了Python中raven.handlers.logging.SentryHandler方法的典型用法代碼示例。如果您正苦於以下問題:Python logging.SentryHandler方法的具體用法?Python logging.SentryHandler怎麽用?Python logging.SentryHandler使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在raven.handlers.logging的用法示例。


在下文中一共展示了logging.SentryHandler方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: init_plugins

# 需要導入模塊: from raven.handlers import logging [as 別名]
# 或者: from raven.handlers.logging import SentryHandler [as 別名]
def init_plugins():
        """初始化日誌、錯誤追蹤、打點插件"""
        from everyclass.rpc import init as init_rpc
        from everyclass.common.flask import print_config

        # Sentry
        if plugin_available("sentry"):
            sentry.init_app(app=__app)
            sentry_handler = SentryHandler(sentry.client)
            sentry_handler.setLevel(logging.WARNING)
            logging.getLogger().addHandler(sentry_handler)

            init_rpc(sentry=sentry)
            logger.info('Sentry is inited because you are in {} mode.'.format(__app.config['CONFIG_NAME']))

        # metrics
        global statsd
        statsd = DogStatsd(namespace=f"{__app.config['SERVICE_NAME']}.{os.environ.get('MODE').lower()}",
                           use_default_route=True)

        init_rpc(logger=logger)

        print_config(__app, logger) 
開發者ID:everyclass,項目名稱:everyclass-server,代碼行數:25,代碼來源:__init__.py

示例2: _install_sentry

# 需要導入模塊: from raven.handlers import logging [as 別名]
# 或者: from raven.handlers.logging import SentryHandler [as 別名]
def _install_sentry():
    if "AVALON_SENTRY" not in Session:
        return

    try:
        from raven import Client
        from raven.handlers.logging import SentryHandler
        from raven.conf import setup_logging
    except ImportError:
        # Note: There was a Sentry address in this Session
        return log.warning("Sentry disabled, raven not installed")

    client = Client(Session["AVALON_SENTRY"])

    # Transmit log messages to Sentry
    handler = SentryHandler(client)
    handler.setLevel(logging.WARNING)

    setup_logging(handler)

    self._sentry_client = client
    self._sentry_logging_handler = handler
    log.info("Connected to Sentry @ %s" % Session["AVALON_SENTRY"]) 
開發者ID:getavalon,項目名稱:core,代碼行數:25,代碼來源:io.py

示例3: init_logging

# 需要導入模塊: from raven.handlers import logging [as 別名]
# 或者: from raven.handlers.logging import SentryHandler [as 別名]
def init_logging(level='INFO'):
    root = logging.getLogger()
    root.setLevel(0)

    patch_gevent_hub_print_exception()
    if State.config.get('sentry'):
        hdlr = SentryHandler(raven.Client(State.config['sentry'], transport=GeventedHTTPTransport))
        hdlr.setLevel(logging.ERROR)
        root.addHandler(hdlr)

    fmter = ServerLogFormatter()

    hdlr = logging.StreamHandler(sys.stdout)
    hdlr.setLevel(getattr(logging, level))
    hdlr.setFormatter(fmter)

    root.addHandler(hdlr)

    root.info(datetime.datetime.now().strftime("%Y-%m-%d %H:%M"))
    root.info('==============================================') 
開發者ID:leancloud,項目名稱:satori,代碼行數:22,代碼來源:entry.py

示例4: __init__

# 需要導入模塊: from raven.handlers import logging [as 別名]
# 或者: from raven.handlers.logging import SentryHandler [as 別名]
def __init__(self, bot):
        self.bot = bot
        self.settings = dataIO.load_json('data/sentry/settings.json')
        if self.settings['dsn'] is None:
            log.warning('Sentry: DSN key is not set. Not sending logs!')
        else:
            if self.settings['ssl'] is False:
                self.raven = Client(self.settings['dsn'] + '?verify_ssl=0')
            else:
                self.raven = Client(self.settings['dsn'])
            self.handler = SentryHandler(self.raven)
            self.handler.setLevel(self.settings['level'])
            self.logger = logging.getLogger("red").addHandler(self.handler)
            setup_logging(self.handler)
            # --- Raven settings
            self.raven.tags = self.settings['tags']
            if self.settings['name'] is not None:
                self.raven.name = self.settings['name']
            if self.settings['environment'] is not None:
                self.raven.environment = self.settings['environment']
            if self.settings.get('ignore'):
                self.raven.ignore = self.settings['ignore'] 
開發者ID:Kowlin,項目名稱:refactored-cogs,代碼行數:24,代碼來源:sentry.py

示例5: init_app

# 需要導入模塊: from raven.handlers import logging [as 別名]
# 或者: from raven.handlers.logging import SentryHandler [as 別名]
def init_app(self, app):
        dsn = app.config.get('SENTRY_DSN')
        if dsn:
            config = app.config.get_namespace('SENTRY_')
            self.client = raven.Client(**config)
            handler = SentryHandler(self.client)
            handler.setLevel(logging.ERROR)
            setup_logging(handler)
            try:
                from raven.contrib.celery import (
                    register_signal, register_logger_signal)
                register_logger_signal(self.client)
                register_signal(self.client)
            except ImportError:
                pass 
開發者ID:shanbay,項目名稱:sea,代碼行數:17,代碼來源:sentry.py

示例6: init_sentry

# 需要導入模塊: from raven.handlers import logging [as 別名]
# 或者: from raven.handlers.logging import SentryHandler [as 別名]
def init_sentry():
    """
    init sentry
    :return:
    """
    from raven import Client
    from raven.handlers.logging import SentryHandler
    from raven.conf import setup_logging

    from complexconfig.configcontainer import configcontainer
    config = configcontainer.get_config("sniffer")

    enable = config.get_boolean("sniffer.sentry.enable", False)
    if not enable:
        return

    sentry_level = config.get_string("sniffer.sentry.min_level", "error")
    sentry_server_name = config.get_string("sniffer.sentry.server_name", "")
    sentry_dsn = config.get_string("sniffer.sentry.dsn", "")
    if not sentry_dsn or not sentry_server_name:
        return

    print_with_time("sentry is enabled with dsn: {}, server_name: {}, level: {}".format(sentry_dsn,
                                                                                        sentry_server_name,
                                                                                        sentry_level))
    client = Client(sentry_dsn, name=sentry_server_name)
    handler = SentryHandler(client)
    if sentry_level.lower() == 'debug':
        handler.level = logging.DEBUG
    elif sentry_level.lower() == 'info':
        handler.level = logging.INFO
    else:
        handler.level = logging.ERROR
    setup_logging(handler) 
開發者ID:threathunterX,項目名稱:sniffer,代碼行數:36,代碼來源:sniffer.py

示例7: load_sentry

# 需要導入模塊: from raven.handlers import logging [as 別名]
# 或者: from raven.handlers.logging import SentryHandler [as 別名]
def load_sentry(self):
        if self.clientid == "":
            return

        self.raven = Client(self.clientid, transport=AioHttpTransport)
        self.handler = SentryHandler(self.raven)
        setup_logging(self.handler)
        log.debug("Sentry handler activated.") 
開發者ID:tekulvw,項目名稱:Squid-Plugins,代碼行數:10,代碼來源:sentryio.py

示例8: setup_sentry

# 需要導入模塊: from raven.handlers import logging [as 別名]
# 或者: from raven.handlers.logging import SentryHandler [as 別名]
def setup_sentry(dsn=None):
  """Configures the Sentry logging handler.

  Args:
    dsn - DSN for the Sentry project.
  """
  handler = SentryHandler(dsn, level=logging.ERROR)
  setup_logging(handler) 
開發者ID:tellapart,項目名稱:aurproxy,代碼行數:10,代碼來源:util.py

示例9: __init__

# 需要導入模塊: from raven.handlers import logging [as 別名]
# 或者: from raven.handlers.logging import SentryHandler [as 別名]
def __init__(self, config=None):
        self.config = {
            'capture_timeout_warnings': boolval(os.environ.get('SENTRY_CAPTURE_TIMEOUTS', True)),
            'timeout_warning_threshold': float(os.environ.get('SENTRY_TIMEOUT_THRESHOLD', 0.50)),
            'capture_memory_warnings': boolval(os.environ.get('SENTRY_CAPTURE_MEMORY', True)),
            'memory_warning_threshold': float(os.environ.get('SENTRY_MEMORY_THRESHOLD', 0.75)),
            'capture_unhandled_exceptions': boolval(os.environ.get('SENTRY_CAPTURE_UNHANDLED', True)),
            'auto_bread_crumbs': boolval(os.environ.get('SENTRY_AUTO_BREADCRUMBS', True)),
            'capture_errors': boolval(os.environ.get('SENTRY_CAPTURE_ERRORS', True)),
            'filter_local': boolval(os.environ.get('SENTRY_FILTER_LOCAL', True)),
            'is_local': os.environ.get('IS_OFFLINE', False) or os.environ.get('IS_LOCAL', False),
            'logging': boolval(os.environ.get('SENTRY_CAPTURE_LOGS', True)),
            'log_level': extract_log_level_from_environment('SENTRY_LOG_LEVEL', logging.WARNING),
            'enabled': boolval(os.environ.get('SENTRY_ENABLED', True)),
        }
        self.config.update(config or {})

        # check for local environment
        if self.config['filter_local'] and self.config['is_local']:
            logger.warning('Sentry is disabled in local environment')
            self.config["enabled"] = False
            return

        if self.config.get('raven_client'):
            assert self.config.get('raven_client') and not isinstance(self.config.get('raven_client'), Client)
        else:
            self.config['raven_client'] = configure_raven_client(self.config)

        if self.config['logging'] and self.config['raven_client']:
            handler = SentryHandler(self.config['raven_client'])
            handler.setLevel(self.config['log_level'])
            setup_logging(handler) 
開發者ID:Netflix-Skunkworks,項目名稱:raven-python-lambda,代碼行數:34,代碼來源:__init__.py

示例10: server_log_handler

# 需要導入模塊: from raven.handlers import logging [as 別名]
# 或者: from raven.handlers.logging import SentryHandler [as 別名]
def server_log_handler(client):
    """ Adds sentry log handler to the logger

    :return: the sentry handler
    """
    from raven.handlers.logging import SentryHandler

    sh = SentryHandler(client=client, level=logging.ERROR)

    # Don't send Sentry events for command-line usage errors
    old_emit = sh.emit
    def emit(self, record):
        if record.message.startswith("Command-line usage error:"):
            return
        return old_emit(record)

    sh.emit = lambda x: emit(sh, x)


    fmt = ("[%(asctime)s][%(levelname)s] %(filename)s: %(lineno)d | "
            "%(message)s")
    formatter = logging.Formatter(fmt=fmt, datefmt="%H:%M:%S")
    formatter.converter = time.gmtime
    sh.setFormatter(formatter)

    logger.addHandler(sh)
    return sh


# define class color 
開發者ID:neuropoly,項目名稱:spinalcordtoolbox,代碼行數:32,代碼來源:sct_utils.py

示例11: __init__

# 需要導入模塊: from raven.handlers import logging [as 別名]
# 或者: from raven.handlers.logging import SentryHandler [as 別名]
def __init__(
        self,
        sentry_kwargs=None,
        *,
        install_excepthook=True,
        loop=None,
        patch_logging=False,
        sentry_log_level=logging.ERROR
    ):
        if sentry_kwargs is None:
            sentry_kwargs = {}

        sentry_kwargs = {
            "transport": raven_aiohttp.AioHttpTransport,
            "enable_breadcrumbs": False,
            # by default, do not let raven.Client install its own excepthook
            "install_sys_hook": not install_excepthook,
            **sentry_kwargs,
        }
        self.client = raven.Client(**sentry_kwargs)

        # Setup Sentry logger - https://docs.sentry.io/clients/python/integrations/#logging
        if patch_logging:
            handler = SentryHandler(client=self.client)
            handler.setLevel(sentry_log_level)
            setup_logging(handler)

        if install_excepthook:
            self.update_excepthook(loop) 
開發者ID:underyx,項目名稱:aiohttp-sentry,代碼行數:31,代碼來源:__init__.py

示例12: __init__

# 需要導入模塊: from raven.handlers import logging [as 別名]
# 或者: from raven.handlers.logging import SentryHandler [as 別名]
def __init__(self, dsn):
        if dsn:
            # ref: https://blog.windrunner.me/tool/sentry.html#%E5%92%8C-scrapy-%E9%9B%86%E6%88%90
            handler = SentryHandler(dsn)
            handler.setLevel(logging.ERROR)
            setup_logging(handler) 
開發者ID:g0v,項目名稱:tw-rental-house-data,代碼行數:8,代碼來源:sentry.py

示例13: setup_logging

# 需要導入模塊: from raven.handlers import logging [as 別名]
# 或者: from raven.handlers.logging import SentryHandler [as 別名]
def setup_logging(log_name, debug=False, filepath=None, sentry_dsn=None,
                  file_lvl="INFO", sentry_lvl="WARN"):
    """Setup logging according to the specified options. Return the Logger
    object.
    """
    fmt = logging.Formatter(
            '%(asctime)s [%(process)d] %(levelname)s %(message)s'
    )

    stream_handler = logging.StreamHandler()

    if debug:
        stream_log_level = logging.DEBUG
        file_log_level = logging.DEBUG
    else:
        stream_log_level = logging.CRITICAL
        file_log_level = getattr(logging, file_lvl)

    logger = logging.getLogger(log_name)
    logger.setLevel(file_log_level)

    stream_handler.setLevel(stream_log_level)
    stream_handler.setFormatter(fmt)
    logger.addHandler(stream_handler)

    if filepath:
        file_handler = logging.FileHandler(filepath)
        file_handler.setLevel(file_log_level)
        file_handler.setFormatter(fmt)
        logger.addHandler(file_handler)

    if sentry_dsn and _HAS_RAVEN:
        sentry_level = getattr(logging, sentry_lvl)
        sentry_handler = SentryHandler(sentry_dsn)
        sentry_handler.setLevel(sentry_level)
        logger.addHandler(sentry_handler)

    return logger 
開發者ID:SpamExperts,項目名稱:OrangeAssassin,代碼行數:40,代碼來源:config.py

示例14: init_app

# 需要導入模塊: from raven.handlers import logging [as 別名]
# 或者: from raven.handlers.logging import SentryHandler [as 別名]
def init_app(self, app: sanic.Sanic):
        self.client = raven.Client(
            dsn=app.config.get('SENTRY_DSN', None),
            transport=raven_aiohttp.AioHttpTransport,
            **app.config.get('SENTRY_PARAMS', {})
        )
        self.handler = SentryHandler(client=self.client, level=app.config.get('SENTRY_LEVEL', logging.ERROR))
        logger.addHandler(self.handler)
        self.app = app
        self.app.sentry = self 
開發者ID:serathius,項目名稱:sanic-sentry,代碼行數:12,代碼來源:sanic_sentry.py

示例15: check_args

# 需要導入模塊: from raven.handlers import logging [as 別名]
# 或者: from raven.handlers.logging import SentryHandler [as 別名]
def check_args(self, args):
        # check allow_other and allow_root
        if args.allow_other:
            args.allow_root = False
        else:
            args.allow_root = True

        # check log_level
        if args.debug:
            args.log_level = "debug"

        # setup logging
        if args.log != "syslog":
            if args.log in ("-", "/dev/stdout"):
                handler = StreamHandler(sys.stdout)
            else:
                handler = TimedRotatingFileHandler(args.log, when="midnight")
            handler.setFormatter(
                Formatter(
                    fmt="%(asctime)s %(threadName)s: " "%(message)s",
                    datefmt="%B-%d-%Y %H:%M:%S",
                )
            )
        else:
            if sys.platform == "darwin":
                handler = SysLogHandler(address="/var/run/syslog")
            else:
                handler = SysLogHandler(address="/dev/log")
            logger_fmt = (
                "GitFS on {mount_point} [%(process)d]: %(threadName)s: "
                "%(message)s".format(mount_point=args.mount_point)
            )
            handler.setFormatter(Formatter(fmt=logger_fmt))

        if args.sentry_dsn != "":
            from raven.conf import setup_logging
            from raven.handlers.logging import SentryHandler

            sentry_handler = SentryHandler(
                args.sentry_dsn,
                tags={
                    "owner": args.user,
                    "remote": args.remote_url,
                    "mountpoint": args.mount_point,
                },
            )
            sentry_handler.setLevel("ERROR")
            setup_logging(sentry_handler)
            log.addHandler(sentry_handler)

        handler.setLevel(args.log_level.upper())
        log.setLevel(args.log_level.upper())
        log.addHandler(handler)

        # set cache size
        lru_cache.maxsize = args.cache_size

        # return absolute repository's path
        args.repo_path = os.path.abspath(args.repo_path)

        return args 
開發者ID:presslabs,項目名稱:gitfs,代碼行數:63,代碼來源:args.py


注:本文中的raven.handlers.logging.SentryHandler方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。