-
Notifications
You must be signed in to change notification settings - Fork 140
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
SNOW-1629635 added system diagnostics
- Loading branch information
1 parent
31e3a0c
commit 3de1edd
Showing
2 changed files
with
63 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,62 @@ | ||
using System; | ||
using System.Diagnostics; | ||
using System.Reflection; | ||
using System.Runtime; | ||
using System.Runtime.InteropServices; | ||
using System.Text; | ||
using Snowflake.Data.Log; | ||
|
||
namespace Snowflake.Data.Core.Tools | ||
{ | ||
internal class Diagnostics | ||
{ | ||
private const int PadRight = -25; | ||
private static readonly SFLogger s_logger = SFLoggerFactory.GetLogger<Diagnostics>(); | ||
|
||
public static void LogDiagnostics() => s_logger.Info(GetDiagnosticInfo()); | ||
|
||
private static string GetDiagnosticInfo() | ||
{ | ||
StringBuilder info = new StringBuilder("System Diagnostics:\n"); | ||
info.AppendLine($"{"OS", PadRight}: {OsName()}"); | ||
info.AppendLine($"{"OS Description", PadRight}: {RuntimeInformation.OSDescription}"); | ||
info.AppendLine($"{"OS Architecture", PadRight}: {RuntimeInformation.OSArchitecture}"); | ||
info.AppendLine($"{"OS Version", PadRight}: {Environment.OSVersion}"); | ||
info.AppendLine($"{"OS x64", PadRight}: {Environment.Is64BitOperatingSystem}"); | ||
info.AppendLine($"{"Processor Architecture", PadRight}: {RuntimeInformation.ProcessArchitecture}"); | ||
info.AppendLine($"{"Processor Count", PadRight}: {Environment.ProcessorCount}"); | ||
info.AppendLine($"{".NET Framework", PadRight}: {RuntimeInformation.FrameworkDescription}"); | ||
info.AppendLine($"{"CLR Runtime Version", PadRight}: {Environment.Version}"); | ||
info.AppendLine($"{"App x64", PadRight}: {Environment.Is64BitProcess}"); | ||
info.AppendLine($"{"GC Server Mode", PadRight}: {GCSettings.IsServerGC}"); | ||
info.AppendLine($"{"GC LOH Compaction Mode", PadRight}: {GCSettings.LargeObjectHeapCompactionMode}"); | ||
info.AppendLine($"{"GC Latency Mode", PadRight}: {GCSettings.LatencyMode}"); | ||
info.AppendLine($"{"GC Total Memory", PadRight}: {GC.GetTotalMemory(false)}"); | ||
AppendAssemblyInfo(info, Assembly.GetEntryAssembly(), "App"); | ||
AppendAssemblyInfo(info, Assembly.GetExecutingAssembly(), "Driver"); | ||
return info.ToString(); | ||
} | ||
|
||
private static void AppendAssemblyInfo(StringBuilder info, Assembly assembly, string assemblyTag) | ||
{ | ||
if (assembly != null) | ||
{ | ||
var assemblyVersion = FileVersionInfo.GetVersionInfo(assembly.Location); | ||
info.AppendLine($"{assemblyTag + " Name", PadRight}: {assemblyVersion.InternalName}"); | ||
info.AppendLine($"{assemblyTag + " File", PadRight}: {assemblyVersion.FileName}"); | ||
info.AppendLine($"{assemblyTag + " Version", PadRight}: {assemblyVersion.FileVersion}"); | ||
} | ||
} | ||
|
||
private static string OsName() | ||
{ | ||
if (RuntimeInformation.IsOSPlatform(OSPlatform.Linux)) | ||
return "UNIX"; | ||
if (RuntimeInformation.IsOSPlatform(OSPlatform.Windows)) | ||
return "WINDOWS"; | ||
if (RuntimeInformation.IsOSPlatform(OSPlatform.OSX)) | ||
return "OSX"; | ||
return "Unknown"; | ||
} | ||
} | ||
} |