Собственный клиент Google - Google Native Client

Собственный клиент Google
Разработчики)Google, другие
изначальный выпуск16 сентября 2011 г.; 9 лет назад (2011-09-16)[1]
Стабильный выпуск
SDK: Перец 45 / 10 июля 2015; 5 лет назад (2015-07-10)

Клиенты: Такой же как Гугл Хром

Репозиторий Отредактируйте это в Викиданных
Написано вC, C ++
Операционная системаWindows, Linux, macOS, Chrome OS
Платформаx86, РУКА, MIPS
ТипПесочница в веб-браузерах для нативного кода
ЛицензияНовый BSD
Интернет сайтразработчик.хром.com/ собственный клиент

Собственный клиент Google (NaCl) это песочница технология для работы подмножества Intel x86, РУКА, или же MIPS собственный код или переносимый исполняемый файл в песочнице. Это позволяет безопасно работать собственный код из веб-браузер, независимо от пользователя Операционная система, позволяя веб-приложения работать с почти родной скоростью, что соответствует планам Google по Chrome OS. Его также можно использовать для защиты браузера. плагины, и части других приложений или полные приложения[2] Такие как ZeroVM.[3]

Чтобы продемонстрировать готовность технологии, 9 декабря 2011 года Google объявила о выпуске нескольких новых версий только для Chrome. игры известны своими богатыми и процессор -интенсивный графика, включая Бастион (больше не поддерживается в Интернет-магазине Chrome). NaCl работает с аппаратным ускорением 3D-графика (через OpenGL ES 2.0), изолированное локальное файловое хранилище, динамическая загрузка, полноэкранный режим и мышь захватывать. Есть также планы сделать NaCl доступным на портативных устройствах.[4][5]

Portable Native Client (PNaCl) - это архитектурно-независимая версия. Приложения PNaCl составлен заранее. В большинстве случаев рекомендуется использовать PNaCl вместо NaCl.[6] Общая концепция NaCl (запуск собственного кода в веб-браузере) была реализована ранее в ActiveX, который, пока еще используется, имеет полный доступ к системе (диску, памяти, пользовательскому интерфейсу, реестру и т. д.). Собственный клиент позволяет избежать этой проблемы, используя песочницу.

Альтернативой NaCl является asm.js, что также позволяет приложениям, написанным на C или же C ++ должен быть скомпилирован для запуска в браузере (более чем на половину собственной скорости), а также поддерживает предварительную компиляцию, но является подмножеством JavaScript и, следовательно, обратно совместим с браузерами, которые не поддерживают его напрямую. Другой альтернативой (хотя изначально он может работать от PNaCl) является WebAssembly.

12 октября 2016 г. комментарий к системе отслеживания проблем Chromium показал, что команды Google Pepper и Native Client были отключены.[7] 30 мая 2017 года Google объявил о прекращении поддержки PNaCl в пользу WebAssembly.[8] Хотя изначально Google планировал удалить PNaCl в первом квартале 2018 года,[8] а позже во втором квартале 2019 г.[9] в настоящее время его планируется удалить в июне 2022 года (вместе с приложениями Chrome).[10]

Обзор

Собственный клиент - это Открытый исходный код проект разрабатывается Google.[11] На свидание, Землетрясение,[12] XaoS, Битва за Веснот,[13] Рок,[14] Лара Крофт и Хранитель Света,[15] Из пыли,[16] и МАМЕ, а также система обработки звука Csound, были перенесены на собственный клиент. Собственный клиент был доступен в Гугл Хром веб-браузер с версии 14 и был включен по умолчанию с версии 31, когда был выпущен Portable Native Client (PNaCl, произносится: pinnacle).[17][18][19]

An РУКА реализация была выпущена в марте 2010 года.[20] x86-64, IA-32, и MIPS также поддерживаются.

Чтобы приложение было переносимым под PNaCl, оно должно быть скомпилировано в не зависящее от архитектуры и стабильное подмножество LLVM промежуточное представление байт-код.[21] Исполняемые файлы называются исполняемыми файлами PNaCl (pexes). PNaCl Toolchain создает файлы .pexe; Файлы NaCl Toolchain .nexe. В магическое число файлов .nexe - это 0x7F 'E' 'L' 'F', что ELF. В Chrome они переводятся в исполняемые файлы для конкретной архитектуры, чтобы их можно было запускать.

