Перейти к содержанию
Fire Monkey от А до Я
  • 0

Переподключение к серверу (DataSnape)


zekelive

Вопрос

Кто работал с DS, подскажите, как реализовать автоматическое переподключение к серверу после тайм-аута? Пробовал кучу вариантов, но не могу отловить момент отключения даже, да и тайм-аут не настраивается. Параметр есть, но реагировать на измененные значения не хочет.

Ссылка на комментарий

Рекомендуемые сообщения

  • 0

эмм... а речь о переподключении к какому серваку?... от клиента к DS или от DS к какому нибудь серваку?

если от клиента к DS то у SQLSonnection есть свойство AfterDisconnect. Имхо, стоит избегать постоянного коннекшна, если конечно это возможно. У меня обычно по необходимости подымается коннешн и отрубается после завершения синхронизации.

если второй вариант ... то аналогичное свойство используемого компонента подключения

 

Ссылка на комментарий
  • 0

если рассуждать логически, нет никакого дисконнекта, есть отсутствие связи при попытке что-то передать

т.е. дисконнект это в основном - обработка ошибок при обмене

пытаемся вызывать что-то, ошибка - переподключение...

Ссылка на комментарий
  • 0
39 минут назад, beklexx сказал:

эмм... а речь о переподключении к какому серваку?... от клиента к DS или от DS к какому нибудь серваку?

если от клиента к DS то у SQLSonnection есть свойство AfterDisconnect. Имхо, стоит избегать постоянного коннекшна, если конечно это возможно. У меня обычно по необходимости подымается коннешн и отрубается после завершения синхронизации.

если второй вариант ... то аналогичное свойство используемого компонента подключения

 

Да. Именно от клиента к DS. Ситуация такова, что пользователь пользовался программой, потом выключил экран и кинул в карман. Через 10 минут достает чтобы снова воспользоваться но клиентская программа уже отключилась от сервера. И приходится закрывать и снова оикрывать приложение. Как сделать так, чтобы при активации формы заново пооисходила процедура подключение ( как при первом запуске программы).

Ссылка на комментарий
  • 0
26 минут назад, krapotkin сказал:

если рассуждать логически, нет никакого дисконнекта, есть отсутствие связи при попытке что-то передать

т.е. дисконнект это в основном - обработка ошибок при обмене

пытаемся вызывать что-то, ошибка - переподключение...

Согласен с вами, отсутствие связи. Как эту связь восстановить?

Ссылка на комментарий
  • 0

также как и в первый раз

if NOT(dm.SQLConnection1.Connected) then
  try
    dm.SQLConnection1.Connected:= True;
....

хотя если реально при отключении связи не происходит дисконнект, то 

if dm.SQLConnection1.Connected then dm.SQLConnection1.Connected:= False;
try
  dm.SQLConnection1.Connected:= True;
....

 

Изменено пользователем beklexx
Ссылка на комментарий
  • 0

я обычно проверяю связь до сервака, прежде чем SQLConnection врубать... чем то типа:

function Tdm.CheckConnect: boolean;
var res: boolean;
begin
  try
    IdTCPClient1.ReadTimeout:= 10000;
    IdTCPClient1.ConnectTimeout:= 10000;
    IdTCPClient1.Connect;
    IdTCPClient1.Disconnect;
    res:=true;
  except
    res:=false;
  end;
  Result:= res;
end;

установив мои IdTCPClient1.Port и IdTCPClient1.Host

Изменено пользователем beklexx
Ссылка на комментарий
  • 0
47 минут назад, beklexx сказал:

также как и в первый раз


if NOT(dm.SQLConnection1.Connected) then
  try
    dm.SQLConnection1.Connected:= True;
....

хотя если реально при отключении связи не происходит дисконнект, то 


if dm.SQLConnection1.Connected then dm.SQLConnection1.Connected:= False;
try
  dm.SQLConnection1.Connected:= True;
....

 

Что то птдобное пробовал уже, но попробую Ваш вариант. Спасибо.

Ссылка на комментарий

Присоединяйтесь к обсуждению

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

Гость
Ответить на вопрос...

×   Вставлено с форматированием.   Вставить как обычный текст

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

×
×
  • Создать...