Skip to content

Latest commit

 

History

History
68 lines (50 loc) · 2.77 KB

README.md

File metadata and controls

68 lines (50 loc) · 2.77 KB

Микросервис для скачивания файлов

Микросервис помогает работе основного сайта, сделанного на CMS и обслуживает запросы на скачивание архивов с файлами. Микросервис не умеет ничего, кроме упаковки файлов в архив. Закачиваются файлы на сервер через FTP или админку CMS.

Создание архива происходит на лету по запросу от пользователя. Архив не сохраняется на диске, вместо этого по мере упаковки он сразу отправляется пользователю на скачивание.

От неавторизованного доступа архив защищен хешом в адресе ссылки на скачивание, например: http://host.ru/archive/3bea29ccabbbf64bdebcc055319c5745/. Хеш задается названием каталога с файлами, выглядит структура каталога так:

- photos
    - 3bea29ccabbbf64bdebcc055319c5745
      - 1.jpg
      - 2.jpg
      - 3.jpg
    - af1ad8c76fda2e48ea9aed2937e972ea
      - 1.jpg
      - 2.jpg

Как установить

Для работы микросервиса нужен Python версии не ниже 3.6.

pip install -r requirements.txt

Как запустить

python server.py

Сервер запустится на порту 8080, чтобы проверить его работу перейдите в браузере на страницу http://127.0.0.1:8080/.

При запуске можно указать следующие параметры:

  • логгирование. По умолчанию включено.
--logging
  • папка с фотографиями. По умолчанию - test_photos.
--photos_folder
  • задержка между скачиваниями фрагментов архива. Один фрагмент - 1000 байт. По умолчанию задержка = 0.
--delay

Как развернуть на сервере

python server.py

После этого перенаправить на микросервис запросы, начинающиеся с /archive/. Например:

GET http://host.ru/archive/3bea29ccabbbf64bdebcc055319c5745/
GET http://host.ru/archive/af1ad8c76fda2e48ea9aed2937e972ea/

Цели проекта

Код написан в учебных целях — это урок в курсе по Python и веб-разработке на сайте Devman.