gRPC全局异常捕获

gRPC全局异常捕获

一般的.net项目比如ASP.NET、控制台程序、Windows服务、桌面程序等都会有framework自带的全局异常捕获机制。ASP.NET的ExceptionFilterAttribute,控制台和Windos服务的AppDomain.CurrentDomain.UnhandledException。那么gRPC的异常捕获是如何实现的。

思路

首先来说一下我走的弯路。我的grpc服务端是依托于.net的控制台程序,同时使用TopShelf框架创建Windows服务。Topshelf有自带的全局异常内部实现也是对AppDomain.CurrentDomain.UnhandledException做了一些封装。但是经过测试发现这种方式是不能捕获gRPC内部的异常的。那么就判断了肯定gRPC内部已经对全局的异常做了捕获,所以我们在控制台使用UnhandledException是不能捕获到的。然后查看gRPC源码,发现gRPC内部的所有异常都会内部消化,然后记录到一个叫ILogger的日志接口,因此我们只需要在控制台实现ILogger接口,在初始化gRPC服务的时候声明就可以了。

实现

首先实现gRPC内部的Grpc.Core.Logging.ILogger接口

 public class GrpcLogger : ILogger
    {
        public ILogger ForType<T>()
        {
            return this;
        }

        public void Debug(string message)
        {
            LogUtil.Debug(message);
        }

        public void Debug(string format, params object[] formatArgs)
        {
            LogUtil.Debug(format);
        }

        public void Error(string message)
        {
            LogUtil.Error(message);
        }

        public void Error(string format, params object[] formatArgs)
        {
            LogUtil.Error(format);
        }

        public void Error(Exception exception, string message)
        {
            LogUtil.Error($"{message}:{exception.ToString()}");
        }

        public void Info(string message)
        {
            LogUtil.Info(message);
        }

        public void Info(string format, params object[] formatArgs)
        {
            LogUtil.Info(format);
        }

        public void Warning(string message)
        {
            LogUtil.Warn(message);
        }

        public void Warning(string format, params object[] formatArgs)
        {
            LogUtil.Warn(format);
        }

        public void Warning(Exception exception, string message)
        {
            LogUtil.Warn($"{message}:{exception.ToString()}");
        }
    }

LogUtil是我的项目里面的日志系统工具类。此处就相当于把gRPC内部的异常日志全部记录到我自己实现的日志系统中,可以自行控制。

ForType()是返回指定类型的日志记录器,可以通过此方法来筛选需要记录的日志。

第二步就是直接把这个GrpcLogger类在服务初始化之后,服务开启之前申明

    GrpcEnvironment.SetLogger(new GrpcLogger());

即可。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值