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


C# PerfTracker类代码示例

本文整理汇总了C#中PerfTracker的典型用法代码示例。如果您正苦于以下问题:C# PerfTracker类的具体用法?C# PerfTracker怎么用?C# PerfTracker使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。


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

示例1: ReadSequential

        public override PerformanceRecord ReadSequential(PerfTracker perfTracker)
        {
            IEnumerable<uint> sequentialIds = Enumerable.Range(0, Constants.ReadItems).Select(x => (uint)x); ;

            return Read(string.Format("[FoundationDB] sequential read ({0} items)", Constants.ReadItems), sequentialIds,
                perfTracker);
        }
开发者ID:j2jensen,项目名称:ravendb,代码行数:7,代码来源:FdbTest.cs

示例2: WriteParallelRandom

 public override List<PerformanceRecord> WriteParallelRandom(IEnumerable<TestData> data, PerfTracker perfTracker,
     int numberOfThreads, out long elapsedMilliseconds)
 {
     return
         WriteParallel(
             string.Format("[FoundationDB] parallel random write ({0} items)", Constants.ItemsPerTransaction),
             data,
             Constants.ItemsPerTransaction, Constants.WriteTransactions, perfTracker, numberOfThreads,
             out elapsedMilliseconds);
 }
开发者ID:j2jensen,项目名称:ravendb,代码行数:10,代码来源:FdbTest.cs

示例3: Read

        private PerformanceRecord Read(string operation, IEnumerable<uint> ids, PerfTracker perfTracker)
        {
			LightningDatabase db;
            using (var env = NewEnvironment(out db, delete: false))
            {
                var sw = Stopwatch.StartNew();

                ReadInternal(ids, perfTracker, env, db);

                sw.Stop();

                return new PerformanceRecord
                {
                    Operation = operation,
                    Time = DateTime.Now,
                    Duration = sw.ElapsedMilliseconds,
                    ProcessedItems = ids.Count()
                };
            }
        }
开发者ID:WimVergouwe,项目名称:ravendb,代码行数:20,代码来源:LmdbTest.cs

示例4: ReadParallelRandom

 public override PerformanceRecord ReadParallelRandom(IEnumerable<uint> randomIds, PerfTracker perfTracker, int numberOfThreads)
 {
     return ReadParallel(string.Format("[Voron] parallel random read ({0} items)", Constants.ReadItems), randomIds, perfTracker, numberOfThreads);
 }
开发者ID:ReginaBricker,项目名称:ravendb,代码行数:4,代码来源:VoronTest.cs

示例5: ReadParallelSequential

        public override PerformanceRecord ReadParallelSequential(PerfTracker perfTracker, int numberOfThreads)
        {
			var sequentialIds = Enumerable.Range(0, Constants.ReadItems).Select(x => (uint)x);

            return ReadParallel(string.Format("[Voron] parallel sequential read ({0} items)", Constants.ReadItems), sequentialIds, perfTracker, numberOfThreads);
        }
开发者ID:ReginaBricker,项目名称:ravendb,代码行数:6,代码来源:VoronTest.cs

示例6: ReadInternal

        private static long ReadInternal(IEnumerable<uint> ids, PerfTracker perfTracker, StorageEnvironment env)
        {
            var ms = new byte[4096];

            using (var tx = env.NewTransaction(TransactionFlags.Read))
            {
                var sw = Stopwatch.StartNew();
                long v = 0;
                foreach (var id in ids)
                {
                    var key = id.ToString("0000000000000000");
                    var readResult = tx.State.Root.Read(tx, key);
                    int reads = 0;
                    while ((reads = readResult.Reader.Read(ms, 0, ms.Length)) > 0)
                    {
                        v += reads;
                    }
	             
                }
                perfTracker.Record(sw.ElapsedMilliseconds);
                return v;
            }
        }
开发者ID:ReginaBricker,项目名称:ravendb,代码行数:23,代码来源:VoronTest.cs

