Warum ist es aufwendig eine Datenbankverbindung herzustellen

Status
Nicht offen für weitere Antworten.
Hallo!

Immer wieder hört man, dass es sehr kostspielig sei, eine Datenbankverbindung aufzubauen.

Ich frage mich allerdings, was daran wirklich so kostspielig ist.

Hier steht beispielsweise:
"Database connections are often expensive to create because of the overhead of establishing a network connection and initializing a database connection session in the back end database. In turn, connection session initialization often requires time consuming processing to perform user authentication, establish transactional contexts and establish other aspects of the session that are required for subsequent database usage."

Also 2 Sachen sind demnach aufwendig:
1. Aufbau der Verbindung, also TCP-Verbindung z.B.
2. Initialisierung einer Session z.B. Authentifizierung, das mit Transaction Context versteh ich eigentlich nicht, wird der nicht erst aufgebaut, wenn man wirklich eine Anweisung abschießt?

OK. Der erste Punkt kann nicht so wahnsinnig teuer sein, schließlich hat man das gleiche auch bei jeder Anfrage eines Browsers an einen Webserver. Für den Aufbau der TCP-Verbindung brauche ich 3 Meldungen, three-way-Handshake, die hin- und hergehen.

Und was ist an dem 2. Punkt hinsichtlich der Übertragungen so aufwendig?
Wieviele Meldungen müssen denn für Authentifizierung hin- und hergehen?
Meiner Meinung nach reichen 2.
1. Nachricht mit Nutzername und Passwort
2. Bestätigung oder Ablehnung

sind also insgesamt in der TCP-Instanz 4 Meldungen, Nachricht + Bestätigung.

Sind also insgesamt 7 Meldungen, die Hin- und Hergehen müssen, bevor man die erste Anfrage machen kann.
Im Vergleich dazu 3 Meldungen, bevor Browser eine Anfrage stellen kann.


Ist das Alles? Das Verhältnis von 7:3?

Was ist zusätzlich aufwendig? Das Kreieren eines Connection-Objekte an sich, also abzüglich der gerade berechneten Zeiten für die Roundtrips?

Vielen Dank für die Antworten im Voraus. Wenn ihr mir geholfen habt, gönne ich euch auch ein schönes WE, vorher nicht. ;-)

bis dann,

Jörg
 

AlArenal

Top Contributor
Schonmal daran gedacht, dass für eine neue DB-Verbindung serverseitig ein neuer Prozess gestartet werden muss?

Der Vergleich mit einem Webbrowser ist ziemlich banane. Ich kenne genug Spaghetti-Code wo einer pro Seitenaufruf zig DB-Verbindungen aufbaut. Das Verhältnis Web- zu DB-Verbindungen ist daher bestenfalls 1:1.

P.S.:
Ich hab schon Wochenende und wenn du dich auf den Kopf stellst! :p
 
S

SlaterB

Gast
1.
> Database connections are often expensive to create because of the overhead of establishing a network connection

dies ist nicht im Vergleich zu einer Browser-Verbindung gemeint, sondern z.B. im Vergleich zu einen lokalen Cache im Hauptspeicher/ Festplatte,
auch eine Browser-Verbindung ist elendig langsam, darum gibts ja auch einen Webseiten-Cache

2.
beim zweiten Punkt siehst du nur die x Nachrichten, die einfache TCP-Verbindung zur Datenbank, dabei steht doch in dem englischen Text viel mehr, Transaktionskontext usw, da siehst du locker drüber weg?

> das mit Transaction Context versteh ich eigentlich nicht, wird der nicht erst aufgebaut, wenn man wirklich eine Anweisung abschießt?

ach doch nicht, tja, ich weiß es auch nicht so genau, wenn aber jemand sagt, dass es dauert, dann vielleicht mit Grund
 
M

maki

Gast
1. Aufbau der Verbindung, also TCP-Verbindung z.B.
...
OK. Der erste Punkt kann nicht so wahnsinnig teuer sein, schließlich hat man das gleiche auch bei jeder Anfrage eines Browsers an einen Webserver. Für den Aufbau der TCP-Verbindung brauche ich 3 Meldungen, three-way-Handshake, die hin- und hergehen.
Da übersiehst du etwas ;)

