Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Построение системы обновлений, Выбор концепции 
:(
    Опции темы
Lindemann66
  Дата 5.6.2012, 10:04 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Thinking...
*


Профиль
Группа: Участник
Сообщений: 117
Регистрация: 2.8.2011
Где: Ульяновск

Репутация: нет
Всего: нет



Всем привет!
Давно я ничего не спрашивал на этом форуме)

Программа: написанное на Qt приложение, БД - SQLite
Вопрос: к тем, кто имеет опыт в проектировании и реализации систем обновлений
Какие есть варианты?
Ну и просто хотелось бы поделиться опытом со сведущими в этой области людьми

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

Проблемы, которые есть в любом случае:
- Необходимо, чтобы в архиве на сервере лежали в ЛЮБОМ СЛУЧАЕ все файлы, которые потребуются
- Если какого-то файла в архиве нет, будет работать неправильно
- Проблема обновлений конфигурационных файлов чтобы сохранить пользовательские настройки...

Какие мысли по всему этому?smile
--------------------
stay true
PM MAIL WWW ICQ   Вверх
math64
Дата 5.6.2012, 10:54 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2505
Регистрация: 12.4.2007

Репутация: 23
Всего: 72



Если нет ограничений на скорость и объём трафика - лучше скачивать всё.
Если скорость маленькая или нужно платить за трафик - скачивать только изменения.
Если могут быть обрывы в соединении или работа в офф-лайн - скачивать дистрибутив.
В зависимости от условий можно предложить пользователю выбрать способ обновлений.
Проблема обновления файлов конфигурации и базы данных всё равно остаётся при любом способе обновления.
PM   Вверх
Amp
Дата 5.6.2012, 12:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 886
Регистрация: 17.2.2009

Репутация: 7
Всего: 17



 + очень популярный вариант "У нас тут вышло обновление - иди-ка ты на сайт и сам качай" smile Неплохо, когда ПО может обновляться модульно с разрешением зависимостей между отдельными модулями (не обязательно, что один модуль это одна dll/exe). И как следствие - если у программы вдруг появляются плагины или расширения, то их обновление органично вписывается в данную концепцию.

Вариант обновление кстати нужен кроссплатформенный или нет?
PM MAIL   Вверх
_GRIN_
Дата 5.6.2012, 23:11 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


одинокий падаван
**


Профиль
Группа: Участник
Сообщений: 272
Регистрация: 18.11.2007
Где: Калуга

Репутация: 6
Всего: 7



а какая целевая ОС?
Если линукс, то rpm или deb пакет изначальной программы и соответствующие пакеты обновлений


--------------------
Дорогу осилит идущий
PM MAIL Skype   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "С/С++: Кроссплатформенное программирование, QT/Gtk+/wxWidgets"
JackYF
Любитель
  • В заголовке темы в квадратных скобках обозначьте используемую вами библиотеку, например: [QT],[GTK],[wx].
  • Если вопрос актуален только для некоторой версии библиотеки, либо, если вы пользуетесь не самой последней версией, укажите это. Например: [QT4], [GTK2].
  • Все начинающие изучать Qt - не забудьте зайти сюда.
  • Проставьте несколько ключевых слов темы, чтобы её можно было легче найти.
  • В вопросе укажите полную версию версию библиотеки, а также все дополнительные используемые программные пакеты.
  • Не забывайте пользоваться кнопкой "Код".
  • Телепатов на форуме нет! Задавайте чёткий, конкретный и полный вопрос. Указывайте полностью ошибки компилятора и компоновщика.
  • Новое сообщение должно иметь прямое отношение к тематике этого раздела. Флуд, флейм, оффтопик запрещены.
  • Категорически запрещается обсуждение вареза, "кряков", взлома программ и т.д.

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, JackYF, Любитель.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | С/С++: Кроссплатформенное программирование, Qt/Gtk+/wxWidgets | Следующая тема »


 




[ Время генерации скрипта: 0.0627 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.