本文整理汇总了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);
}
示例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);
}
示例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()
};
}
}
示例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);
}
示例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);
}
示例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;
}
}
示例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()
};
}
}
示例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;
}
示例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;
}
示例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);
}
}
示例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;
}
示例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);
}
}
示例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;
}
示例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;
}
}
示例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));
}
}