5

目标是获得 Exchange 2010 站点的最小数据库,因此我尝试从 c# 运行以下 powershell 命令,

Get-MailboxDatabase -server Exchange2010 -Status | select-object Name,DatabaseSize

我正在努力的问题是 - 如何管道 Select 子句命令。

这是我的尝试,

WSManConnectionInfo wsConnectionInfo = new WSManConnectionInfo(new Uri("https://" + ExchangeSite + "/powershell?serializationLevel=Full"),
    "http://schemas.microsoft.com/powershell/Microsoft.Exchange", getCredential());
wsConnectionInfo.AuthenticationMechanism = AuthenticationMechanism.Basic;
wsConnectionInfo.SkipCACheck = true;
wsConnectionInfo.SkipCNCheck = true;

rsRemoteRunspace = RunspaceFactory.CreateRunspace(wsConnectionInfo);
rsRemoteRunspace.Open();
Pipeline pipeLine = rsRemoteRunspace.CreatePipeline();

Collection<PSObject> DatabaSize = null;

Command myCommand = new Command("Get-MailboxDatabase");
myCommand.Parameters.Add("Server", "Exchange2010");
myCommand.Parameters.Add("Status", null);
Command myCommand2 = new Command("Select-Object");
    myCommand.Parameters.Add("Name");
myCommand.Parameters.Add("DatabaseSize");
pipeLineMB.Commands.Add(myCommand);
pipeLineMB.Commands.Add(myCommand2);
DatabaSize = pipeLine.Invoke();

但我得到,

"A parameter cannot be found that matches parameter name 'Name'."

请记住,我不能使用 SnapIn,因为代码必须在执行 Exchange 服务器上的 cmdlet 的客户端计算机上运行。

欢迎任何建议。

编辑

我应用了 yamen 建议的修复程序,并且可以调用该命令,但是当我尝试获取该值时,我得到:“对象引用未设置为对象的实例。”

例外

请注意,我可以获取 Servername 和 Name 的值,但它在 DatabaseSize 中失败,所以我猜 'Status' 标志未正确设置,因为该标志是启用此值的标志。

4

2 回答 2

4

你的意思是这样的:

Command myCommand2 = new Command("Select-Object");
myCommand2.Parameters.Add("DatabaseSize");

而不是这个:

Command myCommand2 = new Command("Select-Object");
myCommand.Parameters.Add("DatabaseSize");

注意myCommand2第二行?

无论如何,您可能会发现您实际使用的参数是Property

myCommand2.Parameters.Add("Property", "DatabaseSize");

不止一个:

var props = new string[] { "DatabaseSize", "ServerName", "Name" };
myCommand2.Parameters.Add("Property", props);
于 2012-05-01T03:37:37.193 回答
2

我刚试过这个,有一个类似的场景

dir | select Name

它不起作用。给我同样的错误,说“名称”不是有效参数。然后我尝试了以下方法,它有效

dir | select -first 3

翻译成

        Runspace runspace = RunspaceFactory.CreateRunspace();
        runspace.Open();
        Pipeline pipeline = runspace.CreatePipeline();
        Command dir = new Command("dir");
        pipeline.Commands.Add(dir);
        Command select = new Command("select");
        select.Parameters.Add("first", 3);
        pipeline.Commands.Add(select);

你需要找到参数的名称DatabaseSize,我猜是它的值。

于 2012-05-01T03:19:05.157 回答