Skip to content

Commit

Permalink
Merge pull request #2694 from area363/add-tracing
Browse files Browse the repository at this point in the history
Add pyroscope tracing
  • Loading branch information
area363 authored Jul 17, 2024
2 parents c3b7b2d + 482f099 commit 57d7bf5
Show file tree
Hide file tree
Showing 2 changed files with 96 additions and 0 deletions.
92 changes: 92 additions & 0 deletions Lib9c/Action/HackAndSlash.cs
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,7 @@ public class HackAndSlash : GameAction, IHackAndSlashV10
public Address AvatarAddress;
public int TotalPlayCount = 1;
public int ApStoneCount = 0;
private readonly ActivitySource _activitySource = new ActivitySource("Lib9c.Action.HackAndSlash");

IEnumerable<Guid> IHackAndSlashV10.Costumes => Costumes;
IEnumerable<Guid> IHackAndSlashV10.Equipments => Equipments;
Expand Down Expand Up @@ -117,6 +118,7 @@ public IWorld Execute(
var addressesHex = $"[{signer.ToHex()}, {AvatarAddress.ToHex()}]";
var started = DateTimeOffset.UtcNow;
const string source = "HackAndSlash";
var activity = _activitySource.StartActivity("HackAndSlash");
Log.Verbose("{AddressesHex} {Source} from #{BlockIndex} exec started",
addressesHex, source, blockIndex);

Expand Down Expand Up @@ -145,17 +147,27 @@ public IWorld Execute(

var sw = new Stopwatch();
sw.Start();
var avatarStateActivity = _activitySource.StartActivity(
"GetAvatarState",
ActivityKind.Internal,
activity?.Id ?? string.Empty);
if (!states.TryGetAvatarState(signer, AvatarAddress, out AvatarState avatarState))
{
throw new FailedLoadStateException(
$"{addressesHex}Aborted as the avatar state of the signer was failed to load.");
}

avatarStateActivity?.Dispose();
sw.Stop();
Log.Verbose("{AddressesHex} {Source} HAS {Process} from #{BlockIndex}: {Elapsed}",
addressesHex, source, "Get AvatarState", blockIndex, sw.Elapsed.TotalMilliseconds);

sw.Restart();
var sheetActivity = _activitySource.StartActivity(
"GetSheets",
ActivityKind.Internal,
activity?.Id ?? string.Empty);

var collectionExist = states.TryGetCollectionState(AvatarAddress, out var collectionState) && collectionState.Ids.Any();
var sheetTypes = new List<Type>
{
Expand Down Expand Up @@ -190,11 +202,18 @@ public IWorld Execute(
containQuestSheet: true,
containSimulatorSheets: true,
sheetTypes: sheetTypes);

sheetActivity?.Dispose();
sw.Stop();
Log.Verbose("{AddressesHex} {Source} HAS {Process} from #{BlockIndex}: {Elapsed}",
addressesHex, source, "Get Sheets", blockIndex, sw.Elapsed.TotalMilliseconds);

sw.Restart();

var checkStateActivity = _activitySource.StartActivity(
"CheckState",
ActivityKind.Internal,
activity?.Id ?? string.Empty);
var stakingLevel = 0;
StakeActionPointCoefficientSheet actionPointCoefficientSheet = null;

Expand All @@ -206,6 +225,7 @@ public IWorld Execute(
stakingLevel = actionPointCoefficientSheet.FindLevelByStakedAmount(signer, stakedAmount);
}

checkStateActivity?.Dispose();
sw.Stop();
Log.Verbose("{AddressesHex} {Source} HAS {Process} from #{BlockIndex}: {Elapsed}",
addressesHex, source, "Check StateState", blockIndex, sw.Elapsed.TotalMilliseconds);
Expand All @@ -225,16 +245,25 @@ public IWorld Execute(
}

sw.Restart();
var stageSheetActivity = _activitySource.StartActivity(
"GetStageSheet",
ActivityKind.Internal,
activity?.Id ?? string.Empty);
if (!sheets.GetSheet<StageSheet>().TryGetValue(StageId, out var stageRow))
{
throw new SheetRowNotFoundException(addressesHex, nameof(StageSheet), StageId);
}

stageSheetActivity?.Dispose();
sw.Stop();
Log.Verbose("{AddressesHex} {Source} HAS {Process} from #{BlockIndex}: {Elapsed}",
addressesHex, source, "Get StageSheet", blockIndex, sw.Elapsed.TotalMilliseconds);

sw.Restart();
var validateWorldActivity = _activitySource.StartActivity(
"ValidateWorld",
ActivityKind.Internal,
activity?.Id ?? string.Empty);
var worldInformation = avatarState.worldInformation;
if (!worldInformation.TryGetWorld(WorldId, out var world))
{
Expand Down Expand Up @@ -271,11 +300,16 @@ public IWorld Execute(
);
}

validateWorldActivity?.Dispose();
sw.Stop();
Log.Verbose("{AddressesHex} {Source} HAS {Process} from #{BlockIndex}: {Elapsed}",
addressesHex, source, "Validate World", blockIndex, sw.Elapsed.TotalMilliseconds);

sw.Restart();
var validateItemsActivity = _activitySource.StartActivity(
"ValidateItems",
ActivityKind.Internal,
activity?.Id ?? string.Empty);
var gameConfigState = states.GetGameConfigState();
if (gameConfigState is null)
{
Expand All @@ -287,10 +321,17 @@ public IWorld Execute(
Equipments, blockIndex, gameConfigState);
var foodIds = avatarState.ValidateConsumableV2(Foods, blockIndex, gameConfigState);
var costumeIds = avatarState.ValidateCostumeV2(Costumes, gameConfigState);

validateItemsActivity?.Dispose();
sw.Stop();
Log.Verbose("{AddressesHex} {Source} HAS {Process} from #{BlockIndex}: {Elapsed}",
addressesHex, source, "Validate Items", blockIndex, sw.Elapsed.TotalMilliseconds);
sw.Restart();

var unequipItemsActivity = _activitySource.StartActivity(
"UnequipItems",
ActivityKind.Internal,
activity?.Id ?? string.Empty);
var materialItemSheet = sheets.GetSheet<MaterialItemSheet>();
var apPlayCount = TotalPlayCount;
var minimumCostAp = stageRow.CostAP;
Expand Down Expand Up @@ -367,11 +408,19 @@ public IWorld Execute(
var items = Equipments.Concat(Costumes);
avatarState.EquipItems(items);
sw.Stop();

unequipItemsActivity?.Dispose();
Log.Verbose("{AddressesHex} {Source} HAS {Process} from #{BlockIndex}: {Elapsed}",
addressesHex, source, "Unequip items", blockIndex, sw.Elapsed.TotalMilliseconds);

sw.Restart();
var questSheetActivity = _activitySource.StartActivity(
"GetQuestSheet",
ActivityKind.Internal,
activity?.Id ?? string.Empty);
var questSheet = sheets.GetQuestSheet();

questSheetActivity?.Dispose();
sw.Stop();
Log.Verbose("{AddressesHex} {Source} HAS {Process} from #{BlockIndex}: {Elapsed}",
addressesHex, source, "Get QuestSheet", blockIndex, sw.Elapsed.TotalMilliseconds);
Expand All @@ -384,19 +433,29 @@ public IWorld Execute(
if (ids.Any())
{
sw.Restart();
var questListActivity = _activitySource.StartActivity(
"UpdateQuestList",
ActivityKind.Internal,
activity?.Id ?? string.Empty);
questList.UpdateList(
questSheet,
sheets.GetSheet<QuestRewardSheet>(),
sheets.GetSheet<QuestItemRewardSheet>(),
sheets.GetSheet<EquipmentItemRecipeSheet>(),
ids);
questListActivity?.Dispose();
sw.Stop();
Log.Verbose("{AddressesHex} {Source} HAS {Process} from #{BlockIndex}: {Elapsed}",
addressesHex, source, "Update QuestList", blockIndex, sw.Elapsed.TotalMilliseconds);
}

sw.Restart();

var skillStateActivity = _activitySource.StartActivity(
"GetSkillState",
ActivityKind.Internal,
activity?.Id ?? string.Empty);

var skillStateAddress = Addresses.GetSkillStateAddressFromAvatarAddress(AvatarAddress);
var isNotClearedStage = !avatarState.worldInformation.IsStageCleared(StageId);
var skillsOnWaveStart = new List<Skill>();
Expand Down Expand Up @@ -430,6 +489,7 @@ public IWorld Execute(
}
}

skillStateActivity?.Dispose();
sw.Stop();
Log.Verbose("{AddressesHex} {Source} HAS {Process} from #{BlockIndex}: {Elapsed}",
addressesHex, source, "Get skillState", blockIndex, sw.Elapsed.TotalMilliseconds);
Expand All @@ -438,6 +498,11 @@ public IWorld Execute(
var worldUnlockSheet = sheets.GetSheet<WorldUnlockSheet>();
var crystalStageBuffSheet = sheets.GetSheet<CrystalStageBuffGachaSheet>();
sw.Restart();

var slotstateActivity = _activitySource.StartActivity(
"UpdateSlotState",
ActivityKind.Internal,
activity?.Id ?? string.Empty);
// if PlayCount > 1, it is Multi-HAS.
var simulatorSheets = sheets.GetSimulatorSheets();

Expand Down Expand Up @@ -465,10 +530,17 @@ public IWorld Execute(
{
states = states.SetRuneState(AvatarAddress, runeStates);
}

slotstateActivity?.Dispose();
sw.Stop();
Log.Verbose("{AddressesHex} {Source} HAS {Process} from #{BlockIndex}: {Elapsed}",
addressesHex, source, "Update slotState", blockIndex, sw.Elapsed.TotalMilliseconds);

var simulatorActivity = _activitySource.StartActivity(
"Simulator",
ActivityKind.Internal,
activity?.Id ?? string.Empty);

var stageWaveRow = sheets.GetSheet<StageWaveSheet>()[StageId];
var enemySkillSheet = sheets.GetSheet<EnemySkillSheet>();
var costumeStatSheet = sheets.GetSheet<CostumeStatSheet>();
Expand Down Expand Up @@ -522,6 +594,10 @@ public IWorld Execute(
addressesHex, source, "Simulator.Simulate()", blockIndex, sw.Elapsed.TotalMilliseconds);

sw.Restart();
var clearStageActivity = _activitySource.StartActivity(
"ClearStage",
ActivityKind.Internal,
activity?.Id ?? string.Empty);
if (simulator.Log.IsClear)
{
avatarState.worldInformation.ClearStage(
Expand All @@ -532,11 +608,13 @@ public IWorld Execute(
worldUnlockSheet
);
stageCleared = true;

sw.Stop();
Log.Verbose("{AddressesHex} {Source} HAS {Process} from #{BlockIndex}: {Elapsed}",
addressesHex, source, "ClearStage", blockIndex, sw.Elapsed.TotalMilliseconds);
}

clearStageActivity?.Dispose();
sw.Restart();

// This conditional logic is same as written in the
Expand Down Expand Up @@ -579,21 +657,34 @@ public IWorld Execute(
simulator.Log.waveCount
);
}
simulatorActivity?.Dispose();
sw.Stop();
Log.Debug("{AddressesHex} {Source} {Process} from #{BlockIndex}: {Elapsed}, Count: {PlayCount}",
addressesHex, source, "loop Simulate", blockIndex, sw.Elapsed.TotalMilliseconds, TotalPlayCount);

// Update CrystalRandomSkillState.Stars by clearedWaveNumber. (add)
skillState?.Update(starCount, crystalStageBuffSheet);
sw.Restart();

var updateAvatarActivity = _activitySource.StartActivity(
"UpdateAvatarState",
ActivityKind.Internal,
activity?.Id ?? string.Empty);
avatarState.UpdateQuestRewards(materialItemSheet);
avatarState.updatedAt = blockIndex;
avatarState.mailBox.CleanUp();

updateAvatarActivity?.Dispose();
sw.Stop();
Log.Verbose("{AddressesHex} {Source} HAS {Process} from #{BlockIndex}: {Elapsed}",
addressesHex, source, "Update AvatarState", blockIndex, sw.Elapsed.TotalMilliseconds);

sw.Restart();

var setStateActivity = _activitySource.StartActivity(
"SetState",
ActivityKind.Internal,
activity?.Id ?? string.Empty);
if (isNotClearedStage)
{
avatarState.worldInformation.TryGetLastClearedStageId(out var lastClearedStageId);
Expand All @@ -609,6 +700,7 @@ public IWorld Execute(

states = states.SetAvatarState(AvatarAddress, avatarState);

setStateActivity?.Dispose();
sw.Stop();
Log.Verbose("{AddressesHex} {Source} HAS {Process} from #{BlockIndex}: {Elapsed}",
addressesHex, source, "Set States", blockIndex, sw.Elapsed.TotalMilliseconds);
Expand Down
4 changes: 4 additions & 0 deletions Lib9c/Lib9c.csproj
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,10 @@
</PackageReference>
<PackageReference Include="System.Reactive" Version="4.3.2" />
<PackageReference Include="CsvHelper" Version="15.0.5" />
<!-- Include System.Diagnostics.DiagnosticSource only if targeting netstandard2.1 -->
<PackageReference Include="System.Diagnostics.DiagnosticSource" Version="8.0.0" Condition="'$(TargetFramework)' == 'netstandard2.1'" />
<!-- Include Pyroscope only if not targeting netstandard2.1 -->
<PackageReference Include="Pyroscope" Version="0.8.14" Condition="'$(TargetFramework)' != 'netstandard2.1'" />
</ItemGroup>

<ItemGroup>
Expand Down

0 comments on commit 57d7bf5

Please sign in to comment.