Zugriffe auf den Hauptspeicher zB. liegen im Nanosekunden Bereich, während die Latenzzeiten des Netzwerkes im Milli-, bestenfalls im oberen Microsekunden Bereich liegen, das ist ein riesengroßer Unterschied.
Ob es allerdings subjektiv Wahrgenommen wird ist eine andere Frage.

2. Initialisierung einer Session z.B. Authentifizierung, das mit Transaction Context versteh ich eigentlich nicht, wird der nicht erst aufgebaut, wenn man wirklich eine Anweisung abschießt?
...
Und was ist an dem 2. Punkt hinsichtlich der Übertragungen so aufwendig?
Wieviele Meldungen müssen denn für Authentifizierung hin- und hergehen?
Meiner Meinung nach reichen 2.
1. Nachricht mit Nutzername und Passwort
2. Bestätigung oder Ablehnung
Je nach Sicherheitsstufe ist es dann einiges mehr, dazu kommt das einige DBs wirklich lange brauchen um eine Connection zu erstellen, schliesslich Poolen ja zeitkritische/grössere Anwendungen und brauchen so nicht oft eine neue zu erstellen.
Das beenden einer Verbindung braucht auch Ressourcen.

sind also insgesamt in der TCP-Instanz 4 Meldungen, Nachricht + Bestätigung.

Sind also insgesamt 7 Meldungen, die Hin- und Hergehen müssen, bevor man die erste Anfrage machen kann.
Im Vergleich dazu 3 Meldungen, bevor Browser eine Anfrage stellen kann.
Ich halte das überspitzt gesagt für eine "Milchmädchenrechung".

Der Browser bedient nur einen einzigen User, während der Server alle Browser bedient, je nach Anwendung kommen da bis zu ein paar hundert User zusammen, da macht sich da ständige öffnen &schliessen der DB Verbindung sehr schnell bemerkbar.

Auf Tomcat zB. kann man einen ConnectionPool vom Server verwalten lassen, deine Webanwendung würde über JNDI daruf zugreifen. Damit wäre auch die Änderung der DB Konfiguration (Username, Passwort, IP/Servername, Port, Anzahl der gepoolten Verbindungen, etc. pp.) möglich ohne deine Anwednung zu ändern.
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
B Wie kann ich eine Jtable mit Inhalt einer SQL Abfrage füllen Datenbankprogrammierung 14
I SaaS Applikation: pro Kunde eine Datenbank / Schema oder eine DB für alle Kunden? Datenbankprogrammierung 76
Zrebna PostgreSQL-Query in eine MicrosoftSQL-Query konvertieren - chatGPT hilft nur bedingt. Datenbankprogrammierung 3
T Spring MongoDB: Prüfen ob bereits eine Email existiert Datenbankprogrammierung 15
Zrebna Wie mittels Hibernate eine Join-Tabelle als eigene Java-Klasse erstellen? Datenbankprogrammierung 5
Zrebna Probleme bei Überführung von SQL-Code in eine HQL-Abfrage Datenbankprogrammierung 3
Zrebna Wie mittels PL/SQL eine Datenbankverbindung blockieren? Datenbankprogrammierung 6
berserkerdq2 Was genau muss ich bei date eingeben, wenn ich in Java eine Spalte definiere, die date ist? Datenbankprogrammierung 1
pkm PostgreSQL Kann mit mybatis einen Parameter für eine postgreSQL-Abfrage nicht übergeben. Datenbankprogrammierung 5
Kirby.exe Eine Tabelle updaten Datenbankprogrammierung 16
B Wie kopieren ich eine Spalte von einer Tabelle in eine andere Tabelle SQLite durch java code? Datenbankprogrammierung 26
Z Aus zwei bestehenden Table eine zusätzliche Gemeinsame machen (JavaFX) Datenbankprogrammierung 21
Avalon Attribute werden mit Unterstrich in eine MySQL Datenbank eingetragen Datenbankprogrammierung 10
pkm PostgreSQL Auf eine Spalte kann aus einem Teil der SQL-Aussage nicht zugegriffen werden Datenbankprogrammierung 3
F Mapping einer SQL Abfrage in eine Klasse Datenbankprogrammierung 4
H suche eine Login system Bibliothek für Java Datenbankprogrammierung 5
C Datenbank anlegen und über eine Website mit Daten füllen? Datenbankprogrammierung 25
G Eine Spalte in xampp als Typ array erstellen - ein array mit "insert" hinzufügen. Datenbankprogrammierung 3
F Create Table - Habe ich eine schwache Entität erzeugt ? Datenbankprogrammierung 4
Dimax MySQL Trigger für eine Spalte Datenbankprogrammierung 5
Dimax MySQL Maximale Datenlänge für eine Spalte einer Datenbank in java ermitteln Datenbankprogrammierung 15
D MySQL Eibinden des "mysql-connector" in eine fertige Jar Datenbankprogrammierung 3
P JSP - Daten aus 2 Tabellen in eine neue Tabelle einfügen Datenbankprogrammierung 1
P Daten in eine mySQL Datenbank einfügen Datenbankprogrammierung 4
S MySQL JTable zeigt nach Datenbankabfrage eine Spalte zu viel an Datenbankprogrammierung 0
Thallius MySQL Tabelle splitten aber wie eine abfragen? Datenbankprogrammierung 10
B MySQL Eine Art Sverweis Datenbankprogrammierung 27
O HSQLDB Eine Entität, mehrere Tabellen Datenbankprogrammierung 8
B SQL-Statement Prüfen ob eine Spalte einen Wert enthält Datenbankprogrammierung 2
X SQLite Erhalte bei Query INSERT INTO eine NullPointerException Datenbankprogrammierung 10
L0MiN Wie kann ich eine bestimmte Seite aus verschiedenen Excel-Tabellen in eine neue Exceldatei kopieren? Datenbankprogrammierung 1
N Wie in Java Zugriffe und Updates auf eine Datenbank regeln ? Datenbankprogrammierung 1
E Wie kann ich aus diesem XML eine XMLTABLE-Funktion bauen? Datenbankprogrammierung 3
E Wie kann man mit einer ID-Spalte über eine Parameterübergabe auf eine Seite verweisen? Datenbankprogrammierung 17
A Eine MySQL Zeile mit JDBC löschen Datenbankprogrammierung 5
M Warum ist es suboptimal viele Indexe auf eine Datenbanktabelle zu setzen? Datenbankprogrammierung 4
L Datenmodell erstellen für eine Nutzertanalyse Datenbankprogrammierung 1
serjoscha MySQL Eine Instanz von eigenem DBWrapper -> Fehler durch mehrfachbenutzung möglich? Datenbankprogrammierung 2
S HSQLDB Verbieten eines update auf eine bestimmte reihe Datenbankprogrammierung 4
V HSQLDB Insert in eine Tabelle mit Autoincrement Datenbankprogrammierung 2
H Grosse Menge an Daten in eine Datenbank Datenbankprogrammierung 32
P MySQL eine richtige Datenbank für einen routenplaner erstellen Datenbankprogrammierung 2
D SQL Update auf eine Query möglich? Datenbankprogrammierung 4
S SqlObject - eine objektorientierte Art SQL-Statements zu schreiben. Datenbankprogrammierung 4
C Mit jsp über Java eine DB Abfrage durchführen --> java.lang.ClassNotFoundException Datenbankprogrammierung 4
K SQLite CSV-Datei einlesen in eine Datenbank Datenbankprogrammierung 7
E Datenbank Abfragen in eine GUI schreiben Datenbankprogrammierung 8
A Problem mit Eintragen von Daten in eine Datenbank mittels DAO Datenbankprogrammierung 4
L MySQL MySql in eine Application einbinden? Datenbankprogrammierung 18
R MySQL Voraussetzungen für eine erfolgreiche Datenbankanbindung mittels JDBC Datenbankprogrammierung 2
H Derby/JavaDB Eine verschlüsselte Derby-Datenbank wieder entschlüsseln Datenbankprogrammierung 4
D Was passiert bei absolut zeitgleichem Zugriff auf eine Tablerow Datenbankprogrammierung 7
I Belastet es das System zu sehr einen Timer jede 0.2 Sekunden eine DB Abfrage machen zu lassen? Datenbankprogrammierung 9
I Zugriff auf eine Datenbank auf dem Webserver Datenbankprogrammierung 2
F H2:Wie kann man insert eine Reihe "int" wert als blob in table? Datenbankprogrammierung 12
J mal wieder eine Frage zu parallelen Transaktionen.. Datenbankprogrammierung 2
Screen Ich suche eine SQLDatenbank ohne JDBC-Treiber Datenbankprogrammierung 12
H Derby/JavaDB SQLException wenn die Datenbank in eine Jar gepackt wurde. Datenbankprogrammierung 6
turmaline [Hibernate] @OneToMany - Eine referenzierte Tabelle abfragen Datenbankprogrammierung 11
S Werte aus Datenbank auslesen und in eine bestimmte Excelzelle eintragen Datenbankprogrammierung 2
T Wer kann mir eine Datenbank empfehlen Datenbankprogrammierung 13
DStrohma MS SQL Server 2005 + Java: Immer nur eine aktive Verbindung erlaubt? Datenbankprogrammierung 5
D MySQL Wie schreibe ich in eine Datenbank? Datenbankprogrammierung 8
J String[] in eine SQL-Anweisung implementieren Datenbankprogrammierung 13
Q Access Datenbank in eine Internetseite einbinden Datenbankprogrammierung 2
J Über einen Button eine SQL-DB aussuchen Datenbankprogrammierung 3
O eine Tabelle hat mehrere PrimKey mit dem selben Wert Datenbankprogrammierung 9
R Connection Problem für eine externe DB mit Java (JDBC) Datenbankprogrammierung 9
M Zugriff auf eine Access-Datenbank innerhalb eines jar-Files Datenbankprogrammierung 7
N Wie kann ich Zugriff auf eine MS Access DB (mit JDBC) über Netzwerk erreichen? Datenbankprogrammierung 7
G Wie sieht eine Datenbankverbindung mit jndi aus? Datenbankprogrammierung 3
T eine Datenbank updaten Datenbankprogrammierung 6
C Prüfen, ob eine MySQL-Tabelle bereits existiert Datenbankprogrammierung 7
E Wie auf eine MySql Datenbank zugreifen Datenbankprogrammierung 25
D Werte mit java programm in eine Datenbank einlesen Datenbankprogrammierung 7
T JPQL Query für eine Tabellenansicht Datenbankprogrammierung 2
B Wie persistiert man eine Tree-ähnliche Datenbankstruktur? Datenbankprogrammierung 2
M Aus einem Applet eine Datenbankverbindung starten? Datenbankprogrammierung 26
R Datenbankstruktur für eine renn simulation Datenbankprogrammierung 3
H Wie kann ich eine Datenbank Connection aus XML-Datei lesen! Datenbankprogrammierung 2
G Wie baut man eine Anwendung mit DB Zugriff Datenbankprogrammierung 3
S Als Rückgebewert eine Liste von Werten? Datenbankprogrammierung 3
A Auslesen von Werten aus der DB in eine csv-Datei Datenbankprogrammierung 4
O Oracle 11g wirft bei 90 % der installation eine Exception ? Datenbankprogrammierung 5
T Recordsets in eine JTable einlesen mit Netbeans 6.0 Datenbankprogrammierung 2
R Warum kommt eine Exception bei instanceof ? Datenbankprogrammierung 4
M Tabelle von einer Datenbank in eine Andere Datenbankprogrammierung 4
G Inhalt eine Clob Feldes zw. zwei DB's kopieren Datenbankprogrammierung 2
A Einlesen einer csv-Datei in eine H2-Datenbank Datenbankprogrammierung 3
A Kriterium für eine JList neu definieren Datenbankprogrammierung 3
A Probleme beim Schreiben in eine CSV-Datei aus einer H2-DB Datenbankprogrammierung 2
G Import einer csv-Datei in eine H2-Database Datenbankprogrammierung 12
M Mit Java .txt-Datei in eine Datenbank einlesen lassen Datenbankprogrammierung 33
S Zugriff auf eine große Datenmenge von MS Access per JDBC Datenbankprogrammierung 11
S von einer DB auf eine andere Zugreifen. Datenbankprogrammierung 2
W Wann ist eine Telefonnummer atomar ? Datenbankprogrammierung 3
D Dateien in eine OODB abspeichern Datenbankprogrammierung 3
A Eine einzelne Zeile schreibschützen im DataSet Datenbankprogrammierung 13
E 2 Tabellen anhand eine Spalte zusammenführen? Datenbankprogrammierung 5
M GUI für eine Datenbank Datenbankprogrammierung 2

Ähnliche Java Themen

Neue Themen


Oben