示例7: Read

        private PerformanceRecord Read(string operation, IEnumerable<uint> ids, PerfTracker perfTracker)
        {
            var options = StorageEnvironmentOptions.ForPath(dataPath);
            options.ManualFlushing = true;

            using (var env = new StorageEnvironment(options))
            {
                env.FlushLogToDataFile();

                var sw = Stopwatch.StartNew();

                var v = ReadInternal(ids, perfTracker, env);

                sw.Stop();

                return new PerformanceRecord
                {
                    Bytes = v,
                    Operation = operation,
                    Time = DateTime.Now,
                    Duration = sw.ElapsedMilliseconds,
                    ProcessedItems = ids.Count()
                };
            }
        }
开发者ID:ReginaBricker,项目名称:ravendb,代码行数:25,代码来源:VoronTest.cs

示例8: WriteInternalBatch

        private List<PerformanceRecord> WriteInternalBatch(
            string operation,
            IEnumerator<TestData> enumerator,
            long itemsPerBatch,
            long numberOfBatches,
            PerfTracker perfTracker,
            StorageEnvironment env)
        {
            var sw = new Stopwatch();
            byte[] valueToWrite = null;
            var records = new List<PerformanceRecord>();
            for (var b = 0; b < numberOfBatches; b++)
            {
                sw.Restart();
                long v = 0;
                using (var batch = new WriteBatch())
                {
                    for (var i = 0; i < itemsPerBatch; i++)
                    {
                        enumerator.MoveNext();

                        valueToWrite = GetValueToWrite(valueToWrite, enumerator.Current.ValueSize);
                        v += valueToWrite.Length;
                        batch.Add(enumerator.Current.Id.ToString("0000000000000000"), new MemoryStream(valueToWrite), "Root");
                    }

                    env.Writer.Write(batch);
                }

                sw.Stop();
                perfTracker.Record(sw.ElapsedMilliseconds);

                records.Add(new PerformanceRecord
                {
                    Bytes = v,
                    Operation = operation,
                    Time = DateTime.Now,
                    Duration = sw.ElapsedMilliseconds,
                    ProcessedItems = itemsPerBatch
                });
            }

            return records;
        }
开发者ID:ReginaBricker,项目名称:ravendb,代码行数:44,代码来源:VoronTest.cs

示例9: WriteInternalAsync

        private async Task<List<PerformanceRecord>> WriteInternalAsync(string operation,
            IEnumerator<TestData> enumerator,
            long itemsPerTransaction, long numberOfTransactions, PerfTracker perfTracker, FdbDatabase db)
        {
            var sw = new Stopwatch();
            byte[] valueToWrite = null;
            var records = new List<PerformanceRecord>();

            var location = db.GlobalSpace;

            sw.Restart();
            for (int transactions = 0; transactions < numberOfTransactions; transactions++)
            {
                sw.Restart();
                using (IFdbTransaction tx = db.BeginTransaction())
                {
                    for (int i = 0; i < itemsPerTransaction; i++)
                    {
                        enumerator.MoveNext();

                        valueToWrite = GetValueToWrite(valueToWrite, enumerator.Current.ValueSize);

                        tx.Set(location.Pack(enumerator.Current.Id), Slice.Create(valueToWrite));
                    }

                    await tx.CommitAsync();
                    perfTracker.Record(sw.ElapsedMilliseconds);
                }

                sw.Stop();

                records.Add(new PerformanceRecord
                {
                    Operation = operation,
                    Time = DateTime.Now,
                    Duration = sw.ElapsedMilliseconds,
                    ProcessedItems = itemsPerTransaction
                });
            }

            sw.Stop();

            return records;
        }
开发者ID:j2jensen,项目名称:ravendb,代码行数:44,代码来源:FdbTest.cs