NaCl использует программное обеспечение обнаружение и изоляция неисправностей для песочницы на x86-64 и ARM.[22] Реализация x86-32 Native Client примечательна своим новым методом песочницы, который использует редко используемые архитектуры x86. средство сегментации.[23] Собственный клиент настраивает сегменты x86, чтобы ограничить диапазон памяти, доступный для изолированного кода. Он использует верификатор кода, чтобы предотвратить использование небезопасных инструкций, например тех, которые выполняют системные вызовы. Чтобы предотвратить переход кода к небезопасной инструкции, скрытой в середине безопасной инструкции, Native Client требует, чтобы все косвенные переходы были переходами к началу блоков, выровненных по 32 байта, и инструкциям не разрешается размещать эти блоки между собой.[23] Из-за этих ограничений код C и C ++ необходимо перекомпилировать для работы под собственным клиентом, который предоставляет настраиваемые версии Набор инструментов GNU, конкретно Коллекция компиляторов GNU (GCC), GNU Binutils, и LLVM.

Native Client лицензирован под Лицензия в стиле BSD.

Собственный клиент использует Newlib как его Библиотека C, но порт Библиотека GNU C (GNU libc) также доступна.[24]

Перец

NaCl обозначает хлорид натрия, общая таблица соль; как каламбур, имя перец также использовался. Pepper API - это кроссплатформенный API с открытым исходным кодом для создания модулей Native Client.[25] Pepper Plugin API или PPAPI[26][27] - это кроссплатформенный API для подключаемых модулей веб-браузеров, защищенных собственным клиентом, впервые основанный на Netscape NPAPI, а затем переписать с нуля. В настоящее время он используется в Chromium и Гугл Хром чтобы включить версию PPAPI Adobe Flash[28] и встроенный PDF зритель.[29]

PPAPI

12 августа 2009 года на странице Google Code был представлен новый проект Pepper и связанный с ним Pepper Plugin API (PPAPI),[30] «набор модификаций NPAPI, чтобы сделать плагины более переносимыми и безопасными».[31] Это расширение разработано специально, чтобы упростить реализацию внепроцесс выполнение плагина. Кроме того, цель проекта - предоставить основу для создания полностью кроссплатформенных плагинов. Рассматриваемые темы включают:

  • Единая семантика NPAPI во всех браузерах.
  • Выполнение в отдельном процессе от рендерера-браузера.
  • Стандартизируйте рендеринг с помощью процесса компоновки браузера.
  • Определение стандартизированных событий и функций 2D растеризации.
  • Первоначальная попытка предоставить доступ к 3D-графике.
  • Реестр плагинов.

Pepper API также поддерживает Геймпады (версия 19) и WebSockets (версия 18).[32]

По состоянию на 13 мая 2010 г., Браузер с открытым исходным кодом Google, Хром, был единственным веб-браузером, который использовал новую модель подключаемого модуля браузера.[33] С 2020 года Pepper поддерживается браузерами на основе движка макетов Chrome, Chromium и Blink, такими как Opera и Microsoft Edge.

В январе 2020 года Google объявил, что поддержка PPAPI будет удалена из Google Chrome и Chromium в июне 2021 года.[34]

PPAPI в Firefox

Mozilla Firefox заявили в 2014 году, что они не будут поддерживать Pepper, поскольку нет полной спецификации API, кроме его реализации в Chrome, который сам предназначен для использования с Движок макета Blink только и имеет частные API, специфичные для плагина Flash Player, которые не задокументированы.[35] В октябре 2016 года Mozilla объявила, что она пересмотрела и изучает возможность включения Pepper API и PDFium в будущие выпуски Firefox,[36] однако никаких шагов предпринято не было.

Приложения

Один сайт[37] использует NaCL на сервере, чтобы пользователи могли экспериментировать с Язык программирования Go из своих браузеров.[38]

Прием

Некоторые группы разработчиков браузеров поддерживают технологию Native Client, а другие нет.

Сторонники

Чад Остин (из IMVU ) высоко оценил то, как Native Client может безопасно переносить высокопроизводительные приложения в Интернет (с потерей около 5% по сравнению с собственным кодом), а также ускоряет развитие клиентских приложений, предоставляя возможность выбора используемого языка программирования. (Помимо JavaScript ).[39]

