anonymous@RULINUX.NET~# Last login: 2024-12-26 11:01:03
Регистрация Вход Новости | Разметка | Пользователи | Галерея | Форум | Статьи | Неподтвержденное | Трекер | Правила форума | F.A.Q. | Ссылки | Поиск
[#] [Добавить метку] [Редактировать]
Скрыть

Способ передачи изображений по сети

Есть десктопная программка, клиент-серверная архитектура, но на сервере ничего особенного нет. По сути - морда для удалённой работы с БД и кучка серверных скриптов. Клиентская часть посылает SQL запросы и получает результат, авторизация выполняется силами БД.

Но, кроме данных в БД, есть ещё файлы, в данном случае - изображения. В базе сохраняются пути к файлам, ну а клиент их должен как-то забирать и отображать. Сейчас всё это счастье делается через FTP. В принципе работает, хотя насчёт самого протокола есть сомнения.

Во-первых - он не очень безопасный, как пишут в интернете. Картинки, конечно, не бог весть какие важные, да и сервер сидит в локальной сети за NAT-ом, но всё равно, мало ли что в будущем будет. Во-вторых - разделение прав, допустим на чтение и запись, реализуется через классические юниксовые методы, пользователи и группы. Выглядит немного кривовато, да и простора для модернизации уже нет. Вот, собственно, и вопрос: а что бы такое вместо FTP сделать?

Из рассматриваемых вариантов:

1. HTTP. Воткнуть вебсервер, показывать картинки через него, в качестве аутентификации сделать либо HTTP basic auth (или как она там зовётся), или можно в будущем сделать простую программу, которая будет раздавать картинки на основе данных из БД и какой-нибудь логики. С другой стороны - а лучше ли оно будет, чем FTP?

2. WebDAV. Никогда с ним не работал, но, говорят, для такого подходит.

3. Хранить картинки в базе в виде блобов, так тоже кто-то делает. Меня это немного смущает, да и требований "сделать всё через БД" нет. Насчёт производительности тоже есть сомнения.

Кто-нибудь знает красивые и удобные способы для решения этой задачи?

SystemV(*) (2011-07-29 22:20:00)

Emacs-w3m/1.4.414 w3m/0.5.3

[Ответить на это сообщение]
[#] [Добавить метку] [Редактировать] Ответ на: Способ передачи изображений по сети от SystemV 2011-07-29 22:20:00
avatar
Скрыть

Re: Способ передачи изображений по сети

Я за первый вариант, если картинки большие - то тянуть в несколько потоков. Недостаток: клиенту потребуется два протокола - к базе и веб-серверу. Ещё бы интерфейс клиента к БД завернуть через HTTP, возможно с переносом части логики на сервер.

anonymous(*)(2011-07-29 23:21:08)

[#] [Добавить метку] [Редактировать] Ответ на: Re: Способ передачи изображений по сети от anonymous 2011-07-29 23:21:08
avatar
Скрыть

Re: Способ передачи изображений по сети

>Я за первый вариант, если картинки большие - то тянуть в несколько потоков. Недостаток: клиенту потребуется два протокола - к базе и веб-серверу.
Мне тоже первый вариант больше нравится, наверное его и выберу. Ну а два протокола есть и сейчас, так как ftp, так что я ничего не потеряю.

>Ещё бы интерфейс клиента к БД завернуть через HTTP, возможно с переносом части логики на сервер.
Тоже возникала такая мысль. Правда там есть вопросы, т.к. сервер иногда должен оповещать клиента (например об обновлении базы, или ещё о чём-нибудь), а в http это всё как-то криво реализуется, всякие long-polling и недоделанные вебсокеты. Тут я просто пока не соображу, как лучше всего сделать, буду читать гугл.

SystemV(*)(2011-07-30 15:41:19)

Emacs-w3m/1.4.414 w3m/0.5.3
[#] [Добавить метку] [Редактировать] Ответ на: Способ передачи изображений по сети от SystemV 2011-07-29 22:20:00
avatar
Скрыть

Re: Способ передачи изображений по сети

блоб будет сильно нагружать базу, но имеет свои преимущества. Если большой нагрузки не планируется, то довольно удобно.

ФТП сам по себе совершенно безопасен. Опасны бажные проги и криворукие одмины. Да и смешно заботиться о безопасности, если SQL-запросы посылает удалённый клиент. Выбор между ФТП и ХТТП - ерунда, сделай как попало. Какой-нибудь тайнихттпд будет не хуже фтпд, а с точки зрения возможной расширяемости - лучше. Потом можно будет вынести часть бизнес-логики на веб-сервер с перспективой поставить опач или томкат не меняя клиентскую часть.

про вебдав не ведаю. Почитай его описание для начала чтоли

bugmaker(*)(2011-07-31 00:22:09)

Opera/9.62 (X11; Linux i686; U; en) Presto/2.1.1
[#] [Добавить метку] [Редактировать] Ответ на: Re: Способ передачи изображений по сети от SystemV 2011-07-30 15:41:19
avatar
Скрыть

Re: Способ передачи изображений по сети

> а в http это всё как-то криво реализуется
на самом деле не совсем. Через аякс вполне смотрибельно, если коиент по таймауту опрашивает. В чём-то лучше, чем постоянное сокетное соединение - отвалившийся клиент не будет держать мёртвый коннекшн.

bugmaker(*)(2011-07-31 00:24:13)

Opera/9.62 (X11; Linux i686; U; en) Presto/2.1.1
[#] [Добавить метку] [Редактировать] Ответ на: Re: Способ передачи изображений по сети от SystemV 2011-07-30 15:41:19
avatar
Скрыть

Re: Способ передачи изображений по сети

> два протокола есть и сейчас, так как ftp, так что я ничего не потеряю.
Выброси базоданновый протокол

> Тоже возникала такая мысль. Правда там есть вопросы, т.к. сервер иногда должен оповещать клиента (например об обновлении базы, или ещё о чём-нибудь), а в http это всё как-то криво реализуется, всякие long-polling и недоделанные вебсокеты.
В базе данных это скорее всего тоже нетривиальное дело.

А так.. Поставишь какой-нибудь похапэшный акселератор с кешиком. В кешике сохраняешь значение когда в последний раз произошло событие такое-то. Пришешь одну функцию на похапэ которая берёт из кешика это значение и отдаёт клиенту с заголовками чтобы проксики это кешировали не дольше 1й секунды . Стопицот клиентов ежесекундно опрашивают сервер по адресу  http://yuorserver.narod.ru/server.php?isEventHappened и им либо проксик отдаёт результат либо сам сервер, но при этом не особо нагружаясь (можно даже дату не парсить на каждый запрос - сложить в кеше же текст ответа и плювать им в клиентов)

Остальные запросы в базу тоже можно представить в виде вызовов скрипта, который будет возвращать XML или JSON клиенту. Потом к этому и вебдванольную морду можно будет приделать..

anonymous(*)(2011-07-31 00:47:58)

[#] [Добавить метку] [Редактировать] Ответ на: Re: Способ передачи изображений по сети от bugmaker 2011-07-31 00:24:13
avatar
Скрыть

Re: Способ передачи изображений по сети

> на самом деле не совсем. Через аякс вполне смотрибельно, если коиент по таймауту опрашивает. В чём-то лучше, чем постоянное сокетное соединение - отвалившийся клиент не будет держать мёртвый коннекшн.
Да со всех сторон лучше - а что если таких клиентов стопицот? На каждого коннекшен держать задолбаешься.

anonymous(*)(2011-07-31 00:49:43)

[#] [Добавить метку] [Редактировать] Ответ на: Re: Способ передачи изображений по сети от bugmaker 2011-07-31 00:22:09
avatar
Скрыть

Re: Способ передачи изображений по сети

>Да и смешно заботиться о безопасности, если SQL-запросы посылает удалённый клиент.
Ну там всякие https и все дела, логины с паролями и разделение прав. Хотя да, от прямого SQL надо отказаться.

>Выбор между ФТП и ХТТП - ерунда, сделай как попало.
Оно уже сделано как попало на FTP:)

SystemV(*)(2011-08-01 14:42:52)

Emacs-w3m/1.4.414 w3m/0.5.3
[#] [Добавить метку] [Редактировать] Ответ на: Re: Способ передачи изображений по сети от anonymous 2011-07-31 00:49:43
avatar
Скрыть

Re: Способ передачи изображений по сети

>Да со всех сторон лучше - а что если таких клиентов стопицот? На каждого коннекшен держать задолбаешься.
Ну можно взять асинхронный сервер, которому, в принципе, пофигу на количество коннекшенов в случае long-polling запросов, которые тупо висят. По нагрузке, наверное, выйдет тоже самое, что и периодические соединения на один адрес раз в 2 секунды.

SystemV(*)(2011-08-01 14:54:41)

Emacs-w3m/1.4.414 w3m/0.5.3
[#] [Добавить метку] [Редактировать] Ответ на: Способ передачи изображений по сети от SystemV 2011-07-29 22:20:00
avatar
Скрыть

Re: Способ передачи изображений по сети

Тред не читал, но думаю надо все выпилить, БД тоже и забирать картинки и данные (хранимые в файлах) по sftp, а данные сжимать в блобы и криптовать GPG, на dm-crypt разделе только с twofish-x-x, при этом производить смену всех ключей каждый месяц.

Вот это будет красиво.

anonymous(*)(2011-08-01 18:52:07)

Mozilla/5.0 (X11; U; Linux i686; ru; rv:1.9.1.19) Gecko/20110701 Iceweasel/3.5.19 (like Firefox/3.5.19)
[#] [Добавить метку] [Редактировать] Ответ на: Re: Способ передачи изображений по сети от anonymous 2011-08-01 18:52:07
avatar
Скрыть

Re: Способ передачи изображений по сети

жесть! и керберосом его, керберосом как комаров фумитоксиком

vilfred(*)(2011-08-01 19:05:00)

Mozilla/5.0 (Windows NT 5.1; rv:5.0) Gecko/20100101 Firefox/5.0
Этот тред читают 2 пользователя:
Анонимных: 2
Зарегистрированных: 0




(c) 2010-2020 LOR-NG Developers Group
Powered by TimeMachine

Valid HTML 4.01 Transitional Правильный CSS!