From b6ebcd744d4f1675019e3cc7a344429e6f73e0e8 Mon Sep 17 00:00:00 2001 From: hkhang Date: Fri, 13 Nov 2009 20:38:25 +0000 Subject: [PATCH] *** empty log message *** --- .../Benchmarks/Recovery/Spider/QueryTask.java | 10 +- .../Benchmarks/Recovery/Spider/Spider.java | 9 +- .../src/Benchmarks/Recovery/Spider/dstm.conf | 12 +- .../JavaDSM/DistributedLinkedList.java | 226 ++++++++++++++++++ 4 files changed, 245 insertions(+), 12 deletions(-) create mode 100644 Robust/src/ClassLibrary/JavaDSM/DistributedLinkedList.java diff --git a/Robust/src/Benchmarks/Recovery/Spider/QueryTask.java b/Robust/src/Benchmarks/Recovery/Spider/QueryTask.java index 0904d626..2cb1145c 100644 --- a/Robust/src/Benchmarks/Recovery/Spider/QueryTask.java +++ b/Robust/src/Benchmarks/Recovery/Spider/QueryTask.java @@ -1,15 +1,17 @@ public class QueryTask extends Task { int maxDepth; + int maxSearchDepth; Queue toprocess; DistributedHashMap results; DistributedHashMap visitedList; GlobalString gTitle; GlobalString workingURL; - public QueryTask(Queue todoList, DistributedHashMap visitedList, int maxDepth, DistributedHashMap results) { + public QueryTask(Queue todoList, DistributedHashMap visitedList, int maxDepth, int maxSearchDepth, DistributedHashMap results) { this.todoList = todoList; this.visitedList = visitedList; this.maxDepth = maxDepth; + this.maxSearchDepth = maxSearchDepth; this.results = results; toprocess = global new Queue(); } @@ -17,10 +19,12 @@ public class QueryTask extends Task { public void execute() { int depth; int max; + int maxSearch; atomic { depth = ((GlobalQuery)myWork).getDepth(); max = this.maxDepth; + maxSearch = this.maxSearchDepth; } if (depth < max) { @@ -103,6 +107,7 @@ public class QueryTask extends Task { processList(); } + int searchCnt = 0; while(!toprocess.isEmpty()) { GlobalQuery q = (GlobalQuery)toprocess.pop(); @@ -113,11 +118,12 @@ public class QueryTask extends Task { gsb.append("/"); gsb.append(path); - if (!visitedList.containsKey(gsb.toGlobalString())) { + if (!visitedList.containsKey(gsb.toGlobalString()) && (searchCnt < maxSearchDepth)) { todoList.push(q); GlobalString str = global new GlobalString("1"); visitedList.put(gsb.toGlobalString(), str); + searchCnt++; } } } diff --git a/Robust/src/Benchmarks/Recovery/Spider/Spider.java b/Robust/src/Benchmarks/Recovery/Spider/Spider.java index e14e8a99..27a7827f 100644 --- a/Robust/src/Benchmarks/Recovery/Spider/Spider.java +++ b/Robust/src/Benchmarks/Recovery/Spider/Spider.java @@ -2,6 +2,7 @@ public class Spider { public static void main(String[] args) { int NUM_THREADS = 3; int maxDepth = 4; + int maxSearchDepth = 10; int i, j; Work[] works; QueryTask[] qt; @@ -13,9 +14,9 @@ public class Spider { GlobalString firstpage; int mid[] = new int[NUM_THREADS]; - mid[0] = (128<<24)|(195<<16)|(136<<8)|162; - mid[1] = (128<<24)|(195<<16)|(136<<8)|163; - mid[2] = (128<<24)|(195<<16)|(136<<8)|164; + mid[0] = (128<<24)|(195<<16)|(180<<8)|21; + mid[1] = (128<<24)|(195<<16)|(180<<8)|24; + mid[2] = (128<<24)|(195<<16)|(180<<8)|26; atomic { firstmachine = global new GlobalString(args[1]); @@ -38,7 +39,7 @@ public class Spider { todoList.push(firstquery); for (i = 0; i < NUM_THREADS; i++) { - qt[i] = global new QueryTask(todoList, visitedList, maxDepth, results); + qt[i] = global new QueryTask(todoList, visitedList, maxDepth, maxSearchDepth, results); works[i] = global new Work(qt[i], NUM_THREADS, i, currentWorkList); } } diff --git a/Robust/src/Benchmarks/Recovery/Spider/dstm.conf b/Robust/src/Benchmarks/Recovery/Spider/dstm.conf index eff447b8..da5d354d 100644 --- a/Robust/src/Benchmarks/Recovery/Spider/dstm.conf +++ b/Robust/src/Benchmarks/Recovery/Spider/dstm.conf @@ -1,6 +1,6 @@ -#128.195.180.21 -#128.195.180.24 -#128.195.180.26 -128.195.136.162 -128.195.136.163 -128.195.136.164 +128.195.180.21 +128.195.180.24 +128.195.180.26 +#128.195.136.162 +#128.195.136.163 +#128.195.136.164 diff --git a/Robust/src/ClassLibrary/JavaDSM/DistributedLinkedList.java b/Robust/src/ClassLibrary/JavaDSM/DistributedLinkedList.java new file mode 100644 index 00000000..c902a546 --- /dev/null +++ b/Robust/src/ClassLibrary/JavaDSM/DistributedLinkedList.java @@ -0,0 +1,226 @@ +public class DistributedLinkedListElement { + public DistributedLinkedListElement next; + public DistributedLinkedListElement prev; + public Object element; + + public DistributedLinkedListElement(Object e, + DistributedLinkedListElement n, + DistributedLinkedListElement p) { + element = e; + next = n; + prev = p; + } +} + +public class DistributedLinkedList { + DistributedLinkedListElement head; + DistributedLinkedListElement tail; + int size; + + public DistributedLinkedList() { + clear(); + } + + public add(Object o) { + if( tail == null ) { + head = global new DistributedLinkedListElement(o, null, null); + tail = head; + + } else { + tail.next = global new DistributedLinkedListElement(o, null, tail); + tail = tail.next; + } + size++; + } + + public addFirst(Object o) { + if( head == null ) { + head = global new DistributedLinkedListElement(o, null, null); + tail = head; + + } else { + head.prev = global new DistributedLinkedListElement(o, head, null); + head = head.prev; + } + size++; + } + + public addLast(Object o) { + add(o); + } + + public clear() { + head = null; + tail = null; + size = 0; + } + + public int size() { + return size; + } + + public boolean isEmpty() { + return size == 0; + } + + public Object clone() { + System.out.println("LinkedList.clone() not implemented."); + System.exit(-1); + } + + public boolean contains(Object o) { + DistributedLinkedListElement e = head; + if (o==null) { + while(e!=null) { + if (e.element==null) { + return true; + } + e=e.next; + } + return false; + } else { + while( e != null ) { + if (o.equals(e.element)) { + return true; + } + e = e.next; + } + } + return false; + } + + public Object getFirst() { + if( head == null ) { + return null; + } + return head.element; + } + + public Object getLast() { + if( tail == null ) { + return null; + } + return tail.element; + } + + public Object element() { + getFirst(); + } + + public Object peek() { + getFirst(); + } + + public Object peekFirst() { + getFirst(); + } + + public Object peekLast() { + getLast(); + } + + public Object removeFirst() { + if( head == null ) { + System.out.println("LinkedList: illegal removeFirst()"); + System.exit(-1); + } + Object o = head.element; + head = head.next; + if( head != null ) { + head.prev = null; + } else { + tail = null; + } + size--; + return o; + } + + public Object removeLast() { + if( tail == null ) { + System.out.println("LinkedList: illegal removeLast()"); + System.exit(-1); + } + Object o = tail.element; + tail = tail.prev; + if( tail != null ) { + tail.next = null; + } else { + head = null; + } + size--; + return o; + } + + public void remove(Object o) { + if( head == null ) { + System.out.println("LinkedList: illegal remove( Object o )"); + System.exit(-1); + } + DistributedLinkedListElement e = head; + while( e != null ) { + if( e.element == o ) { + if( e.prev != null ) { + e.prev.next = e.next; + } + if( e.next != null ) { + e.next.prev = e.prev; + } + size--; + return; + } + e = e.next; + } + System.out.println("LinkedList: illegal remove( Object o ), "+o+" not found"); + System.exit(-1); + } + + public Object pop() { + Object o = getFirst(); + removeFirst(); + return o; + } + + public void push(Object o) { + addFirst(o); + } + + public Iterator iterator() { + return global new DistributedLinkedListIterator(this); + } +} + +public class DistributedLinkedListIterator extends Iterator { + DistributedLinkedList ll; + DistributedLinkedListElement itr; + Object removeable; + + public DistributedLinkedListIterator(DistributedLinkedList ll) { + this.ll = ll; + itr = ll.head; + removeable = null; + } + + public boolean hasNext() { + return (null != itr); + } + + public Object next() { + if( itr == null ) { + System.out.println("LinkedListIterator: illegal next()"); + System.exit(-1); + } + removeable = itr.element; + itr = itr.next; + return removeable; + } + + public void remove() { + if( removeable == null ) { + System.out.println("LinkedListIterator: illegal remove()"); + System.exit(-1); + } + ll.remove(removeable); + removeable = null; + } +} + -- 2.34.1