Поделиться через


Импорт и вызов рабочего процесса Windows PowerShell

Windows PowerShell 3 позволяет импортировать и вызвать рабочий процесс, упакованный в виде модуля Windows PowerShell. Сведения о модулях Windows PowerShell см. в статье "Написание модуля Windows PowerShell".

Класс System.Management.Automation.Psjobproxyиспользуется в качестве клиентского прокси-сервера для объектов рабочего процесса на сервере. В следующей процедуре объясняется, как использовать объект System.Management.Automation.Psjobproxyдля вызова рабочего процесса.

Создание объекта PSJobProxy для выполнения команд рабочего процесса на удаленном сервере.

  1. Создайте объект System.Management.Automation.Runspaces.Wsmanconnectioninfo, чтобы создать подключение к удаленному пространству выполнения.

  2. Задайте свойство System.Management.Automation.Runspaces.Wsmanconnectioninfo.Shelluri* объекта System.Management.Automation.Runspaces.Wsmanconnectioninfo, чтобы указать конечную точку Microsoft.PowerShell.Workflow Windows PowerShell.

  3. Создайте пространство выполнения, использующее подключение, созданное путем выполнения предыдущих шагов.

  4. Создайте объект System.Management.Automation.Powershellи задайте для его свойства System.Management.Automation.Powershell.Runspace* пространство выполнения, созданное на предыдущем шаге.

  5. Импортируйте модуль рабочего процесса и его команды в System.Management.Automation.Powershell.

  6. Создайте объект System.Management.Automation.Psjobproxy и используйте его для выполнения команд рабочего процесса на удаленном сервере.

Пример

В следующем примере кода показано, как вызвать рабочий процесс с помощью Windows PowerShell.

В этом примере требуется Windows PowerShell 3.

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Management.Automation;
using System.Management.Automation.Runspaces;

namespace WorkflowHostTest
{

class Program
    {
        static void Main(string[] args)
        {
            if (args.Length == 0)
            {
                Console.WriteLine("Specify path to Workflow module");
                return;
            }

            string moduleFile = args[0];

            Console.Write("Creating Remote runspace connection...");
            WSManConnectionInfo connectionInfo = new WSManConnectionInfo();

            //Set the shellURI to workflow endpoint Microsoft.PowerShell.Workflow
            connectionInfo.ShellUri = "Microsoft.PowerShell.Workflow";

            //Create and open a runspace.
            Runspace runspace = RunspaceFactory.CreateRunspace(connectionInfo);
            runspace.Open();
            Console.WriteLine("done");

            PowerShell powershell = PowerShell.Create();
            powershell.Runspace = runspace;
            Console.Write("Setting $VerbosePreference=\"Continue\"...");
            powershell.AddScript("$VerbosePreference=\"Continue\"");
            powershell.Invoke();
            Console.WriteLine("done");

            Console.Write("Importing Workflow module...");
            powershell.Commands.Clear();

            //Import the module in to the PowerShell runspace. A XAML file could also be imported directly by using Import-Module.
            powershell.AddCommand("Import-Module").AddArgument(moduleFile);
            powershell.Invoke();
            Console.WriteLine("done");

            Console.Write("Creating job proxy...");
            powershell.Commands.Clear();
            powershell.AddCommand("Get-Proc").AddArgument("*");
            PSJobProxy job = powershell.AsJobProxy();
            Console.WriteLine("done");

                Console.WriteLine();
                Console.WriteLine("Using job proxy and performing operations...");
                Console.WriteLine("State of Job :" + job.JobStateInfo.State.ToString());
                Console.WriteLine("Starting job...");
                job.StartJob();
                Console.WriteLine("State of Job :" + job.JobStateInfo.State.ToString());

                // use blocking enumerator to wait for objects until job finishes
                job.Output.BlockingEnumerator = true;
                foreach (PSObject o in job.Output)
                {
                    Console.WriteLine(o.Properties["ProcessName"].Value.ToString());
                }

                // wait for a random time before attempting to stop job
                Random random = new Random();
                int time = random.Next(1, 10);
                Console.Write("Sleeping for {0} seconds when job is running on another thread...", time);
                System.Threading.Thread.Sleep(time * 1000);
                Console.WriteLine("done");
                Console.WriteLine("Stopping job...");
                job.StopJob();
                Console.WriteLine("State of Job :" + job.JobStateInfo.State.ToString());
                Console.WriteLine();
                job.Finished.WaitOne();
                Console.WriteLine("Output from job");
                Console.WriteLine("---------------");

                foreach (PSObject o in job.Output)
                {
                    Console.WriteLine(o.Properties["ProcessName"].Value.ToString());
                }

                Console.WriteLine();
                Console.WriteLine("Verbose messages from job");
                Console.WriteLine("-------------------------");
                foreach (VerboseRecord v in job.Verbose)
                {
                    Console.WriteLine(v.Message);
                }

            runspace.Close();
        }
    }
}