Performance Problem mit File-I/O

Status
Nicht offen für weitere Antworten.

egrath

Aktives Mitglied
Hallo,

ich habe ein kleines Performanceproblem mit der File Klasse. Aber kurz einmal die vorgeschichte damit man weiss um was es geht:

1.) Ich habe einen Ordner in dem pro Tag von einer Fremdapplikation ~10.000 Dateien (in diversen Unterverzeichnissen) abgestellt werden
2.) Dieser Ordner befindet sich auf einem Netzlaufwerk.
3.) Diese Dateien soll ich in ein Zip Archiv packen und das original löschen.

Ich erstelle mir nun eine Liste aller Dateien die ich zu archivieren habe. Um Informationen über die Datei zu bekommen benutze ich die File Klasse (Name, Letztes Modifikationsdatum, etc.). Und hier liegt der Hund begraben: Für die Abfrage des letzten Modifikationsdatums (lastModified) und ob es sich um ein File handelt (isFile) benötige ich pro Datei 30ms - kommt mir schon etwas lang vor.

Ein noch gravierenderes Performanceproblem habe ich anschliessend beim archivieren: Das Lesen einer einzelnen Datei dauert ca. 2-3 sekunden, obwohl das File gerade mal ~2k gross ist. Folgenden Code benutze ich dabei:

Code:
    public boolean addFile( String filePath, String fileName, String pathInZip )
    throws FileNotFoundException, IOException
    {
        debug_.printMessage( "ZipArchiver.addFile(): Adding to ZIP [" + filePath + "]" );
        FileInputStream inStream = new FileInputStream( filePath );
        zipStream_.putNextEntry( new ZipEntry( MessageFormat.format( "{0}{1}", pathInZip, fileName )));
        
        int len = 0;
        byte[] buffer = new byte[readBlockSize_];
        while(( len = inStream.read( buffer )) > 0 )
        {
            zipStream_.write( buffer, 0, len );
        }
        
        zipStream_.closeEntry();
       
        return true;
    }

Das Problem tritt nur über Netzlaufwerke auf, lokal ist das ganze rasend schnell.

Irgendjemand ne idee?

Danke,
Egon
 

egrath

Aktives Mitglied
Hallo,

danke mal für die Anregung hab ich gerade eben probiert (auf beiden Seiten deaktiviert): Keine Besserung

Ich denke daher dass es irgendetwas damit zu tun haben muss wie die File Klasse intern arbeitet.... naja noch etwas rumexperimentieren vielleicht krieg ich es noch hin.

Grüsse,
Egon
 
T

tuxedo

Gast
Netzlaufwerke (CIFS/Samba-Share) sind nicht die schnellsten. 30ms Latenz um ein "lastModified" nachzuschlagen halte ich da schon für recht schnell. Und generell gilt bei sowas: Je kleiner die Datei, desto schlimmer ist das mit dem lesen/verschicken (Stichwort Puffer und ein passendes flush()). Kann mir nicht vorstellen dass Java daran schuld ist wenns lokal 1a geht.

Als WorkAround fällt mir nur eins ein (hab aber kein Plan ob das wirklich schneller wird):

Bastle nen Java-Server auf den Rechner der die Dateien vorhält und greife mit deinem Pack-Programm auf diesen Server zu. So hast du wenigstens einfluss auf die Puffergrößen, abschaltung des Nagle-Algorithmus' etc. Verwende hierzu am besten Java NIO, sowohl im Netzwerk-Part, als auch im File-lesen-und-schreiben-Part.


- Alex
 

egrath

Aktives Mitglied
Hallo,

ok danke für die Info, dann werd ich mal schauen ob ich das Ding nicht gleich lokal auf dem Server laufen lasse!

Grüsse,
Egon
 
G

Gast

Gast
mußt du inStream eigentlich schließen?

nicht das du dich zumüllst.

