Привет, Хаброжители! У нас вышла новая книга Сэма Ньюмена.

image Книга посвящена программированию микросервисов — небольших автономных компонентов, позволяющих добиться модульности и отказоустойчивости любой программы. Теория микро-сервисов тесно связана с философией Unix, способствует улучшению архитектуры любых приложений, дает возможность избегать громоздкого и запутанного кода. Эта книга поможет читателю заново взглянуть на многие, казалось бы, трудноразрешимые проблемы, масшта-бировать любые проекты, ювелирно разрабатывать даже самые сложные системы.

Эта книга полна конкретных примеров использования микросервисов, собранных по всему миру, включая их применение в таких организациях, как Netflix, Amazon, Gilt и REA group, пришедших к мысли, что возросшая автономность этой архитектуры дает их командам огромные преимущества.



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

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

Зачем я (Сэм Ньюмен) написал эту книгу

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

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

Мир микросервисов сегодня

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

Структура книги

Основа книги по большей части тематическая. Поэтому вы можете произвольно выбирать для изучения темы, которые представляют для вас наибольший интерес. Хотя основные положения и идеи я постарался раскрыть в начальных главах, хочется верить в то, что даже достаточно искушенный читатель найдет для себя что-нибудь интересное во всех главах без исключения. Если же вы хотите углубиться в изучение некоторых более поздних глав, я настоятельно рекомендую просмотреть главу 2, касающуюся обширного характера самой темы, а также дающую представление о принятой мною структуре изложения материала.
Для новичков в данной области главы выстроены таким образом, что им, как я надеюсь, будет иметь смысл прочесть всю книгу от начала до конца. Вот краткий обзор всего, что рассматривается в данной книге.

Глава 1. Микросервисы. Начинается с введения в микросервисы с указанием как их преимуществ, так и некоторых недостатков.
Глава 2. Архитектор развития. Посвящена трудностям компромиссов в архитектурах и многообразию всего, что нужно осмыслить при использовании микросервисов.
??Глава 3. Как моделировать сервисы. Начинается с определения границ микросервисов с использованием в качестве вспомогательных средств, направляющих мысли в нужное русло, технологий, позаимствованных из проектирования, основанного на областях применения.
??Глава 4. Интеграция. В этой главе начинается погружение в конкретные технологические последствия по мере рассмотрения наиболее подходящих нам разновидностей технологий обеспечения совместной работы сервисов. В ней также более глубоко рассматривается тема пользовательских интерфейсов и интеграции с устаревшими и уже готовыми коммерческими программными средствами (COTS-продуктами).
??Глава 5. Разбиение монолита на части. Многие специалисты рассматривают микросервисы в качестве своеобразного антидота от крупных, слабо поддающихся изменениям монолитных систем. Именно этот вопрос и будет подробно рассмотрен в данной главе.
Глава 6. Развертывание. Хотя данная книга носит преимущественно теоретический характер, некоторые темы в ней были подняты под влиянием последних изменений в таких технологиях, как развертывание, которое и станет предметом рассмотрения.
??Глава 7. Тестирование. Данная глава посвящена углубленному рассмотрению темы тестирования, к которой следует отнестись с повышенным вниманием, когда речь зайдет о развертывании нескольких отдельных сервисов. Особо будет отмечена роль, которую в содействии обеспечению качества программных средств могут сыграть контракты, основанные на запросах потребителей.
??Глава 8. Мониторинг. Тестирование программного средства перед развертыванием не помогает, если проблемы обнаруживаются во время его работы в производственном режиме, поэтому в данной главе исследуются возможности мониторинга систем, обладающих высокой степенью детализации, и методы, позволяющие справиться со сложностями, присущими распределенным системам.
Глава 9. Безопасность. В данной главе исследуются аспекты безопасности микросервисов и рассматриваются методы, позволяющие выполнять аутентификацию и авторизацию пользователя по отношению к сервису и сервиса — по отношению к другому сервису. Безопасность в вычислительных системах является весьма важной темой, однако многие ее охотно игнорируют. Хотя я ни в коем случае не считаю себя специалистом в области безопасности, но все же надеюсь, что эта глава поможет вам по крайней мере обдумать некоторые аспекты, о которых нужно знать при построении систем, в частности систем на основе микросервисов.
??Глава 10. Закон Конвея и проектирование систем. Основное внимание в данной главе уделяется взаимодействию организационной структуры и архитектуры. Многие организации уже поняли, что если не добиваться в этом вопросе гармонии, то возникнут существенные затруднения. Мы попытаемся добраться до самых глубин этой дилеммы и рассмотрим несколько различных способов увязки проектирования системы со структурой команд.
Глава 11. Масштабирование микросервисов. В данной главе исследуется порядок всех предыдущих действий в условиях расширения системы, позволяющий справиться с постоянно возрастающими вероятностями сбоев, возникающих в условиях использования большого количества сервисов, а также при больших объемах трафика.
??Глава 12. Коротко обо всем. В заключительной главе предпринимается попытка выделить основные черты, отличающие микросервисы от всего остального. В ней перечислены семь принципов микросервисов, а также подведены итоги по ключевым моментам книги.

Об авторе

