AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Probleme mit SQL Server in Terminalsitzung mit mehreren Instanzen
Thema durchsuchen
Ansicht
Themen-Optionen

Probleme mit SQL Server in Terminalsitzung mit mehreren Instanzen

Ein Thema von storfi · begonnen am 12. Jun 2011 · letzter Beitrag vom 13. Jun 2011
Antwort Antwort
storfi

Registriert seit: 1. Dez 2004
15 Beiträge
 
Delphi 5 Enterprise
 
#1

Probleme mit SQL Server in Terminalsitzung mit mehreren Instanzen

  Alt 12. Jun 2011, 10:43
Datenbank: MSSQL • Version: 2005 • Zugriff über: ADO
Hallo,

ich habe bei einem Anwender, bei dem ca. 20 Benutzer auf einem Win2003-Terminalserver arbeiten, gravierende Probleme mit dem SQL Server 2005 (Delphi5-Projekt mit ADO). Meine Vermutung ist, dass dieses spezifische Problem nur dann auftritt, wenn mindestens ein User in seiner Terminalsitzung das Programm mehrmals gestartet hat. Hat jeder Benutzer nur eine Instanz offen, ist soweit alles in Ordnung.

Nun zum eigentlichen Problem: Es gibt Statistiken mit mehreren Minuten Laufzeit. Dabei wird lesend auf eine Tabelle zugegriffen, was zu einem S-Lock führt. Daher habe ich bewusst den Isolation Level auf "Read Uncommited" gesetzt, damit während der Datenaufbereitung andere Benutzer Datensätze in dieser Tabelle einfügen können. Die neuen Datensätze sollen sowieso nicht in der Statistik berücksichtigt werden.

Während der Datenaufbereitung ist der Terminalserver und der Datenbankserver nicht ausgelastet (CPU, Speicher usw.). Trotzdem friert bei anderen Benutzern der Bildschirm ein, wenn neue Datensätze eingefügt werden sollen. Ist die Statistik fertig, können alle anderen Benutzer wieder arbeiten. Also müsste es sich an dieser Stelle um einen Lock auf die Tabelle handeln. Wie gesagt - das Phänomen tritt nur auf, wenn "irgendein" anderer Terminalserver-User mehrere Instanzen in seiner Terminalsitzung offen hat.

Wer hat Erfahrung mit "Read Uncommited" auf MS-Terminalserver? Gibt es einen Isolation Level, der noch weniger restriktiv ist und möglichst gar keine Sperren mehr setzt?

Vielen Dank und noch schöne Feiertage,

Christian
Christian
  Mit Zitat antworten Zitat
generic

Registriert seit: 24. Mär 2004
Ort: bei Hannover
2.416 Beiträge
 
Delphi XE5 Professional
 
#2

AW: Probleme mit SQL Server in Terminalsitzung mit mehreren Instanzen

  Alt 12. Jun 2011, 11:32
Mit dem TS hat das nicht viel zu tun, sondern der SQL Server lockt es halt Aufgrund der Zugriffe.

Grundsätzlich besteht die Möglichkeit das Locking bei einen SQL abzuschalten.
z.B. select * from tabelle with nolock
Coding BOTT - Video Tutorials rund um das Programmieren - https://www.youtube.com/@codingbott
  Mit Zitat antworten Zitat
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#3

AW: Probleme mit SQL Server in Terminalsitzung mit mehreren Instanzen

  Alt 12. Jun 2011, 13:37
Vom Sperrverhalten sollte das "unlock" ja das gleiche Ergebnis liefern, wie der Isolation Level der Connection.
Ich würde dann die SQL Anweisung bevorzugen, weil es direkt an den Server geht und keine Nebeneffekte "unterwegs" in ADO haben kann.

Das Sperrverhalten von msSQL fand ich schon im Jahr 2000 unzweckkmäßig. Dachte da hätte sich mittlerweile was dran getan.
Gruß, Jo
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.861 Beiträge
 
Delphi 11 Alexandria
 
#4

AW: Probleme mit SQL Server in Terminalsitzung mit mehreren Instanzen

  Alt 12. Jun 2011, 13:39
MSSQL unterstützt optional ab Version 2005 Versionierung statt Log als Transaktionssteuerung.
Markus Kinzler
  Mit Zitat antworten Zitat
storfi

Registriert seit: 1. Dez 2004
15 Beiträge
 
Delphi 5 Enterprise
 
#5

AW: Probleme mit SQL Server in Terminalsitzung mit mehreren Instanzen

  Alt 13. Jun 2011, 11:26
Ich setze momentan bei Programmstart über die SQL-Anweisung "SET TRANSACTION ISOLATION LEVEL" explizit auf "READ UNCOMMITED" und war der Meinung, das würde ausreichen. Aber offensichtlich werden andere User parallel mit einem S-LOCK blockiert.

Der Zusatz "WITH NO LOCK" ist ja nur bei SELECT-Anweisungen erlaubt. Daher müsste ich nicht die wenigen INSERTs und UPDATEs ändern, sondern Tausende SELECTs?

Der Hinweis auf die mögliche Versionierung statt Sperren ist für mich sehr interessant. Kann über eine SQL-Anweisung auf "Versionierung" umgestellt werden und wird das im Management Studio einmalig erldigt?

Vielen Dank,
Christian
Christian
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.861 Beiträge
 
Delphi 11 Alexandria
 
#6

AW: Probleme mit SQL Server in Terminalsitzung mit mehreren Instanzen

  Alt 13. Jun 2011, 11:47
Eine Umstellung des Transaktionssteuerungssystems wird wohl nicht nur für eine Abfrage gehen
Markus Kinzler
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 16:19 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz