码迷,mamicode.com
首页 > Web开发 > 详细

LindDotNetCore~Polly组件对微服务场景的价值

时间:2018-01-30 23:02:05      阅读:269      评论:0      收藏:0      [点我收藏+]

标签:gen   图片   wot   项目   identity   pos   cti   服务架构   tps   

回到目录

Polly是一个开源框架,在github上可以找到,被善友大哥收录,也是.App vNext的一员!

App vNext:https://github.com/App-vNext

GitHub:https://github.com/App-vNext/Polly

NanoFabric是一个开源的微服务架构,也是善友大哥推荐的:https://github.com/geffzhang/NanoFabric

对于NanoFabric来说,它集成了很多.net core开源项目,其中包括了Consul + .NET Core + Polly + Ocelot + Exceptionless + IdentityServer,你是否闻到了某种味道!

Polly给我们带来了什么

  1. 对http请求提供重试机制
  2. 对指定异常进行特殊的处理
  3. 提供了多种策略

程序中的使用

封装一个方法,对外提供一个委托的参数,把需要进行polly的代码段输入进来即可,对于http,数据库,网络通讯等非常必要,因为这些场景可能存在不稳定的因素!polly正好可以帮我们非常

友好的解决它,下面的代码主要实现了对所有异常的跟踪,然后每1秒重新执行一次,可以重试5次!

        /// <summary>
        /// polly重试机制
        /// </summary>
        private static HttpResponseMessage retryTwoTimesPolicy(Func<HttpResponseMessage> action)
        {
            var policy = Policy
                .Handle<Exception>()
                .WaitAndRetry(
                 5,
                 retryAttempt => TimeSpan.FromSeconds(Math.Pow(1, retryAttempt)),
                 (ex, timer, c, i) =>
                 {
                     logger.Logger_Info($"执行失败! 重试次数 {c}");
                     logger.Logger_Info($"异常来自 {ex.GetType().Name}");
                 });
            return policy.Execute(action);
        }

我们之前的httpHelper请求对象,也可以引入polly机制,全局进行控制!

        /// <summary>
        /// GET请求
        /// </summary>
        /// <param name="requestUri">服务地址</param>
        /// <param name="nv">参数键值</param>
        /// <returns></returns>
        public static HttpResponseMessage Get(
            string requestUri,
            NameValueCollection nv)
        {
            try
            {

                return retryTwoTimesPolicy(() =>
                {
                    var result = httpClient.GetAsync(GeneratorUri(requestUri, nv)).Result;
                    UnGZip(result);
                    return result;
                });
            }
            catch (Exception ex)
            {
                throw ex;
            }
        }

自己开两个api进程,一个是对外提供服务,别一个作为主服务器,被其它进行访问,当它挂了之后,其实进行可以通过polly进行重试!

技术分享图片

感谢各位的阅读!

微服务来了,但需要我们关注的点多了!

奋斗吧!

回到目录

LindDotNetCore~Polly组件对微服务场景的价值

标签:gen   图片   wot   项目   identity   pos   cti   服务架构   tps   

原文地址:https://www.cnblogs.com/lori/p/8387205.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!