Факт: аудитории Хабра нравятся рецензии на книги по базовым ИТ-технологиям. И сегодня — как раз такая:«Docker. Вводный курс. 3 издание» (Docker: Up & Running, 3rd Edition) от издательства O'Reilly Media, в переводе от БХВ Петербург. Популярное руководство по Docker, написанное Шоном П. Кейном и Карлом Маттиасом, выпущено в 2023 году и предназначена для разработчиков, сисадминов и DevOps-инженеров. Полезность книги — в подробном объяснении технологии Docker от самых основ и до продвинутых концепций и практик.

***

Начнем обзор со ссылки на страницу книги «Docker. Вводный курс. 3 издание» на с айте БХВ.
И напомним, что на все книги по компьютерным технологиям от издательств “БХВ Петербург” и “Фолиант” доступен промокод SSPSOFT на скидку 25% как подарок читателям Хабра от нашего блога.

Кстати, если кто-то хочет прочесть книгу в оригинале на английском языке и бесплатно, то мы нашли ресурс, где можно скачать электронную версию книги Docker: Up & Running, 3rd Edition в формате epub. При желании, этот файл можно легко конвертировать в PDF, если вам удобнее читать именно в таком формате.

Для кого эта книга

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

Шон Кейн — основатель ресурса techlabs.sh и лид по продакшн-операциям в SuperOrbital. Он специализируется на разработке, обучении и написании материалов о современных процессах DevOps, включая Kubernetes, Docker, Terraform и другие технологии. Шон является ведущим изобретателем патента, связанного с контейнерами, и посвящает много свободного времени написанию статей, преподаванию и выступлениям на технологические темы.  

Карл Маттиас занимает должность вице-президента по архитектуре в Community.com. До этого он работал в нескольких крупных технологических компаниях, где на протяжении более чем 25 лет занимал ряд высоких инженерных и руководящих должностей. Карл специализируется на распределенных системах, языках программирования Go, Ruby и Elixir, масштабируемых хранилищах данных, автоматизированной инфраструктуре и воспроизводимых системах.

А теперь о том, кого авторы и издательство видят в качестве читателей этой книги. Если кратко — то всех, кто стремится освоить и эффективно применять Docker и контейнеризацию в своей работе. 

В первую очередь, эта книга будет полезна таким читателям:

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

2. Системным администраторам, стремящимся оптимизировать управление инфраструктурой и повысить ее эффективность.

3. DevOps-инженерам, заинтересованным в улучшении процессов непрерывной интеграции и доставки (CI/CD) с использованием Docker.

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

5. Специалистам по SaaS/PaaS, работающим с сервисами, интегрированными с Docker и Kubernetes.

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

Пару мнений о книге от читателей с Амазон

В этот раз не будет раздела про плюсы и минусы книги — лучше прочесть живые отклики опытных спецов, оставленные на странице книги на Амазон, чтобы получить совет — покупать эту книгу или нет.

  • Evan Volgas: “Эта книга подойдет как новичкам, так и продвинутым пользователям. В каждой главе много полезной информации, а погружение в детали приятно увеличивается по мере чтения книги. 

    Хотелось бы, чтобы автор уделил больше времени использованию облачных сервисов, таких как EKS и CloudRun. Есть глава о EKS, но концепции и вызовы командной строки объясняются лишь поверхностно. Это резко контрастирует с остальной частью книги, где подробно все расписано. Если бы автор пересмотрел эту главу и, возможно, добавил еще две главы для GCS и Azure, эта книга легко получила бы 5 звезд. Как бы то ни было, это надежная четырехзвездочная книга с большим количеством отличного материала как для новичков, так и для опытных пользователей Docker.”

  • Yifan Yang: “Я не думаю, что книга подойдет совсем уж новичкам, некоторые примеры (на мой взгляд) недостаточно хорошо объяснены для людей без опыта работы с Docker. Как по мне, целевая аудитория этой книги — DevOps инженеры уровня мидл.”

Что интересного в главах

По странной причине, на сайте издательства БХВ не нашли оглавления русского издания в виде пробного PDF-фрагмента, как это у них принято. Но зато мы нашли это оглавление на Озон (там кстати книга заметно дороже). 

Английское оглавление есть на сайте O’REILLY, а кроме того — в бесплатной версии этой книги на сайте ebin.pub, о чем мы сказали выше.

