Как заставить веб-сайты работать в текущем пуле приложений с помощью WMI? - PullRequest
0 голосов
/ 23 сентября 2011

Я пытаюсь выяснить, на каких веб-сайтах работает пул приложений. MicrosoftIISv2/WebServerSetting предлагает только свойство AppPoolId, и все значения DefaultAppPool . Я вижу, что все эти пулы приложений работают на разных веб-сайтах IIS. Как я могу заставить веб-сайты работать в пуле приложений с помощью WMI?

1 Ответ

1 голос
/ 25 сентября 2011

Я узнал, что это можно сделать методом EnumAppsInPool.Вот код:

public static IEnumerable<string> GetWebSitesRunningOnApplicationPool(ManagementScope scope, string applicationPoolName)
{
    //get application names from application pool
    string path = string.Format("IIsApplicationPool.Name='W3SVC/APPPOOLS/{0}'", applicationPoolName);
    ManagementPath managementPath = new ManagementPath(path);
    ManagementObject classInstance = new ManagementObject(scope, managementPath, null);
    ManagementBaseObject outParams = classInstance.InvokeMethod("EnumAppsInPool", null, null);


    //get web server names from application names
    IEnumerable<string> nameList = (outParams.Properties["Applications"].Value as string[]) //no null reference exception even there is no application running
                                   .Where(item => !String.IsNullOrEmpty(item)) //but you get empty strings so they are filtered
                                   .ToList() //you get something like /LM/W3SVC/1/ROOT
                                   .Select(item => item.Slice(item.NthIndexOf("/", 2) + 1, item.NthIndexOf("/", 4))); //your WebServer.Name is between 2nd and 4th slahes


    //get server comments from names
    List<string> serverCommentList = new List<string>();
    foreach (string name in nameList)
    {
        ManagementObjectSearcher searcher =
            new ManagementObjectSearcher(scope, new ObjectQuery(string.Format("SELECT ServerComment FROM IIsWebServerSetting WHERE Name = '{0}'", name)));

        serverCommentList.AddRange(from ManagementObject queryObj in searcher.Get() select queryObj["ServerComment"].ToString());
    }

    return serverCommentList;
}

И расширения строк взяты из здесь и здесь

    public static int NthIndexOf(this string target, string value, int n)
    {
        int result = -1;

        Match m = Regex.Match(target, "((" + value + ").*?){" + n + "}");

        if (m.Success)
        {
            result = m.Groups[2].Captures[n - 1].Index;
        }

        return result;
    }

    public static string Slice(this string source, int start, int end)
    {
        if (end < 0) 
        {
            end = source.Length + end;
        }

        int len = end - start;               
        return source.Substring(start, len); 
    }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...