Leanpub Header

Skip to main content

Программирование Cloud Native. Микросервисы, Docker и Kubernetes

Разработка приложений и микросервисов в стиле Cloud Native. Упаковка микросервисов в контейнеры Docker, развертывание микросервисов с помощью Kubernetes. Управление развернутыми сервисами и их взаимодействие.

Программирование всегда доступных, распределенных, обслуживающих миллионы запросов систем основано на возможностях облаков Cloud. Книга расскажет, как создавать приложения согласно концепции Cloud Native, "рожденные" жить и работать в облаке - а именно видеть их как набор микросервисов, упаковывать в образы Docker, и управлять ими в Kubernetes.

Minimum price

Free!

$7.99

You pay

$7.99

Author earns

$6.39
$

...Or Buy With Credits!

You can get credits monthly with a Reader Membership
PDF
EPUB
WEB
1,146
Readers
233
Pages
About

About

About the Book

В этой книге мы взглянем на концепцию Cloud Native - создание приложений, "рожденных" для облака, узнаем о 12 факторах, вспомним как появились технологии виртуализации и масштабирования, разберем что именно принесут нам контейнеры Docker и микросервисы, и увидим, как настройка и оркестровка Kubernetes позволяет развернуть систему любой сложности в любом облаке и мгновенно приспособить ее к растущим нагрузкам.

Используя подход Cloud Native, мощь вычислительных облаков Cloud, и обеспечиваемый ими легкий доступ к прорывным технологиям, точную настройку и изоляцию деталей контейнеров Docker, и оркестровку контейнеров и микросервисов с помощью Kubernetes, вы сможете обслуживать миллионы запросов пользователей так легко, как если бы вы с полной уверенностью показали идеально настроенное приложение на вашем ноутбуке.

Author

About the Author

Иван Портянкин

На данный момент я работаю в компании Google над проектами Google Cloud для Kubernetes, App Engine, контейнеров и Java. До этого я работал над распределенными системами электронной биржевой торговли для финансовых компаний в США, а перед этим работал с компаниями Symantec, IBM и Motorola в Санкт-Петербурге.

До работы над этой книгой я написал еще две книги - в 2005 году вышло полное руководство по библиотеке и способе разработки пользовательских интерфейсов Java Swing, а в 2011 году вышло второе, значительно обновленное издание. Найти эти книги можно на моем сайте http://www.ipsoftware.ru. Еще раньше я сотрудничал с известным автором Брюсом Эккелем, и выпустил перевод его бестселлера Thinking in Java на русском языке в 2001 и 2003 годах.

