当前位置: 首页>>代码示例>>C#>>正文


C# TelemetryClient.TrackDependency方法代码示例

本文整理汇总了C#中Microsoft.ApplicationInsights.TelemetryClient.TrackDependency方法的典型用法代码示例。如果您正苦于以下问题:C# TelemetryClient.TrackDependency方法的具体用法?C# TelemetryClient.TrackDependency怎么用?C# TelemetryClient.TrackDependency使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Microsoft.ApplicationInsights.TelemetryClient的用法示例。


在下文中一共展示了TelemetryClient.TrackDependency方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: Index

        public ActionResult Index()
        {
            var sw = Stopwatch.StartNew();
            var ai = new TelemetryClient();
            var startTime = DateTime.UtcNow;
            var newsViewModel = new List<NewsModel>();
            var spContext = SharePointContextProvider.Current.GetSharePointContext(HttpContext);

            using (var clientContext = spContext.CreateUserClientContextForSPHost())
            {
                if (clientContext == null) return View(newsViewModel);

                //get user info
                var spUser = clientContext.Web.CurrentUser;
                clientContext.Load(spUser, user => user.LoginName);
                clientContext.ExecuteQuery();

                IDatabase cache = RedisHelper.Connection.GetDatabase();
                var cacheKey = $"news_{spUser.LoginName}";

                if (cache.KeyExists(cacheKey))
                {
                    newsViewModel = JsonConvert.DeserializeObject<List<NewsModel>>(cache.StringGet(cacheKey));
                    sw.Stop();
                    var timespanCache = sw.Elapsed;
                    ViewBag.Time = $"{timespanCache.Minutes:00}m:{timespanCache.Seconds:00}s:{timespanCache.Milliseconds / 10:00}ms";
                    ai.TrackDependency("Redis", cacheKey, startTime, sw.Elapsed, true);
                    return View(newsViewModel);
                }

                //Get news items
                Web web = clientContext.Web;
                List newsList = web.GetList("sites/Portal/Lists/News");
                clientContext.Load(newsList);
                var items = newsList.GetItems(CamlQuery.CreateAllItemsQuery());
                clientContext.Load(items,
                    includes =>
                        includes.Include(y => y["Device"], y => y["Department"], y => y.Client_Title,
                            y => y["NewsContent"]));
                clientContext.ExecuteQuery();



                //get user profile property
                PeopleManager peopleManager = new PeopleManager(clientContext);

                var profilePropertyNames = new[] { "Device", "SPS-Department", "Title" };
                UserProfilePropertiesForUser profilePropertiesForUser = new UserProfilePropertiesForUser(
                    clientContext, spUser.LoginName, profilePropertyNames);
                IEnumerable<string> profilePropertyValues =
                    peopleManager.GetUserProfilePropertiesFor(profilePropertiesForUser);

                // Load the request and run it on the server.
                clientContext.Load(profilePropertiesForUser);
                clientContext.ExecuteQuery();

                var propertyValues = profilePropertyValues as IList<string> ?? profilePropertyValues.ToList();
                var devices = propertyValues.ToList()[0];
                var department = propertyValues.ToList()[1];

                foreach (var item in items)
                {
                    TaxonomyFieldValueCollection col = item["Device"] as TaxonomyFieldValueCollection;

                    foreach (var taxItem in col)
                    {
                        if (devices.Contains(taxItem.Label))
                        {
                            int index = newsViewModel.FindIndex(i => i.Title == item.Client_Title);
                            if (index != 0)
                            {
                                newsViewModel.Add(new NewsModel(item.Client_Title, item["NewsContent"].ToString()));
                            }
                        }
                    }
                }
                cache.StringSet(cacheKey, JsonConvert.SerializeObject(newsViewModel), new TimeSpan(0, 0, 1, 0));
            }


            sw.Stop();
            var timespan = sw.Elapsed;
            ViewBag.Time = $"{timespan.Minutes:00}m:{timespan.Seconds:00}s:{timespan.Milliseconds / 10:00}ms";
            ai.TrackDependency("SharePoint", "GetNews", startTime, sw.Elapsed, true);
            return View(newsViewModel);
        }
开发者ID:RickVanRousselt,项目名称:PerformanceAddIn,代码行数:86,代码来源:NewsController.cs

示例2: GetTips

        public async Task<JsonpResult> GetTips()
        {
            IDatabase cache = RedisHelper.Connection.GetDatabase();
            var cacheKey = "tip";
            var ai = new TelemetryClient();
            var startTime = DateTime.UtcNow;
            var timer = System.Diagnostics.Stopwatch.StartNew();

            if (cache.KeyExists(cacheKey))
            {
                timer.Stop();
                ai.TrackDependency("Redis", "GetTip", startTime, timer.Elapsed, true);
                return new JsonpResult(JsonConvert.DeserializeObject<TipsModel>(await cache.StringGetAsync(cacheKey)));
            }

            var tip = GetTipForCurrentUser();

            await cache.StringSetAsync(cacheKey, JsonConvert.SerializeObject(tip), new TimeSpan(0, 0, 10, 0));
            timer.Stop();
            ai.TrackDependency("SharePoint", "GetTip", startTime, timer.Elapsed, true);
            return new JsonpResult(tip);
        }
开发者ID:RickVanRousselt,项目名称:PerformanceAddIn,代码行数:22,代码来源:NewsController.cs


注:本文中的Microsoft.ApplicationInsights.TelemetryClient.TrackDependency方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。