示例10: WriteParallelAsync

        private async Task<Tuple<List<PerformanceRecord>, long>> WriteParallelAsync(string operation,
            IEnumerable<TestData> data,
            int itemsPerTransaction, int numberOfTransactions, PerfTracker perfTracker, int numberOfThreads)
        {
            await NewDatabaseAsync();

            using (FdbDatabase db = await OpenDatabaseAsync())
            {
                long elapsedMilliseconds;
                List<PerformanceRecord> records = ExecuteWriteWithParallel(
                    data,
                    numberOfTransactions,
                    itemsPerTransaction,
                    numberOfThreads,
                    (enumerator, itmsPerTransaction, nmbrOfTransactions) =>
                        WriteInternal(operation, enumerator, itmsPerTransaction, nmbrOfTransactions, perfTracker, db),
                    out elapsedMilliseconds);
                return new Tuple<List<PerformanceRecord>, long>(records, elapsedMilliseconds);
            }
        }
开发者ID:j2jensen,项目名称:ravendb,代码行数:20,代码来源:FdbTest.cs

示例11: WriteParallel

 private List<PerformanceRecord> WriteParallel(string operation, IEnumerable<TestData> data,
     int itemsPerTransaction, int numberOfTransactions, PerfTracker perfTracker, int numberOfThreads,
     out long elapsedMilliseconds)
 {
     Tuple<List<PerformanceRecord>, long> result
         =
         WriteParallelAsync(operation, data, itemsPerTransaction, numberOfTransactions, perfTracker,
             numberOfThreads).Result;
     elapsedMilliseconds = result.Item2;
     return result.Item1;
 }
开发者ID:j2jensen,项目名称:ravendb,代码行数:11,代码来源:FdbTest.cs

示例12: WriteAsync

        private async Task<List<PerformanceRecord>> WriteAsync(string operation, IEnumerable<TestData> data,
            int itemsPerTransaction,
            int numberOfTransactions, PerfTracker perfTracker)
        {
            await NewDatabaseAsync();

            using (FdbDatabase db = await OpenDatabaseAsync())
            {
                IEnumerator<TestData> enumerator = data.GetEnumerator();

                return WriteInternal(operation, enumerator, itemsPerTransaction, numberOfTransactions, perfTracker, db);
            }
        }
开发者ID:j2jensen,项目名称:ravendb,代码行数:13,代码来源:FdbTest.cs

示例13: Write

 private List<PerformanceRecord> Write(string operation, IEnumerable<TestData> data, int itemsPerTransaction,
     int numberOfTransactions, PerfTracker perfTracker)
 {
     return WriteAsync(operation, data, itemsPerTransaction, numberOfTransactions, perfTracker).Result;
 }
开发者ID:j2jensen,项目名称:ravendb,代码行数:5,代码来源:FdbTest.cs

示例14: ReadInternal

        private static long ReadInternal(IEnumerable<uint> ids, PerfTracker perfTracker, LightningEnvironment env,
			LightningDatabase db)
        {
            using (var tx = env.BeginTransaction(LightningDB.TransactionBeginFlags.ReadOnly))
			using (var cursor = new LightningCursor(db, tx))
            {
                long v = 0;
                foreach (var id in ids)
                {
                    var value = cursor.MoveTo(Encoding.UTF8.GetBytes(id.ToString("0000000000000000")));
                    v += value.Value.Length;
                    //Debug.Assert(value != null);
                }
                return v;
            }
        }
开发者ID:WimVergouwe,项目名称:ravendb,代码行数:16,代码来源:LmdbTest.cs

示例15: ReadParallel

        private PerformanceRecord ReadParallel(string operation, IEnumerable<uint> ids, PerfTracker perfTracker, int numberOfThreads)
        {
			LightningDatabase db;
            using (var env = NewEnvironment(out db, delete: false))
            {
                return ExecuteReadWithParallel(operation, ids, numberOfThreads, () => ReadInternal(ids, perfTracker, env, db));
            }
        }
开发者ID:WimVergouwe,项目名称:ravendb,代码行数:8,代码来源:LmdbTest.cs


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