因此,我有一个IIS10 few服务器,运行相当多的应用程序,例如:
+ Default Web Site
-First Application
-Second Application
-Third Application
我们使用nLog将内容记录到数据库中,其中一个是当前的应用程序域
${appdomain:format=Format}
如https://github.com/NLog/NLog/wiki/AppDomain-Layout-Renderer所述。
这很好,除了当我查看我们的整合日志时,我看到appdomain被记录为:
0002:/LM/W3SVC/2/ROOT-1-132036049222959352
我希望将其转换为"Third Application“(因此,当我创建报告时,它将显示为"Third Application”,而不是0002:/LM/W3SVC/2/ROOT-1-132036049222959352。)
条件包括:
我不能更改layoutrenderer.
我尝试过Microsoft.Web.Administration,类似于:
using (ServerManager sm = new ServerManager()){
var thisVal = (from s in sm.Sites
from app in s.Applications
from vDir in app.VirtualDirectories
where vDir.Path.Equals(currVal,StringComparison.InvariantCultureIgnoreCase)
select new KeyValuePair<string, string>(currVal, vDir.Path));
}
但是我在那里找不到应用的根目录。我相信它和https://docs.microsoft.com/en-us/previous-versions/iis/6.0-sdk/ms524308(v=vs.90)是一样的,但那是IIS元数据库,它显然是旧的和坏的。
(上面的代码将与应用程序运行在同一台机器上,所以我不必担心找到正确的服务器,只需翻译名称)
发布于 2019-06-13 22:11:49
您可以枚举(从而过滤)AppDomain的id,如下所示:
using (ServerManager s = new ServerManager())
{
var processList = from m in Process.GetProcessesByName("w3wp") select m.Id;
IEnumerable<WorkerProcess> workerP = (from p in s.ApplicationPools
from w in p.WorkerProcesses
where processList.Any(vn => vn == w.ProcessId)
select w);
foreach (var workProcess in workerP)
{
Console.WriteLine(
$"{workProcess.AppPoolName} Id:{workProcess.ProcessId} AppDomains Count: {workProcess.ApplicationDomains?.Count}");
var ad = workProcess.ApplicationDomains;
if (!ad.Any()) continue;
foreach (var curDomain in ad)
{
Console.WriteLine($"AppDomain: {curDomain.Id} {curDomain.VirtualPath}");
}
}
}
这将为您提供显示AppDomain ids的输出,您可以从中获取vdir:
DefaultAppPool Id:33180 AppDomains Count: 1
AppDomain: /LM/W3SVC/1/ROOT/
https://stackoverflow.com/questions/56360688
复制相似问题