Id Software с Джон Д. Кармак похвалил Native Client на QuakeCon 2012, где говорится: «Если вам нужно что-то делать в браузере, Native Client гораздо интереснее как нечто, начавшееся как чертовски умный хакерский хакерский хакерский хакерский хакерский хакерский хакерский хакерский хакерский хакерский хакерский анализатор x86. теперь динамическая перекомпиляция, но что-то, что вы программируете на C или C ++, и оно компилируется до того, что не будет вашим уровнем оптимизации -O4 для полностью нативного кода, но чертовски близко к нативному коду. Вы могли бы делать все свои зловещие погони за указателями , и все, чем вы хотите заниматься как разработчик игр ".[40]

Недоброжелатели

Другие ИТ-специалисты более критично относятся к этой технологии «песочницы», поскольку у нее есть существенные или существенные проблемы совместимости.

Mozilla вице-президент по продуктам, Джей Салливан, сказал, что Mozilla не планирует запускать собственный код в браузере, поскольку «Эти собственные приложения - просто маленькие черные ящики на веб-странице. [...] Мы действительно верим в HTML, и именно на этом мы хотим сосредоточиться».[41]

Mozilla Кристофер Близзард раскритиковал NaCl, заявив, что собственный код не может развиваться так же, как веб-сайт, управляемый исходным кодом. Он также сравнил NaCl с Microsoft ActiveX технологии, страдающие DLL ад.[2]

Хокон Виум Ли, Технический директор Opera, считает, что «NaCl, похоже,« тоскует по плохим старым временам, прежде чем Интернет »», и что «Native Client предназначен для создания новой платформы или переноса старой платформы в Интернет [...] это вызовет сложности и проблемы с безопасностью и отвлечет внимание от веб-платформы ".[2]

Второе поколение

Второе поколение песочница разработан в Google gVisor.[42][43] Он предназначен для замены NaCl в Google Cloud, а точнее в Google App Engine. Google также продвигает WebAssembly.[44]

Смотрите также

