Автор | Сообщение |
alkresin
|
| moderator
|
Пост N: 31
Зарегистрирован: 06.07.06
|
|
Отправлено: 31.01.08 11:36. Заголовок: Leto DB Server
Только что открыл на Sourceforge новый проект - Leto DB Server - https://sourceforge.net/projects/letodb Это мультиплатформенный ( Windows, Unix/Linux ) сервер баз данных, предоставляющий клиентским программам доступ к dbf/cdx файлам, находящимся на удаленном сервере ( можно и на локальном компьютере запускать - в отладочных целях ). В общем, как ADS :). Проект - на стадии разработки, не все даже базовые функции еще реализованы, до оптимизации дело еще не дошло. Но работает :). Крутится у меня на сервере несколько дней, подключал до 15 клиентов, пока не падает. Мои программы работают с ним нормально. Преимущества по сравнению с обычным файл-сервером: 1) Безопасность - базы могут быть в каталоге, недоступном для клиентских компьютеров - никто их случайно не удалит и не повредит. 2) Поскольку базы открываются серверной программой, а не клиентской, ее целостности ничего не грозит при случайном отключении клиентского компьютера. 3) значительное уменьшение сетевого траффика. 4) Должен быть, по идее, выигрыш в скорости. 5) Возможность контроля за пользователями с помощью утилиты manage ( можно придумать и другие формы контроля ). 6) Можно будет сделать транзакции, stored procedures на Харборе, ... и вообще все в наших руках :). Кто хочет участвовать в разработке, тестировании - пишите.
|
|
|
Ответов - 325
, стр:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
All
[только новые]
|
|
alkresin
|
| moderator
|
Пост N: 110
Зарегистрирован: 06.07.06
|
|
Отправлено: 24.02.08 21:46. Заголовок: Догадываюсь, в чем т..
Догадываюсь, в чем там дело. Попробуйте поменять в line 665: pUStru->uiAreasAlloc = 20; 20 на что-нибудь побольше - 40, например.
|
|
|
Pasha
|
| Администратор
|
Пост N: 821
Зарегистрирован: 23.05.05
|
|
Отправлено: 24.02.08 22:36. Заголовок: сейчас попробую Про..
сейчас попробую Простой тест: Local cPath := '//127.0.0.1:2812/' use (cPath+'table1') new use (cPath+'table2') new ... use (cPath+'table25') new стабильно приводит к gpf на сервере на 25-м use при сборке под xHarbour При сборке под Harbour gpf нет Но при попытке открытия (use) несуществующей таблицы gpf на сервере происходит как для xHarbour, так и для Harbour По поводу udf-функций. Пересборка сервера с нужными функциями для некоторых может вызвать затруднения. Да и добавление новых функций приведет к необходимости пересобрать сервер, что нежелательно Может быть, сделать dll для udf-функций, которую бы сервер загружал, и предоставить программисту добавлять свои функции в эту dll и пересобирать ее ? Хотя, как-то надо указывать codepages, которые должен использовать сервер, то есть без пересборки не обойтись
|
|
|
Pasha
|
| Администратор
|
Пост N: 822
Зарегистрирован: 23.05.05
|
|
Отправлено: 24.02.08 22:41. Заголовок: Да, теперь все работ..
Да, теперь все работает
|
|
|
Pasha
|
| Администратор
|
Пост N: 824
Зарегистрирован: 23.05.05
|
|
Отправлено: 25.02.08 22:51. Заголовок: Смотрю вопросы в Ope..
Смотрю вопросы в Open discussion Наверное, надо заменить: IF !oApp:lAnyExt .AND. !Empty( cBagName ) .AND. Len( cTemp := GetExten( cBagName ) < 3 ) .AND. !( cTemp $ "cdx;idx;ntx" ) на IF !oApp:lAnyExt .AND. !Empty( cBagName ) .AND. Len( cTemp := GetExten( cBagName ) ) < 3 .AND. !( cTemp $ "cdx;idx;ntx" ) ?
|
|
|
Andrey
|
| постоянный участник
|
Пост N: 501
Зарегистрирован: 12.09.06
|
|
Отправлено: 25.02.08 23:19. Заголовок: Когда можно будет пр..
Когда можно будет приступить к тестированию СЕРВЕРА БД под свои рабочие базы ? Я писал об БОЛЬШОЙ проблеме открытия баз с большим количеством полей !!! Если надо образцы баз на которых не работает сервер leto DB , могу выслать.
|
|
|
alkresin
|
| moderator
|
Пост N: 111
Зарегистрирован: 06.07.06
|
|
Отправлено: 26.02.08 11:10. Заголовок: Pasha пишет: Наверн..
Pasha пишет: цитата: | Наверное, надо заменить: IF !oApp:lAnyExt .AND. !Empty( cBagName ) .AND. Len( cTemp := GetExten( cBagName ) < 3 ) .AND. !( cTemp $ "cdx;idx;ntx" ) |
| Точно. Сейчас заменю.
|
|
|
alkresin
|
| moderator
|
Пост N: 112
Зарегистрирован: 06.07.06
|
|
Отправлено: 26.02.08 11:13. Заголовок: Andrey пишет: Я пис..
Andrey пишет: цитата: | Я писал об БОЛЬШОЙ проблеме открытия баз с большим количеством полей !!! |
| Я все исправил, теперь должно работать нормально. Думаю выложить build3 сегодня-завтра.
|
|
|
spair2k
|
| |
Пост N: 15
Зарегистрирован: 31.05.07
|
|
Отправлено: 26.02.08 13:28. Заголовок: создание индексов
в посте говорилось о том, что главная идея этого проекта в легкости переноса существующего кода на другую платформу "добавив 3 строчки кода". попробовал, начал с создания индексов, получилось, но заметил одну вещь - не создаются индексы в которых есть FOR, т.е. в самом индексе TAG прописан, но он пустой. это только у меня проблема?
|
|
|
Pasha
|
| Администратор
|
Пост N: 828
Зарегистрирован: 23.05.05
|
|
Отправлено: 26.02.08 14:05. Заголовок: spair2k пишет: но з..
spair2k пишет: цитата: | но заметил одну вещь - не создаются индексы в которых есть FOR, т.е. в самом индексе TAG прописан, но он пустой. |
| Это на build2 или на свежих сырцах ? Пару недель назад я добавлял OrdCondSet(), должно работать Команду, которой создается индекс, в студию
|
|
|
alkresin
|
| moderator
|
Пост N: 113
Зарегистрирован: 06.07.06
|
|
Отправлено: 26.02.08 17:09. Заголовок: Выложил build3..
Выложил build3
|
|
|
gfilatov
|
| модератор
|
Пост N: 724
Зарегистрирован: 25.05.05
|
|
Отправлено: 26.02.08 17:52. Заголовок: alkresin пишет: Выл..
|
|
|
|
Pasha
|
| Администратор
|
Пост N: 829
Зарегистрирован: 23.05.05
|
|
Отправлено: 26.02.08 23:19. Заголовок: Александр, все-таки ..
Александр, все-таки более 20-ти таблиц не открываются, на сервере происходит gpf Надо увеличить в letofunc.c параметр pUStru->uiAreasAlloc ? И еще возник глючек. После dbAppend() Field->F1 := value ... dbCommit() dbUnlock() на последней команде клиент зависает, по-видимому безуспешно ждет ответ от сервера
|
|
|
alkresin
|
| moderator
|
Пост N: 114
Зарегистрирован: 06.07.06
|
|
Отправлено: 27.02.08 08:49. Заголовок: Александр, все-таки ..
цитата: | Александр, все-таки более 20-ти таблиц не открываются, на сервере происходит gpf Надо увеличить в letofunc.c параметр pUStru->uiAreasAlloc ? |
| Это просто отодвинет барьер после которого происходит gpf. Надо разобраться, в чем дело.
|
|
|
Pasha
|
| Администратор
|
Пост N: 832
Зарегистрирован: 23.05.05
|
|
Отправлено: 27.02.08 19:58. Заголовок: Смотрю, как бы получ..
Смотрю, как бы получше сделать relations Надо и на клиенте, и на сервере хранить установленные relations в каждой РО Затем, на сервере в leto_rec их отрабатывать, и передавать на клиент данные не только текущей РО, но и всех РО, указанных в relations На клиенте их принимать, и соответственно отрабатывать в leto_ParseRec Только при этом надо учесть отложенные commit в связанных РО: проверять не только pArea->uiUpdated, но и изменения в связанных РО Такая схема подойдет ?
|
|
|
alkresin
|
| moderator
|
Пост N: 115
Зарегистрирован: 06.07.06
|
|
Отправлено: 27.02.08 22:38. Заголовок: Александр, все-таки ..
цитата: | Александр, все-таки более 20-ти таблиц не открываются, на сервере происходит gpf |
| Теперь окончательно исправил.
|
|
|
Pasha
|
| Администратор
|
Пост N: 833
Зарегистрирован: 23.05.05
|
|
Отправлено: 27.02.08 23:10. Заголовок: Теперь БД открываетс..
Теперь БД открывается без проблем
|
|
|
alkresin
|
| moderator
|
Пост N: 116
Зарегистрирован: 06.07.06
|
|
Отправлено: 28.02.08 10:36. Заголовок: Смотрю, как бы получ..
цитата: | Смотрю, как бы получше сделать relations Надо и на клиенте, и на сервере хранить установленные relations в каждой РО Затем, на сервере в leto_rec их отрабатывать, и передавать на клиент данные не только текущей РО, но и всех РО, указанных в relations... |
| Чем больше думаю об этом, тем труднее представляю, как это можно сделать корректным путем. RDD методы имеют дело с одной текущей workarea, которая передается им в качестве параметра, а при таком подходе каждый метод, связанный с перемещением по базе, будет получать и должен обрабатывать данные для разных workareas - сделать-то можно, но это нарушает всю логику работы RDD. Не думаю, что это хорошо.
|
|
|
alkresin
|
| moderator
|
Пост N: 117
Зарегистрирован: 06.07.06
|
|
Отправлено: 28.02.08 13:43. Заголовок: Создал developers ma..
Создал developers mail list, подписка на https://lists.sourceforge.net/lists/listinfo/letodb-developers
|
|
|
Pasha
|
| Администратор
|
Пост N: 834
Зарегистрирован: 23.05.05
|
|
Отправлено: 28.02.08 14:57. Заголовок: Буду делать аккуратн..
Буду делать аккуратно Постараюсь, чтобы методы workarea не выходили за пределы своих полномочий Все равно, эффективнее было бы получать посылку от сервера о состоянии всех связанных РО одним пакетом. Да по-другому, наверное, нельзя
|
|
|
alkresin
|
| moderator
|
Пост N: 118
Зарегистрирован: 06.07.06
|
|
Отправлено: 28.02.08 15:36. Заголовок: Выложил build4, т.к...
Выложил build4, т.к. были важные исправления
|
|
|
Ответов - 325
, стр:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
All
[только новые]
|
|