А теперь пройдемся по главам - это может показаться чуть-чуть скучным, но зато у вас будет понимание всей темы, как будто вы проанализировали содержание глав и составили их конспект: 

Глава 1. Введение

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

Глава 2. Ландшафт Docker

Эта глава погружается в экосистему Docker, объясняя, как он упрощает процессы разработки и развертывания. Обсуждается широкая поддержка и принятие Docker в индустрии. Рассматривается архитектура Docker, включая модель клиент-сервер,  сетевые аспекты и отличие от виртуальных машин. Авторы описывают основные инструменты Docker и объясняют, как получить максимальную отдачу от использования контейнеров. Глава также охватывает концепцию неизменяемой инфраструктуры и важность создания приложений без сохранения состояния при работе с Docker.

Глава 3. Установка Docker

В этой главе подробно рассматривается процесс установки Docker на различных операционных системах. Она охватывает установку клиента Docker на Linux, macOS и Windows, а также установку сервера Docker на системах на базе systemd и не-Linux машинах. Авторы предоставляют пошаговые инструкции по тестированию установки на различных дистрибутивах Linux, включая Ubuntu, Fedora и Alpine Linux. Глава завершается обзором основных компонентов сервера Docker.

Глава 4. Работа с образами Docker

Глава начинается с объяснения анатомии Dockerfile и процесса сборки образа. Рассматриваются темы запуска образов, использования аргументов сборки и переменных окружения для конфигурации. Обсуждается создание пользовательских базовых образов и хранение образов в публичных и частных реестрах. Авторы предоставляют советы по оптимизации образов, включая минимизацию их размера и эффективное использование слоев. Глава также охватывает устранение неполадок при сборке и создание мульти-архитектурных образов.

Глава 5. Работа с контейнерами

Эта глава углубляется в концепцию контейнеров, начиная с краткой истории технологии контейнеризации. Подробно рассматривается процесс создания, настройки и управления контейнерами, включая использование томов хранения и квот ресурсов. Обсуждаются различные операции с контейнерами, такие как запуск, остановка, уничтожение, пауза и возобновление. Авторы также объясняют, как настроить автоматический перезапуск контейнеров и как эффективно очищать неиспользуемые контейнеры и образы. Глава завершается кратким обзором контейнеров Windows.

Глава 6. Сбор информации в Docker

В этой главе рассматриваются различные инструменты и команды для исследования и мониторинга Docker-окружения. Авторы объясняют, как получить информацию о версии Docker и сервере, как обновлять образы и инспектировать контейнеры. Обсуждаются методы доступа к работающим контейнерам и управления ими. Глава также охватывает темы логирования, мониторинга статистики контейнеров и проверки их здоровья. Рассматриваются продвинутые инструменты мониторинга, такие как cAdvisor и Prometheus.

Глава 7. Отладка контейнеров

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

Глава 8. Docker Compose

В этой главе рассматривается Docker Compose - инструмент для определения и управления мульти-контейнерными приложениями. Авторы объясняют, как настроить и использовать Docker Compose для запуска сервисов. На примере приложения Rocket.Chat демонстрируются возможности Docker Compose. Обсуждаются различные аспекты управления конфигурацией, включая работу с значениями по умолчанию, обязательными значениями и файлами .env. Эта глава помогает читателям понять, как эффективно организовывать и управлять сложными приложениями с несколькими взаимосвязанными контейнерами.

Глава 9. Контейнеры и продакшн

Эта глава фокусируется на подготовке контейнеров к использованию в продакшн среде. Рассматриваются ключевые аспекты, такие как управление заданиями, ограничение ресурсов, настройка сети и конфигурации. Обсуждаются вопросы упаковки и доставки контейнеров, а также организации логирования и мониторинга. Авторы также затрагивают темы планирования и обнаружения сервисов. Глава завершается обзором роли Docker в DevOps-пайплайне, демонстрируя, как контейнеры могут улучшить процесс разработки и развертывания приложений.

Глава 10. Масштабирование контейнеров

В этой главе рассматриваются различные платформы и инструменты для управления контейнерами в крупномасштабных средах. Обсуждается режим Docker Swarm для оркестрации контейнеров. Значительное внимание уделяется Kubernetes - популярной платформе для автоматизации развертывания, масштабирования и управления контейнеризованными приложениями. Авторы также рассматривают Amazon ECS и Fargate, предоставляя инструкции по настройке и использованию этих сервисов AWS для управления контейнерами. Глава помогает читателям понять, как эффективно масштабировать контейнерные приложения в различных средах.