Рекомендации

  1. ^ "Собственный клиент Google запускается в Chrome". Реестр. 16 сентября 2011 г.. Получено 12 марта 2016.
  2. ^ а б c Мец, Кейд (12 сентября 2011 г.). "Google Native Client: Интернет будущего или прошлого?". Реестр. Получено 17 сентября 2011.
  3. ^ «Архитектура ZeroVM». Архивировано из оригинал 8 февраля 2014 г.. Получено 16 марта 2014.
  4. ^ Розенблатт, Сет (9 декабря 2011 г.). «Native Client превращает Chrome в высокопроизводительную игровую платформу». CNET. Архивировано из оригинал 28 августа 2012 г.. Получено 9 декабря 2011.
  5. ^ «Блог Google Code: игры, приложения и среды выполнения входят в собственный клиент». Googlecode.blogspot.com. 9 декабря 2011 г.. Получено 25 апреля 2012.
  6. ^ «NaCl и PNaCl».
  7. ^ "Bugs.chromium.org". 12 октября 2016 г.. Получено 12 октября 2016.
  8. ^ а б «Прощай, PNaCl, привет, WebAssembly!». Блог Chromium. Получено 31 мая 2017.
  9. ^ «Руководство по миграции WebAssembly - Google Chrome». developer.chrome.com. Получено 20 декабря 2018.
  10. ^ «Изменения в графике поддержки приложений Chrome». Блог Chromium. 10 августа 2020.
  11. ^ "Собственный клиент Google в Google Code". Google. Получено 25 апреля 2012.
  12. ^ Дэвмайкл. "GitHub - davemichael / NaCl-Quake: Quake для собственного клиента (на основе порта SDL Quake)". GitHub.
  13. ^ "Битва за Веснот".
  14. ^ "Индекс /".
  15. ^ «Архивная копия». Архивировано из оригинал 8 декабря 2013 г.. Получено 26 ноября 2013.CS1 maint: заархивированная копия как заголовок (связь)
  16. ^ "Из пыли". Архивировано из оригинал 12 марта 2016 г.. Получено 24 февраля 2016.
  17. ^ Чен, Брэд (8 декабря 2008 г.). «Нативный клиент: технология для запуска нативного кода в Интернете». Google-code-updates.blogspot.com. Получено 25 апреля 2012.
  18. ^ "Блог Chromium: собственный клиент переносит изолированный собственный код в приложения из Интернет-магазина Chrome". Blog.chromium.org. 18 августа 2011 г.. Получено 25 апреля 2012.
  19. ^ "Блог Google Code: Portable Native Client: вершина скорости, безопасности и портативности". blog.chromium.org. 12 ноября 2013 г.. Получено 16 марта 2014.
  20. ^ "Собственный клиент Google идет на ARM и не только". The H. 18 марта 2010 г.. Получено 19 мая 2010.
  21. ^ «PNaCl: переносимые исполняемые файлы для собственного клиента» (PDF). Архивировано из оригинал (PDF) 2 мая 2012 г.. Получено 25 апреля 2012.
  22. ^ Сер, Дэвид; Мут, Роберт; Biffle, Cliff L .; Хименко Виктор; Пасько, Егор; Да, Беннет; Шимпф, Карл; Чен, Брэд (2010). «Адаптация изоляции ошибок программного обеспечения к современным архитектурам ЦП». 19-й симпозиум по безопасности USENIX. Получено 31 июля 2011.
  23. ^ а б Да, Беннет; Сер, Дэвид; Дардык, Грег; Чен, Брэд; Мут, Роберт; Орманди, Тэвис; Окасака, Шики; Нарула, Неха; Фуллагар, Николас (2009). «Собственный клиент: песочница для портативного ненадежного собственного кода x86». Симпозиум IEEE по безопасности и конфиденциальности (Окленд'09). Получено 31 июля 2011.
  24. ^ "Собственный клиент: Строительство". developer.chrome.com. Получено 16 марта 2014.
  25. ^ «Технический обзор».
  26. ^ «Проект Pepper Plugin API в». Google. Получено 25 апреля 2012.
  27. ^ "Источник Chrome: индекс / trunk / src / ppapi". Src.chromium.org. Получено 25 апреля 2012.
  28. ^ «Путь к более безопасным, стабильным и ярким Flash». Google. 8 августа 2012 г.. Получено 10 августа 2013.
  29. ^ Мец, Кейд (18 июня 2010 г.). «Google крепче поддерживает Adobe благодаря слиянию Chrome и PDF». Реестр. Получено 25 апреля 2012.
  30. ^ «Начало работы: история и основы - проекты Chromium». Chromium.org. Получено 25 апреля 2012.
  31. ^ "Pepper.wiki". Google. 24 февраля 2012 г.. Получено 25 апреля 2012.
  32. ^ «Примечания к выпуску».
  33. ^ Мец, Кейд (13 мая 2010 г.). "Google нагревает нативный код для Chrome OS". Theregister.co.uk. Получено 25 апреля 2012.
  34. ^ Энтони Лафорж (15 января 2020 г.). «Переход от приложений Chrome». Блог Chromium.
  35. ^ Збарский, Борис. «Ошибка 729481 - Поддержка api плагина Pepper». Получено 15 апреля 2016.
  36. ^ Мец, Кейд (3 октября 2016 г.). "Проектный миномет". Mozilla. Получено 30 октября 2016.
  37. ^ "Игровая площадка Го".
  38. ^ "Внутри игровой площадки для игры в го - блог Go". blog.golang.org. Получено 27 августа 2016.
  39. ^ Остин, Чад (8 января 2011 г.). «Чад Остин: в защиту языковой демократии (или: почему браузеру нужна виртуальная машина)». Chadaustin.me. Получено 25 апреля 2012.
  40. ^ Кармак, Джон (3 августа 2012 г.). «QuakeCon 2012». youtube.com. Получено 26 августа 2012.
  41. ^ Мец, Кейд (24 июня 2010 г.). «Mozilla: наш браузер не будет запускать собственный код». Реестр. Получено 25 апреля 2012.
  42. ^ https://news.ycombinator.com/item?id=17810591
  43. ^ https://github.com/google/gvisor
  44. ^ Аврам, Авель (31 мая 2017 г.). "Google прекращает поддержку PNaCl". InfoQ. Получено 1 августа 2020. В качестве замены Google теперь продвигает WebAssembly.

внешняя ссылка

Примеры