Сэм Ньюмен — инженер из компании ThoughtWorks, где в настоящее время совмещает работу над клиентскими проектами с решением архитектурных задач для внутренних систем ThoughtWorks. Сэму доводилось работать с компаниями всего мира в самых разных предметных областях, зачастую заниматься одновременно и разработкой, и поддержкой ПО. Если спросить Сэма, чем он занимается, то он ответит: «Работаю с людьми, чтобы создавать все более и более классные софтверные системы». Сэм Ньюмен — автор статей, докладов на конференциях, время от времени он участвует в разработке свободных проектов.

Более подробно с книгой можно познакомиться на сайте издательства.

Оглавление
Отрывок

Для Хаброжителей скидка 25% по купону — Микросервисы.
По факту оплаты бумажной книги отправляем на e-mail электронные версии книг, при покупке электронной книги — все доступные версии отправляются пользователям.

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


  1. camelos
    26.01.2016 14:03

    Ура )) Как раз на днях хотел купить и на сайте ИД было указано, что не продаётся. А тут ещё и скидка.

    Купил. Спасибо! Жду электроверсию ))


  1. novoxudonoser
    26.01.2016 14:49
    -4

    Книга хорошая, жалко что на трекерах только английская версия.


  1. Borz
    26.01.2016 14:53
    +1

    А при покупке бумажной версии цифру что, нельзя получить?


    1. ph_piter
      26.01.2016 14:59
      +2

      после факта оплаты бумажной книги ссылка на скачивание электронных версий приходит


      1. Borz
        26.01.2016 15:02
        +1

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


      1. andreyr82
        27.01.2016 14:50

        Помнится когда-то издательство обещало мне книгу в электронном формате за купленную бумажную копию (https://habrahabr.ru/company/piter/blog/212023/#comment_7308745), но так и не прислали. А вообще редакторам нужно лучше проверять то, что выходит в печать. Конкретно в той книге (Разработка Backbone.js приложений) было очень много неточностей в переводе, а в примерах кода так вообще были пропущенные строки.


  1. ppiitt123
    26.01.2016 15:26
    +3

    А зачем вы электронную книгу в zip архив положили? :) Из письма сразу в iBooks не добавишь.


  1. Barlog
    26.01.2016 16:15
    +3

    Мало того, что книга в zip, так ещё и в CP1251 кодировке имена файлов. У меня Mac и результат выглядит не очень приятно. Переходите на 7z, там с именами файлов всё будет ок.


    1. Borz
      26.01.2016 16:20

      convmv тебе в помощь


      1. Barlog
        26.01.2016 16:22
        +2

        Благодарю. Я написал об этом по большей части не потому, что для меня это большая проблема, а потому, чтобы сервис ИД «Питер» стремился к идеалу.


    1. Borz
      26.01.2016 16:24

      7z, в отличии от zip, не воспринимают всякие читалки. Т.е. придётся отдельно делать распаковку.
      Тут лучше, как выше предложили — предоставлять возможность скачать не архивом


      1. TheShock
        26.01.2016 18:11
        +5

        А может просто лучше названия файлов на английском написать?

        building_microservices_rus.pdf


        1. Borz
          26.01.2016 18:22

          одно другому не мешает


    1. bappoy
      26.01.2016 17:01

      У меня и Windows архив криво распаковывается нативными средствами.


      1. Borz
        26.01.2016 17:13

        а что за версия/локализация? в русской десятке нормально всё:

        картинка


        1. bappoy
          26.01.2016 17:22

          Корпоративная семерка, английская.
          Причем в реестре в HKLM\CurrentControlSet\Control\Nls\CodePage у ключей «1250» и «1252» значение «c_1251.nls», этот хак я еще со времен XP наизусть помню и полез первым делом проверять.


          1. Borz
            26.01.2016 17:55
            +1

            1. bappoy
              26.01.2016 18:17

              Похоже, спасибо! Проверю после следующей перезагрузки (слишком дорогая операция в рабочее время)


    1. LeXeR3
      27.01.2016 11:05

      Распаковывал на планшете на Android. Аналогичная проблема с названиями файлов. Не критично конечно, но было бы неплохо решить эту проблемку.


      1. Borz
        27.01.2016 14:06

        а зачем распаковывать? Я сразу zip положил в "/Books" — Cool Reader подхватил из него epub без вопросов.


        1. LeXeR3
          27.01.2016 19:33

          мне было удобнее читать pdf.


  1. amstr1k
    26.01.2016 19:30

    ph_piter при покупке на OZON электронные книги не высылаются?


    1. ph_piter
      26.01.2016 21:17

      нет


    1. AlexeiZhuravlev
      26.01.2016 21:53

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


      1. amstr1k
        27.01.2016 17:17

        AlexeiZhuravlev аналогичная ситуация. Знал бы, сделал бы заказ у издательства. ph_piter возможно как то решить этот вопрос?


  1. icepro
    26.01.2016 20:09

    ph_piter, а отрывок из ePUB можно?


    1. ph_piter
      26.01.2016 21:19
      +1

      Сейчас уже некому сверстать, завтра Вам отправим.


  1. asci
    26.01.2016 20:56

    Куда писать если оплата прошла, но не засчиталась? На форме заказа написано «Произошла ошибка» и все. Было бы удобно если бы сразу формочка поддержки была)


    1. ph_piter
      26.01.2016 21:19

      Будьте добры в личку


  1. boblenin
    27.01.2016 05:06

    Спасибо, заказано — ознакомимся :)


  1. karudo
    27.01.2016 07:23

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