Глава 11. Расширенные концепции (Продвинутые темы)

Эта глава углубляется в технические детали работы контейнеров, включая использование cgroups и пространств имен. Рассматриваются аспекты безопасности, такие как работа с UID 0, привилегированные контейнеры и безопасный режим вычислений. Обсуждается конфигурация демона Docker и продвинутые настройки сети и хранения. Авторы также рассматривают инструменты для отладки контейнеров без оболочки и возможность замены времени выполнения Docker. Глава завершается обзором gVisor - песочницы для времени выполнения контейнеров от Google.

Глава 12. Экосистема

В этой главе рассматриваются альтернативные инструменты и технологии, дополняющие или конкурирующие с Docker. Обсуждаются клиентские инструменты, такие как nerdctl, podman и buildah, которые предлагают альтернативные способы работы с контейнерами. Авторы также описывают комплексные инструменты для разработчиков, включая Rancher Desktop и Podman Desktop, которые предоставляют интегрированные среды для работы с контейнерами. Эта глава помогает читателям понять разнообразие экосистемы контейнеров и выбрать наиболее подходящие инструменты для своих потребностей.

Глава 13. Проектирование контейнерной платформы

Эта глава фокусируется на принципах проектирования эффективных контейнерных приложений. Рассматривается методология Twelve-Factor App, которая предлагает набор лучших практик для создания масштабируемых и поддерживаемых приложений. Авторы также обсуждают Reactive Manifesto, объясняя, как принципы отзывчивости, устойчивости, эластичности и ориентации на сообщения применимы к контейнерным приложениям. Эта глава предоставляет читателям ценные рекомендации по проектированию надежных и эффективных контейнерных платформ.

Глава 14. Заключительная

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

Заключение

В России издано совсем мало переводных книг по Docker, причем достаточно свежих и с актуальным содержимым. На наш взгляд, несмотря на всего 4 звезды на Амазон, купить книгу все же стоит - деньги, вложенные в знания и личные компетенции, всегда окупаются.

Сочетание глубоких технических знаний Шона Кейна в области DevOps и контейнеризации с обширным опытом Карла Маттиаса в архитектуре и разработке программного обеспечения делает их весьма компетентными авторами для создания этого теоретического и практического руководства по Docker.

Добавим каплю рекламы от нашего блога: компания SSP SOFT приглашает на позиции инженеров QA и DevOps, системного аналитика, аналитика данных, разработчиков на Java, JS, React и Python, 1С — см. страницу на hh.ru. Если вашей специальности нет в текущих вакансиях, все равно присылайте резюме, т.к. новые позиции в командах открываются еженедельно (пишите в Telegram или на почту job@ssp-soft.com).

Успехов в изучении и практическом применении Docker!


Комментарии (8)


  1. withkittens
    27.08.2024 10:51
    +1

    Кстати, если кто-то хочет прочесть книгу в оригинале на английском языке и бесплатно, то мы нашли ресурс, где можно скачать электронную версию книги Docker: Up & Running, 3rd Edition в формате epub.

    А вашу книжку можно почитать бесплатно?


    1. SSP_blog Автор
      27.08.2024 10:51
      +2

      Мы в SSP SOFT как компания по разработке ПО никак не ассоциированы с издательством БХВ.
      Просто делаем рецензии на полезные книги по ИТ для развития сообщества Хабра. За это нам подарили промокод для читателей.


  1. AquariusStar
    27.08.2024 10:51
    +1

    Хотелось спросить. А что за прикол такой насчёт наличия электронной версии? Это же PDF/ePub, которую продавать можно до бесконечности. Вижу только бумажную версию. А хочу электронную. Или опять мне топать на известные ресурсы?


    1. OldNickWhirly
      27.08.2024 10:51
      +2

      Английский оригинал книги в .pdf + DeepL, если уж совсем с языком проблемы. Работы часа на три-четыре.


    1. SSP_blog Автор
      27.08.2024 10:51

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


      1. AquariusStar
        27.08.2024 10:51

        Странно. Ранее я покупал у другого магазина. Выпуск бумажной и электронной одновременно идёт.


        1. ihc988
          27.08.2024 10:51
          +1

          Издательство Питер вроде как продает одновременно, а БХВ - с задержкой.
          У каждого своя торговая политика видимо.


          1. AquariusStar
            27.08.2024 10:51

            Значит, подожду выхода электронной версии.