Kann es evtl. vorteilhafter sein den FileInputStream in einen BufferedInputStream zu packen.
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
Luma Performance-Problem mit RandomAcces File Allgemeine Java-Themen 4
Chris81T Performance Problem durch mehrfaches Starten eines JAVA Prog Allgemeine Java-Themen 8
S Performance Problem Allgemeine Java-Themen 11
G Performance Problem bei der Übertragung Server zum Client Allgemeine Java-Themen 3
8u3631984 Frage Performance bei Linked List und Array List Allgemeine Java-Themen 5
H Performance einer Monte-Carlo-Simulation verbessern Allgemeine Java-Themen 6
goldmensch Datentypen Welche Methode hat die bessere Performance? Allgemeine Java-Themen 12
H Watson-Crick-Complement Performance Allgemeine Java-Themen 18
L Best Practice Auslagerung von Code = Performance Optimierung? Allgemeine Java-Themen 4
B Performance Messungen Allgemeine Java-Themen 4
J Threads verbessern die Performance NICHT ? Allgemeine Java-Themen 8
X Performance für Tomcat / Apache optimieren Allgemeine Java-Themen 2
I Performance - JDBC UPC PoolDataSoure Allgemeine Java-Themen 0
E Lambda filter performance Allgemeine Java-Themen 2
D Performance-Probleme mit Joda-Time Allgemeine Java-Themen 3
A Jasper Report Performance bei PDF erzeugen Allgemeine Java-Themen 0
A Best Practice Variablen vertauschen - Performance Allgemeine Java-Themen 1
R DBUnit Performance Probleme Allgemeine Java-Themen 0
P Performance: super explizit erwähnen oder weglassen? Allgemeine Java-Themen 5
S starke performance probleme des forums Allgemeine Java-Themen 10
C Performance Tips Allgemeine Java-Themen 13
A Performance/Speicherplatz-Nutzung bei Tests Allgemeine Java-Themen 6
R Java Performance testen Allgemeine Java-Themen 18
StrikeTom Java Performance Fragen Allgemeine Java-Themen 5
V Performance steigern Allgemeine Java-Themen 7
D Reflection-Performance Allgemeine Java-Themen 7
M Einfluss von Caching auf die Performance (große Arrays) Allgemeine Java-Themen 24
R Collections Performance einer HashMap Allgemeine Java-Themen 26
i<3java [Groovy/Grails](oder auch java) Mögliche Performance Probleme bei Mailversendung Allgemeine Java-Themen 2
D Performance Objektallokation Allgemeine Java-Themen 28
J Java Performance nicht nachvollziehbar Allgemeine Java-Themen 3
I Library für High Performance Mime Type Erkennung Allgemeine Java-Themen 8
S Performance Frage: Objekt oder static? Allgemeine Java-Themen 33
M Runtime.exec() - Performance / Frage zu Threads Allgemeine Java-Themen 5
M Performance Allgemeine Java-Themen 6
M Performance Allgemeine Java-Themen 5
E Performance website download Allgemeine Java-Themen 13
MQue Performance Methodenaufruf - if Abfrage Allgemeine Java-Themen 19
hdi Was frisst in meinem Programm den Speicher / verschlechtert die Performance Allgemeine Java-Themen 11
J Performance von Java GUI-Anwendungen Allgemeine Java-Themen 2
U Java Performance im Vergleich zu C++ in speziellem Anwendungsfall Allgemeine Java-Themen 6
S Performance und Function Call Depth Allgemeine Java-Themen 6
H Performance Vorteil durch Wechsel der JVM? Allgemeine Java-Themen 6
A Performance: byte[] in byte[][][] konvertieren Allgemeine Java-Themen 2
T Performance ArrayList#remove Allgemeine Java-Themen 8
ARadauer Performance Pptimierung -Lesen/Schreiben Allgemeine Java-Themen 10
G Hibernate, JTable und Performance Allgemeine Java-Themen 17
M Listener und Performance Allgemeine Java-Themen 9
P Performance: Ziehen ohne Zurücklegen (große Datenmenge) Allgemeine Java-Themen 10
D Performance: ArrayList vs. Array vs. "Eigene Liste&quot Allgemeine Java-Themen 8
M nichtreferenzierte Objekte auf NULL setzen -> Performance Allgemeine Java-Themen 4
S Ursache für schlechte Performance Allgemeine Java-Themen 2
L Java Performance Check Tool Allgemeine Java-Themen 3
S Performance von Comparator Allgemeine Java-Themen 3
X Java Performance auf Sun Systemen bzw. generell Allgemeine Java-Themen 4
T Performance String-Operationen und StringBuffer (1.4und 1.5) Allgemeine Java-Themen 18
P miese performance bei nem BufferedImage + repaint :( Allgemeine Java-Themen 6
T Performance-Grundlagen Allgemeine Java-Themen 4
V Performance Leck finden Allgemeine Java-Themen 3
T Tile Game Performance Allgemeine Java-Themen 32
M Performance enorm langsam Allgemeine Java-Themen 26
F Performance von Reflection vs Statisches Coden Allgemeine Java-Themen 4
M Performance: Java zu C/C++ bei Datenbankanwendung Allgemeine Java-Themen 3
Y unnecessary cast & Performance Allgemeine Java-Themen 29
conan2 Performance von paint() Allgemeine Java-Themen 2
G Performance JDOM - DOM - eigene HashMap (SAX) Allgemeine Java-Themen 2
F Bilder als "Thumbnails" laden - Performance Allgemeine Java-Themen 6
S Java3D Performance optimieren Allgemeine Java-Themen 5
F Wenn ihr Performance wollt nehmt C++ Allgemeine Java-Themen 39
N Performance-Test (Geschwindigkeit von Methoden vergleichen)? Allgemeine Java-Themen 4
S Performance Test mit JMeter Allgemeine Java-Themen 2
T Performance Allgemeine Java-Themen 8
J Anfängerliste für gute Performance? Allgemeine Java-Themen 3
I Performance bei "String <-> Byte"-Umwandlung Allgemeine Java-Themen 4
I Performance-Probleme bei Schleife Allgemeine Java-Themen 3
C Performance von FOR Schleifen Allgemeine Java-Themen 25
C Performance Vergleich, Java vs. Tcl/Tk Allgemeine Java-Themen 3
krgewb Problem mit Umlauten und Eszett bei InputStream Allgemeine Java-Themen 3
Max246Sch Backtracking Problem Box Filler Allgemeine Java-Themen 6
NightVision402 VisualVM Startskript Problem Allgemeine Java-Themen 3
javaBoon86 Email Server Connection Problem Allgemeine Java-Themen 1
F Problem mit PDFBOX Library Allgemeine Java-Themen 1
A Java modul Problem Allgemeine Java-Themen 4
D Read JSON File Problem Allgemeine Java-Themen 9
urmelausdemeis Exception in thread "main" java.lang.Error: Unresolved compilation problem: Allgemeine Java-Themen 7
J Problem mit JasperReports Allgemeine Java-Themen 8
M log4j Problem mit jlink Allgemeine Java-Themen 19
8u3631984 Problem beim Mocken von Record Klassen Allgemeine Java-Themen 4
torresbig Website login Problem - Jsoup, wie bisher, klappt nicht! Allgemeine Java-Themen 31
P Selenium . getText Problem Allgemeine Java-Themen 9
A Jar zu Exe Problem Allgemeine Java-Themen 13
sserio Variablen Liste erstellt und ein Problem mit dem Index Allgemeine Java-Themen 6
S Folgendes Problem bei einem Programm Allgemeine Java-Themen 1
stormyark Problem beim Klassen erstellen Allgemeine Java-Themen 1
A Thread.sleep Problem Allgemeine Java-Themen 2
A Problem bei der Nachbarschafttest Allgemeine Java-Themen 11
Splayfer Problem: no main manifest attribute Allgemeine Java-Themen 3
G javamail Problem beim Empfangen von Nachrichten Allgemeine Java-Themen 3
Splayfer JDA Problem mit MessageCounter Allgemeine Java-Themen 0
Splayfer Problem mit BufferedWriter Allgemeine Java-Themen 3

Ähnliche Java Themen

Neue Themen


Oben