Как сделать облако приложение
Облачное хранилище — популярное решение для хранения важных и тяжелых файлов вне смартфона. Если требуется облако в телефоне Андроид, то можно воспользоваться одним из сервисов от Гугл, Яндекс или Майкрософт. Для работы не требуется выполнять сложных манипуляций. Нужно лишь загрузить и зарегистрироваться в бесплатном приложении.
Что такое облачное хранилище в телефоне Андроид
Облачное хранилище представляет собой удаленный сервер, который позволяет хранить информацию, медиафайлы и данные отдельных приложений. Услуга большинством сервисов предоставляется бесплатно. При этом максимально допустимый объем хранения обычно не превышает 2-10 Гб . Для увеличения пространства в облаке необходимо оформлять платную подписку.
Некоторые компании предлагают ознакомиться и посмотреть функционал сервиса, не регистрируясь. Выгрузка и загрузка информации осуществляется через мобильное соединение или Wi-Fi . При наличии высокоскоростного интернета удается просматривать и выгружать тяжелые файлы в облачное хранилище в кратчайшие сроки.
Благодаря облаку удается не только экономить память на телефоне, но и получить доступ к нужным данным с любого другого стационарного или мобильного устройства с интернетом.
Преимущества и недостатки хранения данных в облаке
Среди преимуществ хранения данных в облаке выделяют:
- защиту от удаления;
- доступ к информации с разных устройств;
- защиту от вирусов;
- резервное копирование данных приложений;
- возможность зайти и получить доступ к файлу в любой момент при наличии интернета.
Облако обычно применяется пользователями, которые хотят иметь общее хранилище документов и получать возможность просматривать их с любого устройства.
Недостатками использования облачных сервисов являются:
- потребность в постоянном интернет-соединении для взаимодействия с облаком;
- риск взлома аккаунта;
- небольшой набор функций.
При бесплатном использовании большинство облачных хранилищ файлов в телефоне предлагают ограниченные возможности. Для получения максимума функций требуется оформлять подписку. Ограничения заключаются в предоставлении малого объема памяти для хранения, а также в отсутствии доступа к редактированию и обмену.
Как пользоваться облаком на Андроиде
Наиболее предпочтительным способом использования облачных хранилищ на телефоне считается загрузка приложения из Play Market. Утилиты предоставляются бесплатно. Для установки следует перейти в магазин приложений, осуществить поиск по названию или категории и загрузить программу. Для использования хранилища требуется предварительно создать аккаунт, после чего войти в него.
Также можно пользоваться нужным облаком на Андроиде через браузер. Такой вариант является менее удобным. Войти в облако можно посредством перехода на официальную страницу сервиса и авторизации через аккаунт.
Во время авторизации потребуется ввести свои данные. Официальные сайты сервисов ориентированы на использование со стационарных ПК и ноутбуков и плохо подходят для мобильных платформ.
Крупные компании (Гугл, Яндекс), адаптируют свои сервисы для смартфонов, что несколько упрощает использование через браузер.
Облачные хранилища — это, по сути, дополнительное место для файлов. Если память телефона заполнена, но есть документы, которые еще пригодятся, можно перенести их в облако. Для этого необходимо:
- Открыть установленное приложение — например, Google Диск .
- Нажать на кнопку со знаком плюса в правом нижнем углу.
- Открыть программе доступ к файлам устройства.
- После загрузки на экране телефона высветится соответствующее уведомление.
Загруженный файл можно будет открывать непосредственно в облаке или загрузить на любое устройство.
Лучшие облачные хранилища для смартфонов
Крупные IT компании предлагают собственные облачные сервисы, которые можно использовать на Андроиде, iOS, Windows и Mac. Чтобы подобрать для себя наиболее подходящее решение, следует внимательно ознакомиться с условиями предоставления услуги.
Персональное файловое хранилище, которое позволяет синхронизировать папки с ПК с другими устройствами, смартфонами и ноутбуками.
Большой объем памяти ( до 2 Тб ) при использовании платного тарифа; высокий уровень безопасности; возможность быстро найти нужный файл.
Отсутствие встроенных текстовых редакторов; малый объем диска при использовании бесплатной версии.
Хранилище, предназначенное для размещения файлов разного формата. Имеется возможность создавать собственные папки и перемещать файлы между ними прямо в облаке.
Встроенный антивирус, который не допустит загрузки вредоносного файла; безлимитное пространство при выгрузке фото со смартфона; 8 Гб бесплатного дискового пространства для каждого пользователя; достаточно функциональное приложение для Андроид
Малое количество платных тарифов; текстовый редактор хорошо работает только в версии для браузера на ПК; в определенных ситуациях невысокая скорость при загрузке.
Облачный сервис с большим функционалом даже в бесплатной версии. Особенностями Microsoft One Drive считается наличие офисных редакторов, удобное приложение для Андроид и понятный интерфейс в десктопной версии.
Высокий уровень защищенности; наличие платного тарифа, который позволяет восстанавливать удаленные файлы в течение 30 дней ; возможность упорядочить хранимую информацию.
Малое количество памяти в бесплатной версии (всего 5 Гб ); отсутствие функции поиска файлов по названию; периодически возникающие неполадки на сервере.
Сервис с возможностью группирования файлов и предоставления общего доступа к загруженной информации. Особенностью MEGA считается высокий уровень безопасности, который достигается за счет применения ключа шифрования.
50 Гб свободного места на диске, возможность пользоваться сервисом без регистрации; удобный интерфейс; большой выбор платных тарифов
Невысокая скорость выгрузки и загрузки файлов; малофункциональное мобильное приложение для Андроид смартфонов
Хранилище и файлообменник, среди отличительных особенностей которого находится надежность и простота в использовании. Для выбора доступны платные тарифы (99 рублей в месяц — 100 Гб , 300 рублей — 1 Тб , 750 рублей — 3 Тб ).
10 Гб памяти на диске при бесплатном использовании; наличие приложения для Андроид и Айос;
несколько видов подписок; автоматическое определение скорости интернета.
Наличие большого количества рекламы; отсутствие истории изменения файлов; нет возможности синхронизации папок за пределами каталога Яндекс.Диска.
Один из самых популярных сервисов, который предлагает множество возможностей. Для использования Диска подойдет общий аккаунт Google. Применять сервис можно посредством отдельного приложения на смартфоне или входа на сайт.
15 Гб общего хранилища бесплатно;
возможность просматривать фото, офисные файлы и видео прямо из облака без задержек;
настройка доступа для разных пользователей;
встроенные текстовые редакторы;
высокий уровень безопасности.
Документы, которые находятся в общем доступе, могут индексироваться поисковыми системами; возможны проблемы с конфиденциальностью файлов.
Облачное хранилище нужно выбирать с учетом личных предпочтений, целей и задач. Также требуется учитывать, при каких сценариях будет использоваться облако. Для личного применения отлично подойдут бесплатные сервисы от популярных компаний. Для профессионального использования внутри организаций рекомендуется сразу приобретать платную подписку для получения максимального функционала и большего пространства на виртуальном диске.
Если на телефоне недостаточно места или малый объем встроенной памяти, использование облака — отличное решение. Чтобы установить и настроить приложение, не потребуется много времени. В облачное хранилище можно выгружать фото и видео с телефона, а также синхронизировать данные приложений. Сервис можно использовать для обмена документами и совместного редактирования рабочих офисных файлов.
В предыдущем посте мы рассказали, как облачные сервисы превратились в негласный стандарт предоставления ИТ-услуг. Нетрудно догадаться, что компании, которые желают по-прежнему зарабатывать на пользовательских приложениях, должны адаптировать и создавать новые продукты с учетом Cloud-Native подхода. Впрочем, для разработчиков это однозначно позитивная новость, поскольку использование облачных технологий открывает для них огромные новые возможности. Главное уметь ими правильно распорядиться.
Когда приложение заказывает окружение
Если вы уже читали гид по облачным технологиям, то наверняка помните, что одним из «источников магии» облаков является технология виртуализации. Благодаря этому разработчику практически не нужно задумываться о параметрах серверов, на которых будет работать его приложение. Зачем тратить на это время, если правильно настроенный гипервизор или контейнер могут сконфигурировать машину с практически любыми характеристиками, которые нужны приложению для работы?
Развитием этой идеи является подход Infrastructure as code (IAC). Его суть в том, чтобы дать возможность разработчикам или службам эксплуатации применять для обслуживания инфраструктуры такие же подходы, которые используются на этапе разработки. Он позволяет готовить общие программные блоки управления заранее и легко осуществлять интеграцию таких компонентов в новых проектах.
Возможности современных ЦОДов уже позволяют переходить к декларативному языку управления инфраструктурой. В идеале, приложение должно само администрировать занимаемый им пул ресурсов в дата-центре. Это позволит разработчику не быть запертым в ограничениях, связанных с процессом работы с инфраструктурой, когда надо заказывать и проектировать наперед или если одни и те же компоненты инфраструктуры повторяются в разных проектах.
Фактически разработчик или инженер делает Pull Request, в котором находится конфигурация виртуальной машины (ядра, память, сеть, шаблон и т.д.), далее менеджер виртуального окружения самостоятельно создает машину или создает новый инстанс базы данных или стартует предустановленный сервис, согласно настройкам в файле. Такой подход — настоящее спасение при работе с большими данными и нейронными сетями. Приложения, связанные с этими технологиями, в некоторых случаях нуждаются в динамически изменяемых объемах памяти и процессорных мощностей.
Например, для обучения сети необходимо «прогнать» через нее сотни гигабайт информации, и облака позволяют получить необходимые для этого мощности по запросу. После того, как обучение будет завершено, ресурсы возвращаются в пул провайдера, а разработчику не нужно думать, чем их занять или как по-другому сконфигурировать приложение, чтобы оно продолжало работу на меньшем объеме мощности.
Монолит vs. упорядоченный хаос
Благодаря тому, что облака умеют эластично подстраиваться под потребности разработчика, это, теоретически, упрощает еще одну задачу – проблему масштабирования приложений. Почему теоретически?
К сожалению, задача по масштабированию приложений не является линейной. Чтобы приложение справлялось с огромными нагрузками в периоды пиковой посещаемости (или вычислений), недостаточно просто давать ему дополнительную память и процессорные мощности. Абсолютно у каждого традиционного приложения есть порог, после которого оно уже не в состоянии «переварить» новые ресурсы и продемонстрировать рост производительности. Проблема в данном случае состоит не в ресурсах, а в самой архитектуре большинства программ.
Особенно остро эта проблема стоит для приложений с монолитной архитектурой, которые, фактически, представляют собой единые бинарные файлы. Достоинства такого подхода очевидны: монолитные приложения достаточно просты и линейны. Все сценарии поведения пользователя можно предсказать, отследить и при необходимости произвести отладку бага.
Однако у такой простоты есть цена. Во-первых, это уже упомянутые выше проблемы с масштабированием. В какой-то момент даже самое продуманное монолитное приложение перестает работать эффективнее от апгрейда конфигурации сервера на котором оно исполняется.
Во-вторых, монолитное приложение не так-то просто перенести на новые сервера и для этого может потребоваться полная перекомпиляция программы.
В-третьих, такое приложение сложно поддерживать и развивать. Любое обновление превращается требует полной сборки всей программы, и ошибка в одном из блоков кода может обернуться падением всей системы.
В поисках идей, как решить эти проблемы была разработана другая концепция – service-oriented architecture (SOA). Она подразумевает, что приложение разделено на несколько модулей, каждый из которых предоставляет другим какую-то функциональность. Между собой модули взаимодействуют через набор веб-служб, и независимо друг от друга могут обращаться к единой или к собственным базам данных.
Такой подход действительно упрощает поддержку программы и не превращает ее обновление «в работу сапера», в которой нет права на ошибку; но и у него есть свои недостатки. Ключевой из них – проблемы с масштабированием разработки таких приложений. По мере роста программы, новые функции становится все сложнее «запихивать» в изначально утвержденные архитектором 5-10 пакетов. Их число становится все больше, что оборачивается проблемами с поддержкой.
Микросервис как элемент эволюции приложения
Результатом эволюции SOA стала идея микросервисной архитектуры, которая и используется при конструировании облачных приложений. Концептуально идеи обоих подходов крайне схожи, и некоторые архитекторы даже не выделяют микросервисную архитектуру в отдельную парадигму, считая ее частным случаем SOA.
Микросервисная архитектура подразумевает, что приложение состоит не из какого-то небольшого количества крупных модулей, а из множества независимых друг от друга частей. В отличие от монолита, в микросервисном приложении можно использовать различные способы взаимодействия компонентов между собой. У системы нет единого, заранее определенного состояния. Вместо этого каждый компонент работает «по ситуации»: как только ему поступает событие он начинает работу. Это позволяет делать очень гибкую и независимую архитектуру.
При этом число сервисов в микросервисном приложении постоянно меняется – какие-то добавляются, какие-то удаляются. В новом подходе можно любой микросервис заменить и вместо него встроить цепочку микросервисов. Другие сервисы продолжают стабильно работать, потому что не связаны напрямую между собой. Такова естественная эволюция программы. Благодаря этому у разработчиков и архитекторов появляется возможность быстро что-то менять, чтобы реагировать на изменения бизнес-требований и опережать конкурентов.
Помимо повышения скорости выпуска обновлений использование микросервисной архитектуры позволяет добиться децентрализации управления. Команда, которая отвечает за разработку того или иного сервиса, сама вправе определять его внутреннюю архитектуру и его особенности. Такой подход, кстати, сейчас в Блоке Технологии внедряет Архитектурный совет Сбербанка.
При этом садясь за разработку своего облачного приложения не следует спешить со скорейшим дроблением его на составные элементы. Главный противник подобного бездумного подхода — Мартин Фаулер; он же – один из авторов идеи микросервисной архитектуры. Проще изначально использовать монолитный подход, и потом стимулировать эволюцию приложения «естественным образом», ориентируясь на расшивку узких мест и добавление дополнительных функций.
В результате можно сформулировать следующее правило: задача программиста при работе с микросервисной архитектурой – не просто разбить приложение на максимальное количество составных частей, а разумным образом разграничить их ответственность за получение и обработку данных.
Четыре детали
Помимо множества очевидных достоинств, у микросервисной архитекутуры есть свои особенности, которые необходимости учитывать при разработке своего облачного приложения. В частности, для поддержки работы такого приложения необходимо постоянно поддерживать повышенные требования к качеству управления внутренними API.
Когда один из компонентов меняет свой интерфейс, он должен поддерживать обратную совместимость, чтобы поддерживать прошлую версию собственного API. Если это правило соблюдается, можно динамично переключаться со старой версии на новую без сбоев работе. Если же поддержка прежней версии API не проработана, то это грозит в лучшем случае, потерей части функциональности приложения, а в худшем – постоянными сбоями в его работе.
Вторая важная особенность микросервисных приложений заключается в сложностях поиска в них багов. Если «падает» приложение, написанное в монолитной логике или SOA, найти источник проблемы не составит труда. В приложении, состоящем из множества сервисов, поиск причины бага может сильно затянуться из-за того, что данные от пользователя нередко проходят обработку через несколько микросервисов, и сложно определить, в каком именно из них происходит сбой. При этом процесс поиска бага нужно вести очень аккуратно: любой неудачный рефакторинг может привести к поломке работающего модуля, и в дополнение к первоначальной проблеме разработчик получит вторую.
Третья важная деталь, которую необходимо учитывать, разрабатывая облачное приложение – способ взаимодействия его составных частей между собой. Как и в SOA, для обмена данными сервисы используют веб-службы, но в микросервисной архитектуре появились паттерны взаимодействия, например, как streaming, CQRS, Event sourcing. Обычно разработчики рассчитывают, что время отклика между запросом и ответом в приложении достаточно небольшое. В распределенной системе нельзя полагаться даже на то, что ответ вообще придет.
Так же в архитектуре облачных приложений микросервисы используют различные базы данных, наиболее оптимально подходящие для решения их конкретных задач. Например, гриды могут быстро читать, но с трудом справляются с большим количеством операций по изменениям данных. Такая база хорошо подойдет для ведения счетов вкладов – они редко изменяются. Другой тип операций – процессинг; в нем ежедневно по каждой карте могут быть десятки изменений, а чтений данных наоборот мало.
Наконец, четвертый факт, о котором нужно помнить при разработке облачного приложения – микросервисная архитектура ориентирована в первую очередь на использование сервисов без поддержки состояний. При этом не стоит впадать в крайности. Некоторые сервисы, при необходимости, все же могут осуществлять поддержку состояния, если того требует бизнес-логика, и они должны быть спроектированы особенно тщательно.
Например: если пользователь делает запрос на получение кредита, то получившая заявку система должна это состояние сохранить, чтобы передать его другим сервисам. А вот сервис, отвечающий за поиск информации во внутренней картотеке кредитных историй, может не сохранять состояние и забыть о том, данные на какого именного пользователя он искал пару минут назад – все равно уже через мгновенье ему придет новый запрос (хотя и в этом процессе может быть различное поведение сервиса).
Все описанные выше примеры и практики уже активно используются лидерами мировой ИТ-отрасли. Например, пионером в развитии микросервисной архитектуры является Netflix. Компания выпустила множество open-source приложений, библиотек и фреймворк для мониторинга, балансировки и логирования запущенных микросервисных приложений.
В этой электронной книге описывается подход, основанный на шаблонах, для создания реальных облачных решений. Шаблоны применяются к процессу разработки, а также к методикам архитектуры и программирования.
Содержимое основано на презентации, разработанной Скотт Гатри (, и доставляется ИТ-специалистом на конференции для норвежских разработчиков (NDC) в июне 2013 (часть 1, часть 2) и в Microsoft Tech Ed австралии в сентябре, 2013 (часть 1, часть 2). Многие другие были обновлены и дополнены содержимым при переходе из видео в письменную форму.
Целевая аудитория
Разработчикам, которые интересуются разработкой для облака, в том числе переходим в облако или не знакомы с разработкой в облаке, будет представлен краткий обзор наиболее важных концепций и рекомендаций, которые необходимо знать. Основные понятия показаны в конкретных примерах, а в каждой главе содержатся ссылки на другие ресурсы для получения более подробных сведений. Примеры и ссылки на дополнительные ресурсы предназначены для Microsoft Frameworks and Services, но эти принципы также применяются и к другим платформам веб-разработки и облачным средам.
Разработчики, которые уже разрабатывают для облака, могут найти здесь идеи, которые помогут сделать их более успешными. Каждую главу серии можно читать независимо друг от друга, чтобы можно было выбирать интересующие вас темы.
Все, кто наблюдался с Скотт Гатри (для создания реальных облачных приложений с помощью презентации Azure и хочет получить дополнительные сведения и обновленную информацию, найдет это здесь.
Шаблоны разработки в облаке
В этой электронной книге объясняется, как тринадцать рекомендованные шаблоны для разработки в облаке. "Шаблон" используется здесь в широком смысле, что означает рекомендуемый способ сделать следующее: как лучше всего разрабатывать, проектировать и программировать облачные приложения. Это ключевые шаблоны, которые помогут Вам «попадать в «смолу успеха», если вы их проберете.
- Используйте скрипты для повышения эффективности и снижения числа ошибок в повторяющихся процессах.
- Демонстрация. сценарии управления Azure.
- Настройка структуры ветвления в системе управления версиями для упрощения рабочего процесса DevOps.
- Демонстрация: Добавление скриптов в систему управления версиями.
- Демонстрация: Обеспечьте защиту конфиденциальных данных от системы управления версиями.
- Демонстрация. использование Git в Visual Studio.
- Автоматизируйте сборку и развертывание с каждым возвратом системы управления версиями.
- Типы хранилищ данных.
- Выбор правильного хранилища данных.
- Демонстрация: база данных SQL Azure.
- Секционирование данных по вертикали, горизонтали или обоим, чтобы упростить масштабирование реляционной базы данных.
- Храните файлы в облаке с помощью службы BLOB-объектов.
- Демонстрация. Использование хранилища BLOB-объектов в приложении Fix ИТ.
- Типы сбоев.
- Область сбоя.
- Основные сведения об SLA.
- Используйте интеллектуальную логику повтора и возврата, чтобы уменьшить влияние временных сбоев.
- Демонстрация. повторное или обратное отключение в Entity Framework 6.
- Повышение масштабируемости и снижение затрат на транзакции базы данных за счет использования распределенного кэширования.
- Обеспечение высокой доступности и повышение масштабируемости благодаря слабо связанным веб-и рабочим уровням.
- Демонстрация. очереди службы хранилища Azure в приложении Fix ИТ.
- Известные проблемы
- Рекомендации
- Загрузка, сборка, запуск и развертывание.
В этой оставшейся части главы представлен пример приложения Fix it и веб-приложения в облачной среде службы приложений Azure, в которой выполняется приложение для устранения проблем.
Пример приложения Fix ИТ
Большинство снимков экрана и примеров кода, приведенных в этой электронной книге, основаны на приложении Fix ИТ, первоначально разработанном Скотт Гатри ( , чтобы продемонстрировать Рекомендуемые шаблоны и методики разработки облачных приложений.
Вы можете отслеживать ход выполнения созданных рабочих элементов, просматривать сведения о билетах и помечать их как завершенные.
Это очень простое приложение с точки зрения возможностей, но вы узнаете, как создать его, чтобы он мог масштабироваться до миллионов пользователей и будет устойчивым к таким возможностям, как сбои баз данных и разрывы подключений. Вы также узнаете, как создать автоматизированный и гибкий рабочий процесс разработки, который позволит вам быстро и лучше повысить эффективность и улучшить работу приложения.
Веб-приложения в службе приложений Azure
В фоновом режиме веб-приложения в службе приложений Azure предоставляют множество архитектурных компонентов и функций, которые вам пришлось бы создавать, если вы собираетесь разместить веб-сайт с помощью IIS на собственных виртуальных машинах. Один из компонентов — это конечная точка развертывания, которая автоматически настраивает IIS и устанавливает приложение на столько виртуальных машин, сколько требуется для запуска сайта.
Если компьютер выходит из строя, Azure автоматически извлекает его из ротации, запускает новый экземпляр виртуальной машины и начинает направление трафика на новый экземпляр — все без времени простоя для приложения.
Все это происходит автоматически. Вам нужно всего лишь создать веб-сайт и развернуть в нем приложение, используя Windows PowerShell, Visual Studio или портал управления Azure.
Сводка
В этом вводе представлен список разделов, которые будут рассмотрены в книге, снимки экрана примера приложения и краткий обзор веб-приложений в облачной среде службы приложений Azure. Одно из замечательных преимуществ разработки приложений в и в облаке заключается в том, что можно легко автоматизировать повторяющиеся задачи разработки, такие как создание тестовой среды и развертывание в нем кода. Как это сделать, тема в следующей главе.
Ресурсы
Дополнительные сведения о темах, описанных в этой главе, см. в следующих ресурсах.
SaaS – это наиболее распространенная модель оказания услуг для большинства поставщиков софта. Эта модель также помогает поставщикам облачных решений предоставлять инфраструктурные услуги (IaaS). Приложения зачастую создаются в публичном облаке, например, в Amazon Cloud (AWS), Microsoft Azure, Google Cloud и др. Однако иногда организации используют ресурсы своего дата-центра для размещения приложений, чтобы инвестировать только в свою инфраструктуру. Для разработки приложений SaaS нужно больше, чем просто деплой в облаке. Правильное проектное планирование поможет качественно проработать структуру, оптимально сократить расходы и более эффективно управлять развертыванием. В этой статье будет представлено несколько ключевых моментов и советов по распространению приложений, работающих по модели SaaS , которая еще долго будет широко применяться.
Микросервисная архитектура .
Если у вас монолитное приложение, возможно, имеет смысл разбить его на логические части, которые можно развернуть по отдельности. Это не только улучшит модульность, но и оптимизирует приложение для того, чтобы оно занимало меньше места. Предположим, у вас есть приложение, которое использует фоновые процессы. Можно развернуть основное приложение и фоновые процессы отдельно, разбив это все на 2 или более отдельных приложения. Это сократит потребность в ресурсах. Кроме того, теперь есть возможность еще и независимо масштабировать приложения по отдельности в зависимости от потребностей каждой части. Если есть спрос на фоновые процессы, вы можете увеличить размер ресурса под них, то же самое можно сделать и с ресурсами для основного приложения. Так как ресурс для каждого модуля небольшой, масштабирование конкретного дискретного уровня или элемента обойдется дешевле, чем масштабирование больших ресурсов.
Непрерывная поставка обновлений
Это новинка для многих локальных приложений. Клиенты всегда ожидают последней версии от облачных приложений. Если смотреть на это со стороны разработчика, - теперь вы можете не только апдейтить по частям, но и вносить изменения в структуру данных пользователей так, чтобы они этого не заметили. Процесс обновления приложения становится полностью прозрачным для клиентов.
Это лишь некоторые моменты. Но основная суть очевидна.
Выбирайне подходчщие сервисы. Допустим, вы хотите развернуть приложение в облаке, но для начала задумайтесь, какие именно облачные сервисы вы хотите использовать для этой цели? Просто IaaS (Инфраструктура как услуга)? Или PaaS (Платформа как услуга)? Ответ не всегда на поверхности. А если планируете развернуть приложение на нескольких облачных платформах или локально? Имеет смысл пользоваться услугами поставщика по минимуму и больше внимания уделить модели IaaS. Итак, вот несколько рекомендаций:
Приценитесь и выберите оптимальное решение
Важным фактором при выборе решения должна быть стоимость. Например, некоторые PaaS-сервисы, управляемые поставщиками облачных решений, могут быть переведены под управление силами вашей команды, чтобы снизить затраты. Хотя такая схема подходит не для каждого сервиса, стоит все предусмотреть.
Учитывайте опыт своей команды
Задайте себе вопросы:
- Что нужно конкретно вам, чтобы использовать облачный сервис?
- Если бы ваша команда самостоятельно занималась поддержкой основной инфраструктуры, какие навыки были бы ей необходимы?
Проектируйте с учетом вероятности отказа системы
Проектирование отказоустойчивых и высокодоступных приложений имеет основополагающее значение для облачных услуг. Предположим, ваше приложение работает со сбоями, сможете ли вы гарантировать, что пользователи продолжат с ним работать? Учтите, сбои могут быть как в приложении, так и в базовой инфраструктуре.
Использование балансировщика нагрузки
Узлы приложения для этого размещают за балансировщиком нагрузки, чтобы в случае выхода из строя нескольких узлов, приложение обслуживалось через другие узлы.
Использование модели с географическим распределением
Некоторые поставщики предлагают возможность для распределения приложения по нескольким географическим областям, чтобы даже в случае физического воздействия на одну локацию (например, из-за стихийного бедствия) приложение можно было бы обслуживать из других локаций. Например, облако AWS предлагает развертывание приложения в нескольких зонах доступности.
Безопасность
Безопасность включает в себя множество аспектов – от защиты инфраструктуры до защиты приложений. Некоторые аспекты безопасности нацелены на доступность только требуемых портов, использование как можно меньших привилегий для ресурсов, управление доступом на основе ролей, шифрование и т.д. Безопасность не должна рассматриваться как одномоментное действие. Это продолжительный процесс, который должен постоянно совершенствоваться.
Многопользовательская аренда
Ключевое преимущество работы в облаке – это возможность обслуживания нескольких пользователей, использующих один и тот же экземпляр приложения. Это помогает выявить некоторые очевидные пробелы в проекте приложения, чтобы гарантировать, что данные пользователей разделены как с целью обеспечения безопасности, так и в целях его администрирования. Некоторые используют разные экземпляры базы данных для каждого клиента. А другие – одну базу данных, присваивая данным идентификаторы конкретных клиентов. Независимо от того, какой подход вы используете, важно убедиться, что архитектура отвечает требованиям масштабируемости и безопасности. Например, если вы решите использовать базу данных для каждого клиента, вы можете разместить несколько баз данных в одном экземпляре СУБД.
Минимизация времени простоя системы и бесшовное обновление
Многие клиенты ожидают от приложений SaaS минимального или нулевого времени простоя. И так как обычно поддержкой занимается компания-разработчик приложения, обновления происходят бесшовно. Проблема заключается в том, что ваше приложение, возможно, не предназначено для обновлений без прерывания работы, особенно если оно изначально не разрабатывалось как SaaS -приложение. Есть 2 ключевых аспекта , которые следует учитывать:
а) обновление кода приложения
б) изменение структуры данных в хранилище
Для выкатывания приложений могут быть использованы специальные стратегии, в которых новый выпуск деплоится в новой программной среде (стеке), затем тестируется и запускается, если деплой прошел успешно. Старые ресурсы стека могут быть выведены из эксплуатации и задействованы позже. Один из подходов к бесшовному обновлению состоит в том, чтобы сделать модель данных «n-1 совместимой». Это значит, что, если развернутый выпуск имеет версию модели данных n, она совместима с предыдущей версией модели (n-1), таким образом гарантируется, что обновление не сломает ее. Откуда гарантии? На протяжении всего цикла разработки требуется серьезная дисциплина и следование определенным рекомендациям, например, нельзя удалять столбцы, предоставляя необходимые скрипты обновления для обработки любых потребностей миграции данных и т.д. В случае, если обновление не произойдет, есть возможность откатить его. Теперь ясно, что это не только технически сложно в исполнении из-за миграции и отката данных, н о еще и может замедлиться процесс развертывания. Вам следует тщательно продумать , что наиболее подходит под ваши потребности, и реализовать соответствующее решение.
Еще немного о финансовой составляющей
По мере создания вашего приложения и проектирования деплоя, вы можете предложить несколько подходов для развертывания. Тем не менее, для успешной реализации модели SaaS необходимо выбрать наиболее экономически эффективную модель, которая не только отвечает вашим актуальным потребностям, но может удовлетворить еще и потенциальные, например, в случае роста или падения спроса на ресурс . Сейчас поясним. Допустим, вы не хотите растрачиваться впустую на резервирование ресурсов, но и хотите избежать ситуации, когда приложение не справляется с очень большим наплывом пользователей и высокой нагрузкой. Важно найти правильный баланс. Эмпирическое правило при выборе размера ресурса: всегда прислушивайтесь к своему опыту, а если в процессе тестирования выяснится, что требуется более высокая конфигурация, - увеличивайте.
DevOps – очень актуальная тема в разрезе модели SaaS, стоит рассмотреть ее отдельно. Выделим ключевые моменты DevOps для облачной модели:
Непрерывный деплой
Использование системы контроля версий для всего, включая изменения DevOps
Понятно, что для кода приложения используется ветка master репозитория. Важно сделать то же самое и для любых изменений кода скриптов DevOps . Например, когда вы внедряете изменения в инфраструктуру, они тоже должны быть включены в систему контроля версий, протестированы и только затем отправлены в продакшн.
Гибкая инфраструктура
Чтобы преуспеть в SaaS, вам надо убедиться, что ваша инфраструктура достаточно гибкая и справится с изменениями спроса на ресурсы. По мере роста спроса она должна масштабироваться до соответствующего уровня, а при снижении – высвобождать незадействованные мощности. Экспериментируйте, чтобы отыскать баланс. К примеру, вы можете использовать автоматическое масштабирование, облачная инфраструктура в этом случае будет «подстраиваться» сама.
Мониторинг и оповещения
Технологические стеки обычно состоят из десятков постоянно обновляющихся компонентов, устранение неполадок может стать проблемой. Важно использовать правильные механизмы мониторинга и оповещения, чтобы в случае алерта получилось быстро устранить проблему. Хороший совет – использовать некоторые базовые возможности мониторинга через облако: централизованное ведение журнала, аварийные сигналы, уведомления об ошибках.
О планировании и расстановке приоритетов
Как и в любом успешном проекте, в SaaS тоже без планирования не обойтись. Хотя многие стремятся просто выкатывать версии одну за другой в продакшн. Но всегда важно учитывать первичные потребности бизнеса и правильно расставлять приоритеты. Да, вы не ослышались, растягивать цели – неплохо. Важно сначала правильно все спланировать. Если у вас нет хорошего модульного тестирования или автотеста, и вы пытаетесь выкатить каждый новый фрагмент кода в продакшн, вряд ли это сулит хорошие перспективы в итоге. Могут возникнуть неприятные последствия. Программные продукты начнут слишком часто ломаться после деплоя, и проектная группа будет вынуждена тратить время и усилия на сглаживание негативных последствий.
SaaS влияет также на модель автоматизации
В своей инфраструктуре вы можете продавать лицензии лишь на определенную сумму, а при SaaS вам предстоит переосмыслить модель для вашего бизнеса. Хотите ли вы использовать модель на основе подписки, на основе потребления, гибридную модель или какую-то еще…
Надеемся, вы получили исчерпывающее представление о том, что необходимо для разработки облачного или SaaS-приложения. Это, безусловно, полезный опыт, помогающий взглянуть на разработку приложения, учитывая разные аспекты, и грамотно запустить его в продакшн. Как говорится: «Облако – это путешествие, а не конечный пункт прибытия!»
Забудь о Dropbox и Google Drive.
Пока разработчики сервисов борются между собой, не давая нам выбрать идеальное решение, предлагаю организовать свое облако и забыть о других альтернативах.
Зачем мне свое облако?
Свое облачное хранилище имеет ряд преимуществ и лишь несколько недостатков, с которыми можно ужиться. Для начала о плюсах такого решения:
- никаких тарифных планов, лимитов и платежей;
- передача любых файлов между устройствами и потоковый просмотр данных на любом девайсе;
- никакие файлы не будут выгружаться на сторонние сервера;
- можно создавать ссылки для ограниченного доступа к файлам (предоставлять временный доступ или разрешить только чтение);
- просто круто упомянуть в разговоре с друзьями, что у тебя есть свое облачное хранилище.
Можно будет забыть о существующих сервисах и перестать приглашать новых друзей, когда закончится свободное место в Dropbox или Yandex Диск. Конечно, собственное облако имеет ряд ограничений по сравнению с популярными решениями:
- не получится передавать данные между приложениями (некоторые программы и игры имеют поддержку популярных облаков, «прикрутить» туда наше облако не удастся);
- придется держать включенным серверный компьютер для доступа к данным из облака.
Как видите, недостатки у решения не такие уж и существенные, можно создать свое облако для личных целей, а при необходимости обменяться данными между приложениями на iPhone или постоянно иметь доступ к определенным данным всегда пригодится имеющийся аккаунт в том же Dropbox или Google Drive.
Что мне понадобится для создания своего облака?
- любой компьютер, который будет выступать сервером;
- учетная запись в сервисе Tonido;
- 5 минут свободного времени.
Для многих может стать проблемой необходимость в постоянном компьютере-сервере. Подойдет любой стационарный Mac или PC, который выступает в роли медиа-сервера в квартире или просто может быть регулярно включен.
Можно использовать и ноутбук, но во время работы вдалеке от розетки придется останавливать сервер облака, чтобы экономить заряд аккумулятора и сетевой трафик. В это время просмотреть данные с других устройств не получится.
Я уже готов, что нужно делать?
Для начала переходим на сайт сервиса Tonido и загружаем бесплатное приложение для своей операционной системы (выбираем раздел с серверными программами). Есть версии для OS X, Windows и Linux.
После установки программы нас автоматически перебросит на сайт сервиса, регистрируемся и создаем свою учетную запись. Процедура полностью бесплатна и не займет больше минуты времени. В процессе мы придумаем постоянный web-адрес для нашего хранилища (он будет выступать логином) и пароль для авторизации.
Важным этапом является выбор папок доступных извне. Если пропустить этот шаг, то при подключении с другого устройства можно будет просматривать и редактировать абсолютно любые файлы с компьютера-сервера.
В любой момент через веб-интерфейс в разделе Разное можно добавить или удалить видимые в облаке папки.
Как теперь пользоваться облаком?
Когда настройка будет завершена, можно попытаться получить доступ к данным с любого другого устройства, для этого предусмотрено несколько вариантов:
- можно просто авторизироваться в своем аккаунте через браузер и получить доступ к файлам;
- для мобильных устройств можно загрузить бесплатное приложение (есть версии для iOS, Android, Windows Phone и BlackBerry OS);
- для компьютера есть возможность установить клиентскую программу.
Какие возможности есть у моего облака?
Возможности бесплатного аккаунта в Tonido практически безграничны. Ознакомиться со всем перечнем можно на специальной странице. Для личного использования большинству из нас этого хватит с головой. Корпоративные клиенты могут получить еще целый вагон полезных фишек, но за это придется заплатить.
Через мобильное приложение на iPhone и iPad можно:
- загрузить любой файл с компьютера или на него;
- просматривать фильмы или сериалы без загрузки на устройство;
- слушать музыкальную коллекцию, превратив клиентское приложение в облачный плеер;
- сохранять любые данные для работы с ними оффлайн.
Клиенты для настольных операционных систем обладают аналогичными возможностями и ни чем не уступают решениям от облачных сервисов. Можно настроить постоянную синхронизацию, чтобы иметь копии всех расшаренных файлов.
Как сделать ограниченный доступ для определенных пользователей?
Отдельного упоминания заслуживает режим предоставления ограниченного доступа. Чтобы выдать кому-либо права на просмотр определенных данных, заходим в веб-интерфейс. Здесь открываем любую из доступных папок и нажимаем на иконку с гаечным ключом.
Выбираем раздел Общая папка и открываем Расширенные опции.
Здесь можно создать учетную запись с ограниченными правами или задать временное ограничение, после указанной даты файлы по сгенерированной ссылке будут недоступны.
Вот такой ряд весомых аргументов имеет свое облако. Теперь любые данные будут всегда с вами без условностей и ограничений.
(8 голосов, общий рейтинг: 4.75 из 5)Артём Суровцев
Люблю технологии и все, что с ними связано. Верю, что величайшие открытия человечества еще впереди!
Читайте также: