Главная страница
Навигация по странице:

  • Ключевые слова

  • Причины и цели создания новой оболочки

  • Требование Cmd.exe WSH

  • Отличие PowerShell от других оболочек – ориентация на объекты

  • Загрузка и установка PowerShell

  • Запуск оболочки. Выполнение команд

  • комп. Лекция. Лекция 16 1 2


    Скачать 58.36 Kb.
    НазваниеЛекция 16 1 2
    Анкоркомп. сети
    Дата12.11.2020
    Размер58.36 Kb.
    Формат файлаdocx
    Имя файлаЛекция.docx
    ТипЛекция
    #150144

    Лекция 16:

    Введение в оболочку командной строки Windows PowerShell

    A

    |

    версия для печати

    < Лекция 15 || Лекция 16: 12 || Лекция 17 >

    Аннотация: Описываются возможности оболочки Windows PowerShell и отличие ее от традиционных оболочек и языков сценариев. Обсуждаются основные концепции PowerShell (типы команд, структура командлетов, псевдонимы команд). Рассматриваются особенности справочной системы PowerShell

    Ключевые слова: Windows, сервер, monadic, внутренние команды, автозавершение, REN

    Введение в оболочку командной строки Windows PowerShell

    На настоящий момент мы рассмотрели уже три разных инструмента, предназначенных для автоматизации работы в операционной системе Windows: оболочки командной строки Cmd.exe и WMIC, а также сервер сценариев WSH. Зачем же компании Microsoft понадобилась разработка еще одной полностью новой оболочки командной строки со своим языком сценариев?

    Причины и цели создания новой оболочки

    Чтобы ответить на этот вопрос, вспомним основные требования к "идеальному" средству автоматизации, которые мы обсуждали в первой лекции, и посмотрим, в какой степени удовлетворяют этим требованиям перечисленные выше инструменты (табл.16.1).

    Таблица 16.1. Требования к инструменту автоматизации

    Требование

    Cmd.exe

    WSH

    WMIC

    Работа во всех версиях операционной системы без установки дополнительного программного обеспечения

    Да

    Да

    Нет (только Windows XP и выше)

    Интеграция с командной строкой

    Да

    Нет

    Да

    Согласованный и непротиворечивый синтаксис команд и утилит

    Нет

    Нет

    Да

    Поддержка псевдонимов (кратких синонимов) для длинных названий команд

    Нет

    Нет

    Да

    Автоматическое завершения команд и имен файлов при вводе их с клавиатуры

    Частично (автоматическое завершение имен файлов и папок)

    Нет

    Нет

    Поддержка истории введенных команд с возможностью их повторного вызова, просмотра и редактирования

    Да

    Нет

    Да

    Наличие подробной встроенной справки по командам с примерами использования

    Частично

    Нет

    Да

    Возможность автоматического выполнения сценариев

    Да (язык командных файлов)

    Да (языки сценариев VBScript, JScript и т.д.)

    Частично (команды WMIC можно встраивать в командные файлы)

    Доступ и использование всех технологий и возможностей, поддерживаемых операционной системой

    Нет (нет прямого доступа к объектам COM, WMI, ADSI, .NET)

    Да

    Нет (доступ только к объектам WMI)

    Как мы видим, у каждого из рассмотренных нами ранее инструментов автоматизации присутствовали довольно серьезные недостатки, не позволявшие сказать, что Windows обладает по-настоящему мощным и эффективным средством для работы с командной строкой и написания сценариев.

    Новая оболочка Windows PowerShell (предварительно она была названа Monad) была задумана разработчиками Microsoft как более мощная среда для написания сценариев и работы из командной строки. Разработчики PowerShell преследовали несколько целей. Главная и самая амбициозная из них – создать среду составления сценариев, которая наилучшим образом подходила бы для современных версий операционной системы Windows и была бы более функциональной, расширяемой и простой в использовании, чем какой-либо аналогичный продукт для любой другой операционной системы. В первую очередь эта среда должна была подходить для решения задач, стоящих перед системными администраторами (тем самым Windows получила бы дополнительное преимущество в борьбе за сектор корпоративных платформ), а также удовлетворять требованиям разработчиков программного обеспечения, предоставляя им средства для быстрой реализации интерфейсов управления к создаваемым приложениям.

    Для достижения этих целей были решены следующие задачи:

    • Обеспечение прямого доступа из командной строки к объектам COM, WMI и .NET. В новой оболочке присутствуют команды, позволяющие в интерактивном режиме работать с COM-объектами, а также с экземплярами классов, определенных в информационных схемах WMI и .NET.

    • Организация работы с произвольными источниками данных в командной строке по принципу файловой системы. Например, навигация по системному реестру или хранилищу цифровых сертификатов выполняется из командной строки с помощью аналога команды CD интерпретатора Cmd.exe.

    • Разработка интуитивно понятной унифицированной структуры встроенных команд, основанной на их функциональном назначении. В новой оболочке имена всех внутренних команд (в PowerShell они называются командлетами) соответствуют шаблону "глагол-существительное", например, Get-Process (получить информацию о процессе), Stop-Service (остановить службу), Clear-Host (очистить экран консоли) и т.д. Для одинаковых параметров внутренних команд используются стандартные имена, структура параметров во всех командах идентична, все команды обрабатываются одним синтаксическим анализатором. В результате облегчается запоминание и изучение команд.

    • Обеспечение возможности расширения встроенного набора команд. Внутренние команды PowerShell могут дополняться командами, создаваемыми пользователем. При этом они полностью интегрируются в оболочку, информация о них может быть получена из стандартной справочной системы PowerShell.

    • Организация поддержки знакомых команд из других оболочек. В PowerShell на уровне псевдонимов собственных внутренних команд поддерживаются наиболее часто используемые стандартные команды из оболочки Cmd.exe и Unix-оболочек. Например, если пользователь, привыкший работать с Unix-оболочкой, выполнит ls, то он получит ожидаемый результат: список файлов в текущем каталоге (то же самое относится к команде dir).

    • Разработка полноценной встроенной справочной системы для внутренних команд. Для большинства внутренних команд в справочной системе дано подробное описание и примеры использования. В любом случае встроенная справка по любой внутренней команде будет содержать краткое описание всех ее параметров.

    • Реализация автоматического завершения при вводе с клавиатуры имен команд, их параметров, а также имен файлов и папок. Данная возможность значительно упрощает и ускоряет ввод команд с клавиатуры.

    Главной особенностью среды PowerShell, отличающей ее от всех других оболочек командной строки, является то, что единицей обработки и передачи информации здесь является объект, а не строка текста.

    Отличие PowerShell от других оболочек – ориентация на объекты

    При разработке любого языка программирования одним из основных является вопрос о том, какие типы данных и каким образом будут в нем представлены. При создании PowerShell разработчики решили не изобретать ничего нового и воспользоваться унифицированной объектной моделью .NET. Данный выбор был сделан по нескольким причинам.

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

    Во-вторых, объектная модель .NET является самодокументируемой: каждый объект .NET содержит информацию о своей структуре. При интерактивной работе это очень полезно, так как появляется возможность непосредственно из командной строки выполнить запрос к определенному объекту и увидеть описание его свойств и методов, то есть понять, какие именно манипуляции можно проделать с данным объектом, не изучая дополнительной документации с его описанием.

    В-третьих, работая в оболочке с объектами, можно с помощью их свойств и методов легко получать нужные данные, не занимаясь разбором и анализом символьной информации, как это происходит во всех традиционных тексто-ориентированных оболочках командной строки. Рассмотрим пример. В Windows XP есть консольная утилита tasklist.exe, которая выдает информацию о процессах запущенных в системе:

    C:\>tasklist
    Имя образа PID Имя сессии № сеанса Память

    ========================= ====== ================ ======== ============

    System Idle Process 0 0 16 КБ

    System 4 0 32 КБ

    smss.exe 560 0 68 КБ

    csrss.exe 628 0 4 336 КБ

    winlogon.exe 652 0 3 780 КБ

    services.exe 696 0 1 380 КБ

    lsass.exe 708 0 1 696 КБ

    svchost.exe 876 0 1 164 КБ

    svchost.exe 944 0 1 260 КБ

    svchost.exe 1040 0 10 144 КБ

    svchost.exe 1076 0 744 КБ

    svchost.exe 1204 0 800 КБ

    spoolsv.exe 1296 0 1 996 КБ

    kavsvc.exe 1516 0 9 952 КБ

    klnagent.exe 1660 0 5 304 КБ

    klswd.exe 1684 0 64 КБ

    Предположим, что мы в командном файле интерпретатора Cmd.exe с помощью этой утилиты хотим определить, сколько оперативной памяти тратит процесс kavsvc.exe. Для этого нужно выделить из выходного потока команды tasklist соответствующую строку, извлечь из нее подстроку, содержащую нужное число и убрать пробелы между разрядами (при этом следует учесть, что в зависимости от настроек операционной системы разделителем разрядов может быть не пробел, а другой символ). В PowerShell аналогичная задача решается с помощью команды get-process, которая возвращает коллекцию объектов, каждый из которых соответствует одному запущенному процессу. Для определения памяти, затрачиваемой процессом kavsvc.exe, нет необходимости в дополнительных манипуляциях с текстом, достаточно просто взять значение свойства WS объекта, соответствующего данному процессу.

    Наконец, объектная модель .NET позволяет PowerShell напрямую использовать функциональность различных библиотек, являющихся частью платформы .NET. Например, чтобы узнать, каким днем недели было 9 ноября 1974 года, в PowerShell можно выполнить следующую команду:

    (get-date "09.11.1974").DayOfWeek

    В этом случае команда get-date возвращает .NET-объект DateTime, имеющий свойство, при обращении к которому вычисляется день недели для соответствующей даты. Таким образом, разработчикам PowerShell не нужно создавать специальную библиотеку для работы с датами и временем – они просто берут готовое решение в .NET.

    Загрузка и установка PowerShell

    Оболочка PowerShell может работать не во всех версиях операционной системы, ее можно использовать в Windows XP SP 2, Windows Server 2003 SP 1 и более поздних версиях. Кроме этого, в системе должна быть установлена платформа .NET Framework 2.0 (в Windows XP данную среду придется устанавливать дополнительно, дистрибутив можно загрузить с сайта Microsoft по адресу http://msdn.microsoft.com/netframework/downloads/updates/default.aspx).

    Загрузить PowerShell можно с сайта Microsoft, открыв страницу http://microsoft.com/powershell, где имеются ссылки на файл установки последней версии и пакеты документации на разных языках. Запустив загруженный файл, следуйте указаниям мастера установки. В 32-разрядных версиях Windows оболочка PowerShell устанавливается по умолчанию в каталог %SystemRoot%\System32\WindowsPowerShell\v1.0. В 64-разрядных версиях Windows 32-разрядная версия PowerShell устанавливается в каталог %SystemRoot%\SystemWow64\WindowsPowerShell\v1.0, а 64-разрядная версия Windows PowerShell устанавливается в каталог %SystemRoot%\System32\WindowsPowerShell\v1.0.

    Запуск оболочки. Выполнение команд

    Установив оболочку в системе, можно начать новый интерактивный сеанс. Для этого следует нажать на кнопку Пуск (Start), открыть меню Все программы (All Programs) и выбрать элемент Windows PowerShell. Другой вариант запуска оболочки – пункт Выполнить… (Run) в меню Пуск (Start), ввести имя файла powershell и нажать кнопку OK.

    В результате откроется новое командное окно с приглашением вводить команды (рис. 16.1).




    увеличить изображение
    Рис. 16.1. Командное окно оболочки PowerShell

    Выполним первую команду в PowerShell. Пусть это будет что-то знакомое, например dir (команды в PowerShell обрабатываются без учета регистра). На экран будет выведен список файлов в текущем каталоге:

    PS C:\Documents and Settings\User> dir

    Каталог: Microsoft.PowerShell.Core\FileSystem::C:\Documents

    and Settings\User

    Mode LastWriteTime Length Name

    ---- ------------- ------ ----

    d---s 14.12.2007 10:10 Cookies

    d---- 12.05.2005 17:16 DoctorWeb

    d---- 06.11.2004 13:03 Phone Browser

    d---s 22.09.2004 23:49 UserData

    d-r-- 04.10.2004 15:33 Главное меню

    d-r-- 05.12.2007 0:49 Избранное

    d-r-- 31.10.2007 21:03 Мои документы

    d---- 05.12.2007 10:54 Рабочий стол

    -a--- 24.05.2006 21:22 8304 gsview32.ini

    Типы команд PowerShell

    В оболочке PowerShell поддерживаются команды четырех типов: командлеты, функции, сценарии и внешние исполняемые файлы.

    Первый тип – так называемые командлеты (cmdlet). Этот термин используется пока только внутри PowerShell. Командлет представляет собой класс .NET, порожденный от базового класса Cmdlet ; разрабатываются командлеты с помощью пакета PowerShell Software Developers Kit (SDK). Единый базовый класс Cmdlet гарантирует совместимый синтаксис всех командлетов, а также автоматизирует анализ параметров командной строки и описание синтаксиса командлетов для встроенной справки.

    Данный тип команд компилируется в динамическую библиотеку (DLL) и подгружается к процессу PowerShell во время запуска оболочки (то есть сами по себе командлеты не могут быть запущены как приложения, но в них содержатся исполняемые объекты). Так как компилированный код подгружается к процессу оболочки, данный тип команд выполняется наиболее эффективно. Командлеты – это аналог внутренних команд традиционных оболочек.

    Следующий тип команд – функции. Функция – это блок кода на языке PowerShell, имеющий название и находящийся в памяти до завершения текущего сеанса командной оболочки. Функции, как и командлеты, поддерживают именованные параметры. Анализ синтаксиса функции производится один раз при ее объявлении.

    Сценарий – это блок кода на языке PowerShell, хранящийся во внешнем файле с расширением ps1. Анализ синтаксиса сценария производится при каждом его запуске.

    Последний тип команд – внешние исполняемые файлы, которые выполняются обычным образом операционной системой.

    Имена и структура командлетов


    Как уже было отмечено выше, в PowerShell аналогом внутренних команд являются командлеты. Командлеты могут быть очень простыми или очень сложными, но каждый из них разрабатывается для решения одной, узкой задачи. Работа с командлетами становится по-настоящему эффективной при использовании их композиции (конвейеризации объектов между командлетами). Подробнее об этом мы поговорим на следующей лекции.

    Имена командлетов всегда соответствуют шаблону "глагол-существительное", где глагол задает определенное действие, а существительное определяет объект, над которым это действие будет совершено.

    Например, Get-Process (получить информацию о процессе), Stop-Service (остановить службу), Clear-Host (очистить экран консоли) и т.д. Чтобы просмотреть список командлетов, доступных в ходе текущего сеанса, нужно выполнить командлет Get-Command:

    PS C:\> Get-Command
    CommandType Name Definition

    ----------- ---- ----------

    Cmdlet Add-Content Add-Content [-Path] [-Value]
    Cmdlet Add-History Add-History [[-InputObject]
    ] [-Pass...

    Cmdlet Add-Member Add-Member [-MemberType]
    [-Name]...

    Cmdlet Add-PSSnapin Add-PSSnapin [-Name] [-PassThru] [-Ve...

    Cmdlet Clear-Content Clear-Content [-Path] [-Filter
    Cmdlet Clear-Item Clear-Item [-Path] [-Force] [-Filter ...

    ...

    16.1.

    По умолчанию командлет Get-Command выводит сведения в трех столбцах: CommandType, Name и Definition. При этом в столбце Definition отображается синтаксис командлетов (многоточие ( … ) в столбце синтаксиса указывает на то, что данные обрезаны).

    Командлеты могут иметь параметры, к которым можно обратиться по имени, перед которым ставится дефис ( - ), или по позиции (в последнем случае интерпретация параметра будет выполняться в зависимости от его местоположения в командной строке).

    Замечание

    Косые черты ( / и \ ) вместе с параметрами в оболочке Windows PowerShell не используются.

    В общем случае синтаксис командлетов имеет следующую структуру:

    имя_командлета –параметр1 -параметр2 аргумент1 аргумент2

    Здесь параметр1 – параметр (переключатель), не имеющий значения; параметр2 – имя параметра, имеющего значение аргумент1 ; аргумент2 – параметр, не имеющий имени. Например, командлет Get-Process имеет параметр Name, который определяет имя процесса, информацию о котором нужно вывести. Имя этого параметра указывать необязательно. Таким образом, для получения сведений о процессе Far можно ввести либо команду Get-Process -Name Far, либо команду Get-Process Far.

    Автоматическое завершение команд


    Находясь в оболочке PowerShell, можно ввести часть какой-либо команды, нажать клавишу и система попытается сама завершить эту команду.

    Подобное автоматическое завершение срабатывает, во-первых, для имен файлов и путей файловой системы. При нажатии клавиши PowerShell автоматически расширит частично введенный путь файловой системы до первого найденного совпадения. При повторении нажатия клавиши производится циклический переход по имеющимся возможностям выбора. Также в PowerShell реализована возможность автоматического завершения путей файловой системы на основе шаблонных символов ( ? и * ). Например, если ввести команду cd c:\pro*files и нажать клавишу , то в строке ввода появится команда cd 'C:\Program Files'.

    Во-вторых, в PowerShell реализовано автозавершение имен командлетов и их параметров. Если ввести первую часть имени командлета (глагол) и дефис, нажать после этого клавишу , то система подставит имя первого подходящего командлета (следующий подходящий вариант имени выбирается путем повторного нажатия ). Аналогичным образом автозавершение срабатывает для частично введенных имен параметров командлета: нажимая клавишу , мы будем циклически перебирать подходящие имена.

    Наконец, PowerShell позволяет автоматически завершать имена используемых переменных (объектов) и имена свойств объектов .

    Псевдонимы команд


    Механизм псевдонимов, реализованный в оболочке PowerShell, дает возможность пользователям выполнять команды по их альтернативным именам (например, вместо команды Get-Childitem можно пользоваться псевдонимом dir ). В PowerShell заранее определено много псевдонимов, можно также добавлять собственные псевдонимы в систему.

    Псевдонимы в PowerShell делятся на два типа. Первый тип предназначен для совместимости имен с разными интерфейсами. Псевдонимы этого типа позволяют пользователям, имеющим опыт работы с другими оболочками (Cmd.exe или Unix-оболочки), использовать знакомые им имена команд для выполнения аналогичных операций в PowerShell, что упрощает освоение новой оболочки, позволяя не тратить усилий на запоминание новых команд PowerShell. Например, пользователь хочет очистить экран. Если у него есть опыт работы с Cmd.exe, то он, естественно, попробует выполнить команду cls. PowerShell при этом выполнит командлет Clear-Host, для которого cls является псевдонимом и который выполняет требуемое действие – очистку экрана. Для пользователей Cmd.exe в PowerShell определены псевдонимы cd, cls, copy, del, dir, echo, erase, move, popd, pushd, ren, rmdir, sort, type ; для пользователей Unix – псевдонимы cat, chdir, clear, diff, h, history, kill, lp, ls, mount, ps, pwd, r, rm, sleep, tee, write.

    Узнать, какой именно командлет скрывается за знакомым псевдонимом, можно с помощью командлета Get-Alias:

    PS C:\> Get-Alias cd

    CommandType Name Definition

    ----------- ---- ----------

    Alias cd Set-Location

    Псевдонимы второго типа (стандартные псевдонимы) в PowerShell предназначены для быстрого ввода команд. Такие псевдонимы образуются из имен командлетов, которым они соответствуют. Например, глагол Get сокращается до g, глагол Set сокращается до s, существительное Location сокращается до l и т.д. Таким образом, для командлету Set-Location соответствует псевдоним sl, а командлету Get-Location – псевдоним gl.

    Просмотреть список всех пседонимов, объявленных в системе, можно с помощью командлета Get-Alias без параметров. Определить собственный псевдоним можно с помощью командлета Set-Alias.

    Справочная система PowerShell


    В PowerShell предусмотрено несколько способов получения справочной информации внутри оболочки.

    Краткую справку по одному командлету можно получить с помощью параметра ? (вопросительный знак), указанного после имени этого командлета. Например:

    PS C:\> get-process -?
    ИМЯ

    Get-Process

    ОПИСАНИЕ

    Отображает процессы, выполняющиеся на локальном компьютере.
    СИНТАКСИС

    Get-Process [[-name] ] []

    Get-Process -id []

    Get-Process -inputObject
    []
    ПОДРОБНОЕ ОПИСАНИЕ

    Командлет Get-Process извлекает объект-процесс для каждого процесса.

    При использовании командлета "Get-Process" без указания параметров

    происходит отображение всех процессов, выполняющихся на компьютере,

    что эквивалентно команде "Get-Process *". Процесс можно определить

    по имени или идентификатору (PID) или передав объект по ковнейеру

    в командлет Get-Process. Для Get-Process по умолчанию

    передается имя процесса. Для Stop-Process по умолчанию передается

    идентификатор процесса.
    ССЫЛКИ ПО ТЕМЕ

    Stop-Process
    ЗАМЕЧАНИЯ

    Для получения дополнительных сведений введите:

    "get-help Get-Process -detailed".

    Для получения технических сведений введите:

    "get-help Get-Process -full".

    Более подробную информацию можно получить с помощью специального командлета Get-Help с параметрами Detailed или Full (например, Get-Help Get-Process -Full ). Запустив данный командлет с параметром *, можно увидеть все доступные разделы справочной системы.

    Командлет Get-Help позволяет просматривать справочную информацию не только о разных командлетах, но и о синтаксисе языка PowerShell, о псевдонимах, о различных аспектах работы оболочки функциям и т.д. Список тем, обсуждение которых представлено с справочной службе PowerShell, можно увидеть следующим образом:

    PS C:\> Get-Help about_*
    Name Category Synopsis

    ---- -------- --------

    about_alias HelpFile Использование альтернативных имен ко...

    about_arithmetic_operators HelpFile Операторы, которые используются в ко...

    about_array HelpFile Компактная структура размещения элем...

    about_assignment_operators HelpFile Операторы, используемые в оболочке W...

    about_associative_array HelpFile Компактная структура данных для хран...

    about_automatic_variables HelpFile Переменные, автоматически задаваемые...

    about_break HelpFile Инструкция для немедленного завершен...

    about_command_search HelpFile Как оболочка Windows PowerShell обна...

    about_command_syntax HelpFile Формат команд в Windows PowerShell

    . . .

    16.2.

    Таким образом, чтобы прочитать справочную информацию об использовании массивов в PowerShell, нужно выполнить следующую команду: Get-Help about_array.

    Командлет Get-Help выводит содержимое раздела справки на экран сразу целиком. Функции man и help позволяют справочную информацию выводить поэкранно (аналогично команде MORE интерпретатора Cmd.exe), например: man about_array.


    написать администратору сайта