annotate src/main/java/jp/ac/u_ryukyu/ie/cr/bbs/network/bbs/NetworkJungleBulletinBoard.java @ 11:edc70340506d draft default tip

networkbenchmark jar log4j conflict
author suruga
date Wed, 19 Apr 2017 21:36:44 +0900
parents 2890ae6b1aef
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
8
tatsuki
parents: 4
diff changeset
1 package jp.ac.u_ryukyu.ie.cr.bbs.network.bbs;
2
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
2
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
3
9
2890ae6b1aef network browsing
tatsuki
parents: 8
diff changeset
4 import jp.ac.u_ryukyu.ie.cr.bbs.local.browsing.JungleBrowsingBulletinBoard;
2
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
5 import jp.ac.u_ryukyu.ie.cr.jungle.Jungle;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
6 import jp.ac.u_ryukyu.ie.cr.jungle.persistent.ChangeList;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
7 import jp.ac.u_ryukyu.ie.cr.jungle.persistent.ChangeListReader;
8
tatsuki
parents: 4
diff changeset
8 import jp.ac.u_ryukyu.ie.cr.jungle.transaction.editor.jungleTreeEditor.JungleTreeEditor;
tatsuki
parents: 4
diff changeset
9 import jp.ac.u_ryukyu.ie.cr.jungle.tree.JungleTree;
2
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
10 import jp.ac.u_ryukyu.ie.cr.jungle.util.Either;
8
tatsuki
parents: 4
diff changeset
11 import jp.ac.u_ryukyu.ie.cr.jungle.util.Error.Error;
2
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
12 import jp.ac.u_ryukyu.ie.cr.jungleNetwork.core.NetworkDefaultJungle;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
13 import jp.ac.u_ryukyu.ie.cr.jungleNetwork.persistent.AliceJournal;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
14 import jp.ac.u_ryukyu.ie.cr.jungleNetwork.persistent.NetworkJournal;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
15 import jp.ac.u_ryukyu.ie.cr.jungleNetwork.persistent.PersistentJournal;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
16 import jp.ac.u_ryukyu.ie.cr.jungleNetwork.transaction.JungleUpdater;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
17
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
18 import java.io.File;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
19 import java.io.IOException;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
20 import java.util.concurrent.atomic.AtomicInteger;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
21
9
2890ae6b1aef network browsing
tatsuki
parents: 8
diff changeset
22 public class NetworkJungleBulletinBoard extends JungleBrowsingBulletinBoard implements NetworkBulletinBoard {
2890ae6b1aef network browsing
tatsuki
parents: 8
diff changeset
23 private final Jungle jungle;
2
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
24 private final NetworkJournal journal;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
25 private final String LOG_DIR;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
26 private Boolean persistentFlag;
9
2890ae6b1aef network browsing
tatsuki
parents: 8
diff changeset
27 private AtomicInteger requestCounter; //使われてない?
2
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
28 private long renewTime;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
29
9
2890ae6b1aef network browsing
tatsuki
parents: 8
diff changeset
30 private NetworkJungleBulletinBoard(String _uuid, NetworkJournal journal) {
2890ae6b1aef network browsing
tatsuki
parents: 8
diff changeset
31 this(new NetworkDefaultJungle(journal, _uuid), journal);
2890ae6b1aef network browsing
tatsuki
parents: 8
diff changeset
32 }
2890ae6b1aef network browsing
tatsuki
parents: 8
diff changeset
33
2890ae6b1aef network browsing
tatsuki
parents: 8
diff changeset
34 private NetworkJungleBulletinBoard(Jungle jungle, NetworkJournal journal) {
2890ae6b1aef network browsing
tatsuki
parents: 8
diff changeset
35 super(jungle);
2890ae6b1aef network browsing
tatsuki
parents: 8
diff changeset
36 this.jungle = jungle;
2890ae6b1aef network browsing
tatsuki
parents: 8
diff changeset
37 this.journal = journal;
2
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
38 BulletinBoardJungleManager.setJungle(jungle);
9
2890ae6b1aef network browsing
tatsuki
parents: 8
diff changeset
39 this.persistentFlag = false;
2890ae6b1aef network browsing
tatsuki
parents: 8
diff changeset
40 this.requestCounter = BulletinBoardJungleManager.getRequestCounter();
2890ae6b1aef network browsing
tatsuki
parents: 8
diff changeset
41 this.LOG_DIR = "./log";
2890ae6b1aef network browsing
tatsuki
parents: 8
diff changeset
42 this.renewTime = 0;
2
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
43 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
44
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
45 public NetworkJungleBulletinBoard(String _uuid) {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
46 this(_uuid, new AliceJournal());
9
2890ae6b1aef network browsing
tatsuki
parents: 8
diff changeset
47 this.jungle.createNewTree("boards");
2
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
48 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
49
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
50 public static NetworkBulletinBoard NewPersistentJungle(String _uuid) {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
51 NetworkJungleBulletinBoard board = new NetworkJungleBulletinBoard(_uuid, new PersistentJournal());
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
52 board.persistentFlag = true;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
53 return board;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
54 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
55
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
56 public void init() {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
57 if (!persistentFlag) {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
58 return;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
59 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
60 checkAndCreateLogDirectory();
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
61 try {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
62 commitLogRecover();
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
63 } catch (IOException e) {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
64 e.printStackTrace();
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
65 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
66 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
67
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
68 public void checkAndCreateLogDirectory() {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
69 File logFile = new File(LOG_DIR);
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
70 if (!logFile.exists()) {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
71 logFile.mkdir();
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
72 return;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
73 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
74 if (logFile.isFile()) {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
75 logFile.delete();
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
76 logFile.mkdir();
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
77 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
78 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
79
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
80 public void commitLogRecover() throws IOException {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
81 File[] logFiles = new File(LOG_DIR).listFiles();
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
82 for (File logFile : logFiles) {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
83 commitLogRecover(logFile);
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
84 logFile.delete();
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
85 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
86 if (jungle.getTreeByName("boards") == null) {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
87 jungle.createNewTree("boards");
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
88 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
89 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
90
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
91 private void commitLogRecover(File logFile) throws IOException {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
92 journal.setInputFile(logFile);
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
93 ChangeListReader reader = journal.getReader();
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
94 if (reader == null)
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
95 return;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
96 for (ChangeList chList : reader) {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
97 String treeName = chList.getTreeName();
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
98 JungleTree tree = jungle.getTreeByName(treeName);
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
99 if (tree == null) {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
100 tree = jungle.createNewTree(treeName);
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
101 }
8
tatsuki
parents: 4
diff changeset
102 JungleTreeEditor editor = tree.getLocalJungleTreeEditor();
2
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
103 Either<Error, JungleTreeEditor> either = JungleUpdater.edit(editor, chList);
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
104 editor = either.b();
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
105 if (either.isA()) {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
106 throw new IOException("Failed commit log recovery");
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
107 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
108 editor.success();
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
109 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
110 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
111
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
112 public long getRenewTime(String _boardName) {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
113 return renewTime;
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
114 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
115
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
116 public int getRequestNum() {
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
117 return requestCounter.get();
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
118 }
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
119
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
120
3c188a5b69ef add network bbs
tatsuki
parents:
diff changeset
121 }