- fix for NPE when loading the cytag image

- some hacks for less memory usage:
-- less usage of buffer and cache memory in EcoFS
-- buffer allocation on-demand in BufferedIOChunks
-- removed largest ybr idx

git-svn-id: https://svn.berlios.de/svnroot/repos/yacy/trunk@5595 6c8d7289-2bf4-0310-a012-ef5d649a1542
pull/1/head
orbiter 16 years ago
parent 4c11843eba
commit 333489420b

File diff suppressed because one or more lines are too long

@ -77,13 +77,6 @@ public class URLLicense {
public yacyURL releaseLicense(final String license) { public yacyURL releaseLicense(final String license) {
yacyURL url = null; yacyURL url = null;
url = permissions.remove(license); url = permissions.remove(license);
/*
if (url == null) {
System.out.println("DEBUG-URLLICENSE: no URL license present for code=" + license);
} else {
System.out.println("DEBUG-URLLICENSE: granted download of " + url.toString());
}
*/
return url; return url;
} }

@ -75,6 +75,9 @@ public abstract class HttpClient {
* @param timeout in milliseconds * @param timeout in milliseconds
* @return * @return
*/ */
public static byte[] wget(final String uri) {
return wget(uri, new httpRequestHeader(), 10000, null);
}
public static byte[] wget(final String uri, final httpRequestHeader header, final int timeout) { public static byte[] wget(final String uri, final httpRequestHeader header, final int timeout) {
return wget(uri, header, timeout, null); return wget(uri, header, timeout, null);
} }

@ -33,7 +33,7 @@ public final class BufferedIOChunks extends AbstractIOChunks implements IOChunks
protected RandomAccessInterface ra; protected RandomAccessInterface ra;
private int bufferSize; private int bufferSize;
private final long commitTimeout; private final long commitTimeout;
private final byte[] buffer; private byte[] buffer;
private long lastCommit = 0; private long lastCommit = 0;
public BufferedIOChunks(final RandomAccessInterface ra, final String name, final int buffersize, final long commitTimeout) { public BufferedIOChunks(final RandomAccessInterface ra, final String name, final int buffersize, final long commitTimeout) {
@ -41,7 +41,7 @@ public final class BufferedIOChunks extends AbstractIOChunks implements IOChunks
this.ra = ra; this.ra = ra;
this.bufferSize = 0; this.bufferSize = 0;
this.commitTimeout = commitTimeout; this.commitTimeout = commitTimeout;
this.buffer = new byte[buffersize]; // this is a buffer at the end of the file this.buffer = null; // this is a buffer at the end of the file. It will be initialized if necessary
this.lastCommit = System.currentTimeMillis(); this.lastCommit = System.currentTimeMillis();
} }
@ -64,6 +64,7 @@ public final class BufferedIOChunks extends AbstractIOChunks implements IOChunks
// do the read // do the read
if (pos >= this.ra.length()) { if (pos >= this.ra.length()) {
// read from the buffer // read from the buffer
if (this.buffer == null) this.buffer = new byte[this.bufferSize];
System.arraycopy(this.buffer, (int) (pos - this.ra.length()), b, off, len); System.arraycopy(this.buffer, (int) (pos - this.ra.length()), b, off, len);
} else if (pos + len >= this.ra.length()) { } else if (pos + len >= this.ra.length()) {
// the content is partly in the file and partly in the buffer // the content is partly in the file and partly in the buffer
@ -84,13 +85,14 @@ public final class BufferedIOChunks extends AbstractIOChunks implements IOChunks
if (len == 0) return; if (len == 0) return;
if (pos >= this.ra.length()) { if (pos >= this.ra.length()) {
// the position is fully outside of the file // the position is fully outside of the file
if (pos - this.ra.length() + len > this.buffer.length) { if (this.buffer != null && pos - this.ra.length() + len > this.buffer.length) {
// this does not fit into the buffer // this does not fit into the buffer
commit(); commit();
this.ra.seek(pos); this.ra.seek(pos);
this.ra.write(b, off, len); this.ra.write(b, off, len);
return; return;
} }
if (this.buffer == null) this.buffer = new byte[this.bufferSize];
System.arraycopy(b, off, this.buffer, (int) (pos - this.ra.length()), len); System.arraycopy(b, off, this.buffer, (int) (pos - this.ra.length()), len);
this.bufferSize = (int) Math.max(this.bufferSize, pos - this.ra.length() + len); this.bufferSize = (int) Math.max(this.bufferSize, pos - this.ra.length() + len);
return; return;
@ -110,7 +112,7 @@ public final class BufferedIOChunks extends AbstractIOChunks implements IOChunks
public synchronized void commit() throws IOException { public synchronized void commit() throws IOException {
this.lastCommit = System.currentTimeMillis(); this.lastCommit = System.currentTimeMillis();
if (this.bufferSize == 0) return; if (this.buffer == null || this.bufferSize == 0) return;
this.ra.seek(this.ra.length()); // move to end of file this.ra.seek(this.ra.length()); // move to end of file
this.ra.write(this.buffer, 0, this.bufferSize); this.ra.write(this.buffer, 0, this.bufferSize);
this.bufferSize = 0; this.bufferSize = 0;

@ -67,8 +67,8 @@ public class EcoFS {
/** /**
* stay below hard disc cache (is that necessary?) * stay below hard disc cache (is that necessary?)
*/ */
private static final int maxReadCache = 256 * 1024; private static final int maxReadCache = 16 * 1024;
private static final int maxWriteBuffer = 256 * 1024; private static final int maxWriteBuffer = 16 * 1024;
public EcoFS(final File tablefile, final int recordsize) throws IOException { public EcoFS(final File tablefile, final int recordsize) throws IOException {

@ -635,6 +635,7 @@ public final class plasmaSwitchboard extends serverAbstractSwitch<IndexingStack.
//plasmaSnippetCache.result scr = snippetCache.retrieve(new URL("http://www.heise.de/kiosk/archiv/ct/2003/4/20"), query, true, 260); //plasmaSnippetCache.result scr = snippetCache.retrieve(new URL("http://www.heise.de/kiosk/archiv/ct/2003/4/20"), query, true, 260);
this.dbImportManager = new ImporterManager(); this.dbImportManager = new ImporterManager();
this.trail = new ArrayList<String>();
log.logConfig("Finished Switchboard Initialization"); log.logConfig("Finished Switchboard Initialization");
} }

Loading…
Cancel
Save