Патч

Материал из Википедии — свободной энциклопедии
(перенаправлено с «Hotfix»)
Перейти к навигации Перейти к поиску

Запла́тка,илипатч(англ.patch/pætʃ/заплатка) — информация, предназначенная для автоматизированного внесения определённых изменений в компьютерныефайлы.Применение патча иногда называется «пропатчиванием».

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

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

Размер патчей может варьироваться от несколькихкилобайтдо сотенмегабайт.В частности, очень большими патчи могут быть при изменении или замене непрограммных данных, таких как файлы с графикой и звуком (часто встречаются вкомпьютерных играх). Тем не менее, большой размер может быть вызван и многочисленностью вносимых изменений. При этом слова «патч», «заплатка» обычно используются для обозначения небольших исправлений, большие же патчи, серьёзно меняющие или обновляющие программу, часто называются «service pack» или «software updates».

Причины использования патчей

[править|править код]
  • Описание изменений обычно меньше полнойверсии программы,пригодной дляустановкис нуля (за исключением большого количества изменений, например, если обновление происходит сразу через несколько версий).
    • Промежуточный вариант между мелкими патчами и заменой всего сразу — патч, включающий в себя изменения, указанные в нескольких последовательных патчах за определённый период —кумулятивный патч(лат.cumulatio— «увеличение, скопление»).
  • Описание изменений может включать в себя контекст, так что патч может быть применим к версиям файлов, отличающимся от тех, для которых он был создан (обычно возможно для текстовых файлов). Патч, содержащий и заменяемые данные, позволяет отменить изменения, в том числе при наличии не мешающих последующих изменений.

Во времена, когда для загрузки программ в компьютеры использовались перфокарты или бумажные ленты, разработчики программ распространяли патчи в виде перфокарт с отличным от первоначального набором перфорации или указывали наперфолентеместа, которые следует изменить. Пользователи заменяли соответствующие перфокарты в стопке или вырезали помеченную часть ленты и вклеивали вместо неё новый кусок программы. Тогда же и возникло название «patch» (англ.patch,буквально — «заплатка»).

Позже для распространения патчей стали использоватьсямагнитные ленты.Когда же были изобретеныдискеты,патчи стали отправляться на дискетах вконвертахпопочте.Сегодня, в эру повсеместного распространенияинтернета,компьютерные программы и их пользователи скачивают патчи ссайтовразработчиков.

Виды патчей

[править|править код]
  • Патчи могут распространяться в виде списка различий между двумя версиямифайлаили набора файлов. Такие патчи обычно используются при разработке программного обеспечения. Существуют специальныеутилитыдля автоматического создания и применения таких патчей (например,diffиpatch;различныесистемы управления версиями).
  • Патчи для обновленияоткомпилированногопрограммного обеспечения распространяются в виде двоичных файлов, скачиваемых самой программой, либо в составе самостоятельных программ, запускаемых самим пользователем. В этом случае необходимые изменения файлов программы или их полная замена зачастую происходит автоматически, без вмешательства пользователя.

Коротко выполняемые патчами задачи можно описать следующими действиями:

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

Программное обеспечение

[править|править код]

Для автоматического обновления у пользователя патчи используются обычно в крупных проектах, где важен объём пересылаемых данных.

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

Например, при разработкеядра операционной системы Linux,Линус Торвальдс,его автор, получал тысячи писем с патчами к своей версии от множества программистов.

Веб-серверApacheразвился из набора патчей, написанных ранее различнымивеб-мастерамидля добавления функциональности кNCSA HTTPd.По легенде, отсюда и возникло название — означающее, что это есть по сути коллекция патчей: «a patchy server».

Музыкальное ПО

[править|править код]

В программах для создания музыки патчем называется сохранённый в памяти музыкального синтезатора набор программируемых параметров звучания определённого звука — программный модуль, содержащий различные дополнительныезвуковые эффектыипресеты.

Участие пользователя в обновлении ПО

[править|править код]

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

В случае обновленияоперационных системисерверного программного обеспеченияпатчи играют важную роль в поддержаниибезопасностии устранениидыр в защите.Чтобы облегчить установку таких обновлений, операционные системы часто поддерживают автоматические или полуавтоматические механизмы обновления. При этом осторожные пользователи (в частности,системные администраторы) обычно отключают автоустановку патчей, пока не убедятся в стабильной работе исправленных версий на чужих примерах[1].В случае больших или очень важных патчей разработчики часто сначала сами проводят предварительное тестирование (бета-тестирование).

Принудительное обновление

[править|править код]

Иногда разработчики программ принуждают пользователей к обновлению. Это может выражаться в ограничении доступа с помощью необновлённой программы к сервисам разработчика (например, невозможности устанавливать последующие патчи и обновления), либо в полном или частичном отказе самой программы.

Причинами могут быть:

  • уязвимости в программе, делающие её использование опасным для сервисов разработчика, компьютера пользователя или других компьютеров;
  • изменения или исправления, напрямую связанные с сервисами разработчика (совместимость между установленными у всех пользователей копиями, правила игры, условия использования сервисов);
  • борьба против определённых действий пользователя (например, читерства в сетевых играх илииспользования несвободных компонентов ПО, не одобренного правообладателем); при этом могут удаляться важные функции, например, возможность установки Unix-подобных операционных систем на игровую консольPlayStation 3OtherOS»).[2]

Патч встроенного ПО

[править|править код]

Во многих устройствахпрограммное обеспечениенаходится в памяти самого устройства в виде т. н.прошивки,которая включает в себя сразу иоперационную систему,управляющую работой устройства, и собственно набор программ, обеспечивающих выполнение тех или иных его функций. Поэтому если разработчиком предусмотрена возможность замены его прошивки (перепрошивка), то применение патча напрограммное обеспечениеустройства чаще всего представляет собой полную замену целиком всей прошивки на более новую версию. Обычно такой патч состоит из файла, содержащего обновленный программный код в двоичном виде, и специальной программы, записывающей его в память устройства вместо прежней версии. Пример такого вида патчей — перепрошивкаБИОСаматеринской платыкомпьютераили современного мобильного телефона, подключённого к компьютеру.

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

Разработка патчей

[править|править код]

Для создания, использования и учёта патчей используютсистемы управления версиями.

Автоматизация установки

[править|править код]

Зачастую современные программы обновлений могут управлять патчами.Автоматизациявсего процесса упрощает задачу конечного пользователя — ему достаточно запустить программу, а та уже решит, нужно ли ставить патчи, и в каком порядке. Бывает и так, что программа скачивает обновления из интернета без участия пользователя. Такой способ часто применяется в поддержке серверного программного обеспечения и операционных систем. В ситуации, когда администратору приходится следить за несколькими компьютерами такой подход помогает поддерживать надёжность системы в целом. Обычно таким способом происходит установка обновлений безопасности.

Вспомогательные утилиты

[править|править код]

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

Подробнее см. в статьеСамораспаковывающийся архив.
  1. Действительно в основном для серверов, на рабочих станциях обычно стоит автообновление.
  2. PS3 Firmware (v3.21) Update(амер. англ.).PlayStation.Blog(28 марта 2010). Дата обращения: 24 мая 2022.Архивировано26 апреля 2019 года.