Мое резюме вы сможете найти в LinkedIn (http://linkedin.com/in/ivanporty), код и примеры из книг, а также некоторые полезные инструменты на моей странице в Github. 

Contents

Table of Contents

Введение

  1. Актуальность и глубина информации. Онлайн-документация
  2. Аудитория книги
  3. Программирование и архитектура. Концепция Cloud Native
  4. Русскоязычные термины
  5. Пользовательские интерфейсы
  6. Примеры и их тестирование на GitHub
  7. Выбор Go и Java
  8. Сторонние библиотеки и инструменты
  9. Основные провайдеры облачных услуг - Amazon, Google, Microsoft
  10. Дополнительные форматы книги на ipsoftware.ru
  11. Открытый текст. Благодарности

1. Приложения, созданные для облака — концепция Cloud Native

  1. Основные положения концепции Cloud Native
  2. Микросервисы — быстрый цикл разработки и постоянный выпуск
  3. Контейнеры — изоляция и гарантия неизменяемости версий
  4. Облако — неизменная эластичная инфраструктура. “Феникс” вместо “снежинки”
  5. Оркестровка Kubernetes — декларативное описание состояния
  6. Инструменты для сбора журналов и наблюдения
  7. Разработка на практике — 12 факторов облачного приложения
  8. Резюме

2. Микросервисы

  1. Монолиты
  2. Архитектура на основе сервисов (SOA)
  3. Микросервисы по Мартину Фаулеру
  4. Разбиение системы на микросервисы
  5. Обратная сторона медали
  6. Резюме

3. Контейнеры и Docker

  1. Контейнеры — это Linux
  2. Docker
  3. Образы (image) Docker
  4. Интерактивные контейнеры — запуск и управление на примере образа Ubuntu
  5. Открытие мира для контейнера — веб-сервер nginx и работа с портами
  6. Резюме

4. Создание образов Docker. Команды Dockerfile

  1. Структура Dockerfile. Основные команды. Базовый образ
  2. Создание образов для приложений Java, Go, Node.js
  3. Многоступенчатая сборка. Размер образа image
  4. Репозитории образов. Метки, версии и latest
  5. Альтернативы Dockerfile. Jib
  6. Альтернативы Dockerfile. Buildpacks
  7. Резюме

5. Первые шаги в Kubernetes

  1. Первые выводы
  2. Первое развертывание
  3. Сервисы Kubernetes — точка доступа к масштабируемому приложению
  4. Отладка сервисов — переадресация портов
  5. Доступ к сервису из Интернета — балансировщик нагрузки
  6. Доступ к журналам (logs)
  7. Простое горизонтальное масштабирование
  8. Удаление развертывания и сервиса
  9. Визуальное представление кластера
  10. Версии Kubernetes
  11. Резюме

6. Объекты Kubernetes. YAML. Декларативное управление кластером

  1. Несколько слов об «ужасах» YAML
  2. Объект Deployment вместо kubectl create deployment
  3. Объект Service вместо kubectl expose
  4. Императивное управление кластером Kubernetes — create и delete
  5. Декларативное управление кластером. Команда apply
  6. Резюме

7. Взаимодействие сервисов Kubernetes

  1. Обнаружение сервисов через DNS
  2. Обнаружение сервисов с помощью переменных окружения
  3. Сервисы и метки
  4. Основные типы сервисов в Kubernetes
  5. Виртуальные IP-адреса. Kube-proxy
  6. Развертывание нескольких сервисов
  7. Локальное тестирование взаимодействующих сервисов
  8. Проверка готовности сервиса к работе
  9. Резюме

8. Метки и аннотации Kubernetes. «Канарейки». Service Mesh

  1. Метки на практике. «Канареечное» развертывание
  2. «Сине-зеленое» развертывание
  3. Шаблоны YAML — Kustomize
  4. Ручная отладка отсеков Pods и контейнеров с помощью меток
  5. Сетка микросервисов — Service Mesh
  6. Аннотации
  7. Резюме

9. Непрерывное обновление в Kubernetes. Deployment

  1. Непрерывное обновление (rolling update)
  2. История обновлений. Откат к стабильным версиям.
  3. Стратегия непрерывного обновления
  4. Автоматическое масштабирование
  5. Проверка жизнеспособности (liveness)
  6. Резюме

10. Управление ресурсами Kubernetes

  1. Распределение ресурсов по умолчанию
  2. Требования к ресурсам в развертываниях Deployment
  3. Пространства имен Namespace
  4. Дополнительные контексты kubectl
  5. Резюме

Завершение

The Leanpub 60 Day 100% Happiness Guarantee

Within 60 days of purchase you can get a 100% refund on any Leanpub purchase, in two clicks.

Now, this is technically risky for us, since you'll have the book or course files either way. But we're so confident in our products and services, and in our authors and readers, that we're happy to offer a full money back guarantee for everything we sell.

You can only find out how good something is by trying it, and because of our 100% money back guarantee there's literally no risk to do so!

So, there's no reason not to click the Add to Cart button, is there?

See full terms...

Earn $8 on a $10 Purchase, and $16 on a $20 Purchase

We pay 80% royalties on purchases of $7.99 or more, and 80% royalties minus a 50 cent flat fee on purchases between $0.99 and $7.98. You earn $8 on a $10 sale, and $16 on a $20 sale. So, if we sell 5000 non-refunded copies of your book for $20, you'll earn $80,000.

(Yes, some authors have already earned much more than that on Leanpub.)

In fact, authors have earned over $14 million writing, publishing and selling on Leanpub.

Learn more about writing on Leanpub

Free Updates. DRM Free.

If you buy a Leanpub book, you get free updates for as long as the author updates the book! Many authors use Leanpub to publish their books in-progress, while they are writing them. All readers get free updates, regardless of when they bought the book or how much they paid (including free).

Most Leanpub books are available in PDF (for computers) and EPUB (for phones, tablets and Kindle). The formats that a book includes are shown at the top right corner of this page.

Finally, Leanpub books don't have any DRM copy-protection nonsense, so you can easily read them on any supported device.

Learn more about Leanpub's ebook formats and where to read them

Write and Publish on Leanpub

You can use Leanpub to easily write, publish and sell in-progress and completed ebooks and online courses!

Leanpub is a powerful platform for serious authors, combining a simple, elegant writing and publishing workflow with a store focused on selling in-progress ebooks.

Leanpub is a magical typewriter for authors: just write in plain text, and to publish your ebook, just click a button. (Or, if you are producing your ebook your own way, you can even upload your own PDF and/or EPUB files and then publish with one click!) It really is that easy.

Learn more about writing on Leanpub