SASGIS - SAS.Планета
View Issue Details
0000744SAS.Планета[All Projects] Хотелкаpublic18-05-2011 16:2419-05-2011 04:06
gpsMax 
Parasite 
normalminorhave not tried
closedno change required 
110418 
 
0000744: Многопользовательский доступ к файлу меток (простое минимальное решение, одновременно сидит один юзер)
Нескольким людям хочется работать (править и добавлять) над одной и той же пачкой меток.

В данном тикете опишу простой стандартный путь реализации "типа многопользовательского доступа". Типа - потому что первый юзер заходит и блокирует, остальные сидят и ждут снятия блокировки. Так, например, работает тот же MS Word и многие другие программулины.

На разделяемом ресурсе лежат файлы Categorymarks.sml и Marks.sml. Если какой-то пользователь запускает SAS, тот кладёт в тот же каталог некий файлик-флажок, желательно с именем пользователя внутри. Обычный текстовый файлик, в момент работы открытый, чтоб не удалили случаем. У последующих пользователей SAS проверяет наличие файла-флажка и если он есть, то программа выдаёт пользователю сообщение о том, что база меток заблокирована и используется юзером таким-то (логин берётся из файла).

Как вариант, последующие юзеры могут открыть метки в режиме read-only, без возможности добавлять и изменять что-либо. Вроде такая возможность уже есть (не пробовал, но в 659-й хотелке написано, что вполне), надо только добавить условий.

Итого, получается многозадачность простыми средствами.
доступ, плагины
related to 0000172closed vdemidov Программа блокируется с окном об ошибке при запуске без прав на чтение .sml файлов меток 
related to 0000659closed gpsMax При запуске из общей папки с правами только на чтение выдаётся ошибка про zmp 
related to 0000745closed vdemidov Многопользовательский доступ к файлу меток (сложное решение, одновременно сидит несколько пользователей) 
related to 0000173closed vasketsov Добавить в SASPlanet.ini указание пути к файлам меток (аналогично существующему пути для кэша) 
Issue History
18-05-2011 16:24gpsMaxNew Issue
18-05-2011 16:27gpsMaxDescription Updatedbug_revision_view_page.php?rev_id=1228#r1228
18-05-2011 16:28gpsMaxBug Revision Dropped: Description: 0001227
18-05-2011 16:42gpsMaxRelationship addedrelated to 0000745
18-05-2011 16:44gpsMaxTag Attached: доступ
18-05-2011 16:45gpsMaxRelationship addedrelated to 0000173
18-05-2011 16:45gpsMaxStatusnew => acknowledged
18-05-2011 17:00gpsMaxRelationship addedrelated to 0000172
18-05-2011 17:09gpsMaxDescription Updatedbug_revision_view_page.php?rev_id=1237#r1237
18-05-2011 17:10ParasiteNote Added: 0002575
18-05-2011 17:12ParasiteNote Added: 0002576
18-05-2011 17:17gpsMaxRelationship addedrelated to 0000659
18-05-2011 17:19gpsMaxNote Added: 0002577
18-05-2011 17:21gpsMaxNote Edited: 0002577bug_revision_view_page.php?bugnote_id=2577#r1239
18-05-2011 17:34ParasiteNote Added: 0002579
18-05-2011 20:05vdemidovTag Attached: плагины
19-05-2011 01:57TolikNote Added: 0002582
19-05-2011 04:05ParasiteNote Added: 0002586
19-05-2011 04:06ParasiteStatusacknowledged => closed
19-05-2011 04:06ParasiteAssigned To => Parasite
19-05-2011 04:06ParasiteResolutionopen => no change required

Notes
(0002575)
Parasite   
18-05-2011 17:10   
>Нескольким людям хочется работать (править и добавлять) над одной и той же пачкой меток.
Тикет не нужен:
1. C помощью subst (ну или "Подключить сетевой диск") - папка шары монтируется как локальный диск.
2.0 Если _вся_ папка САСа на шаре_ака_диске - то работаем с ним как обычно. Для всех остальных всё наработанное - таки на общей шаре.
2.1 Если САС - локален, а на шаре _только_ метки - то в папке САСа ставим NTFS-линки на свежесозданный диск. Работаем, улыбаемся и машем.

PS: способ _КРАЙНЕ!!!!!!_ не рекомендуется для одновременной работы более чем 1го пользователя!!!!!
(0002576)
Parasite   
18-05-2011 17:12   
>Если какой-то пользователь запускает SAS, тот кладёт в тот же каталог некий файлик-флажок, желательно с именем пользователя внутри. Обычный текстовый файлик, в момент работы открытый, чтоб не удалили случаем. У последующих пользователей SAS проверяет наличие файла-флажка

PPS: это называется "семафор" :)
(0002577)
gpsMax   
18-05-2011 17:19   
(edited on: 18-05-2011 17:21)
> Если САС - локален, а на шаре _только_ метки - то в папке САСа ставим NTFS-линки на свежесозданный диск.

Можно извернуться и так, но лучше дождаться 173-й хотелки.

> способ _КРАЙНЕ!!!!!!_ не рекомендуется для одновременной работы

Вот-вот. А способ, описанный выше, будет работать устойчиво.

(0002579)
Parasite   
18-05-2011 17:34   
>А способ, описанный выше, будет работать устойчиво.
При принятии во внимание сути тикета ("одновременно сидит один юзер", конец цитаты) - нет никакой разницы со штатным монопольным юзанием вот прямо сегодня.

В данном режиме семафоры _не нужны_.
(0002582)
Tolik   
19-05-2011 01:57   
> первый юзер заходит и блокирует, остальные сидят и ждут снятия блокировки
ТАКОЙ "многопользовательский" доступ никому не нужен.
По-моему, этот тикет надо закрыть.
(0002586)
Parasite   
19-05-2011 04:05   
>По-моему, этот тикет надо закрыть.
+1, ибо он описывает именно то, что имеет место быть в САСе на наст.момент.
CLOSED.