0
|
1 \chapter{分散フレームワーク Alice の評価} \label{chapter:chapter5}
|
11
|
2 この章では、Aliceを用いた実験方法等についてまとめ、第\ref{chapter:chapter4}章で行った効果の測定、先行研究であるFedarated Lindaとの性能比較を行い、評価を行なう。また、TreeVNCとAliceVNCの比較をコードの観点からも評価を行なう。
|
10
|
3 \section{TORQUE Resource Manager を用いた実験方法}
|
|
4 Aliceの性能を実験する際に、学科にある共用のブレードサーバーを用いた。TORQUE Resource Manager (\url{http://www.adaptivecomputing.com/products/torque.php})というジョブスケジューラーによって、他の利用者とのリソースが競合しないように管理されている。
|
11
|
5
|
|
6 \subsection {TORQUE Resource Manager}
|
|
7 TORQUE は、1台のマスターと複数台のスレーブで構成される。(図 \ref{fig:torque})
|
|
8 スレーブは、マスターへ現在の自身のリソースの利用状況を報告する。
|
|
9
|
|
10 \begin{figure}[htbp]
|
|
11 \begin{center}
|
|
12 \includegraphics[width=80mm]{./images/torque.pdf}
|
|
13 \end{center}
|
|
14 \caption{TORQUE の構成}
|
|
15 \label{fig:torque}
|
|
16 \end{figure}
|
|
17
|
|
18 ユーザーはマスターを用いてTORQUEを利用する。ジョブを記述したシェルスクリプトを用意し、スケジューラーに投入する。投入するタイミングで、利用したいマシン台数、CPUコア数を指定することができる。(ソースコード \ref {src:torque})
|
|
19
|
|
20 TORQUE は、ジョブに必要なマシンが揃い次第、受け取ったジョブを実行する。
|
|
21
|
|
22 \begin{table}[html]
|
|
23 \lstinputlisting[label=src:torque, caption=10台(1台あたり4コア)で走らせる例]{source/Torque.sh}
|
|
24 \end{table}
|
|
25
|
|
26 \section{並列環境における改善の測定}
|
|
27
|
|
28 \section{分散環境における改善の測定}
|
|
29 第\ref{chapter:chapter4}章 の分散環境における改善の効果をリングトポロジーによる実験によって測定を行なう。
|
|
30 また、先行研究であるFederated Lindaとの比較も行なう。
|
10
|
31
|
|
32 \subsection{実験概要}
|
11
|
33 リングのトポロジーを構成し、メッセージが 100 周する時間を計り、1周あたりの平均時間を求める実験である。(図 \ref{fig:topologyring})
|
|
34
|
|
35 \begin{figure}[htbp]
|
|
36 \begin{center}
|
|
37 \includegraphics[width=110mm]{images/topologyring.pdf}
|
|
38 \end{center}
|
|
39 \caption{100周にかかる時間を計測し、1周あたりの平均時間を求める}
|
|
40 \label{fig:topologyring}
|
|
41 \end{figure}
|
|
42
|
|
43 実験では、トポロジーの構築時間は実験に含めてはいない。
|
|
44
|
10
|
45 \subsection{実験環境}
|
11
|
46 ブレードサーバー(表 \ref{tb:blade})上の仮想マシン(表 \ref{tb:virtual})による仮想クラスタ環境を用いて実験を行った。
|
|
47
|
10
|
48 \begin{table}[htbp]
|
11
|
49 \caption{ブレードサーバーの詳細}
|
|
50 \label{tb:blade}
|
10
|
51 \begin{center}
|
|
52 \begin{tabular} {|l|l|}
|
11
|
53 \hline
|
10
|
54 {\bf マシン台数}&8台\\
|
|
55 \hline
|
|
56 {\bf CPU}&Intel(R) Xeon(R) X5650 @ 2.67GHz\\
|
|
57 \hline
|
|
58 {\bf 物理コア数}&12\\
|
|
59 \hline
|
|
60 {\bf 論理コア数}&24\\
|
|
61 \hline
|
|
62 {\bf CPU キャッシュ}&12MB\\
|
|
63 \hline
|
|
64 {\bf Memory}&132GB\\
|
|
65 \hline
|
|
66 \end{tabular}
|
|
67 \end{center}
|
|
68 \end{table}
|
|
69
|
|
70 \begin{table}[htbp]
|
|
71 \caption{仮想クラスタの詳細}
|
11
|
72 \label{tb:virtual}
|
10
|
73 \begin{center}
|
|
74 \begin{tabular} {|l|l|}
|
|
75 \hline
|
11
|
76 {\bf マシン台数}&48台\\
|
10
|
77 \hline
|
|
78 {\bf CPU}&Intel(R) Xeon(R) X5650 @ 2.67GHz\\
|
|
79 \hline
|
|
80 {\bf 物理コア数}&2\\
|
|
81 \hline
|
|
82 {\bf 仮想コア数}&4\\
|
|
83 \hline
|
|
84 {\bf CPU キャッシュ}&12MB\\
|
|
85 \hline
|
|
86 {\bf Memory}&8GB\\
|
|
87 \hline
|
|
88 \end{tabular}
|
|
89 \end{center}
|
|
90 \end{table}
|
|
91
|
11
|
92 \subsection{実験結果}
|
|
93 \subsubsection{改善効果とFederated Lindaとの比較}
|
|
94 データのサイズは4KBで実験を行った。
|
|
95 \begin{figure}[htbp]
|
|
96 \begin{center}
|
|
97 \includegraphics[width=140mm]{images/compare.pdf}
|
|
98 \end{center}
|
|
99 \caption{4096 bytes のデータを 100 周させたときの 1 周にかかる平均時間}
|
|
100 \label{fig:compare}
|
|
101 \end{figure}
|
|
102
|
|
103 改善によって24\% ほど実行速度を改善することができた。また、改善後とFederated Lindaの比較では45台の場合、0.8ms 程、Aliceが遅い。
|
|
104 \subsubsection{no-tcp-delay有無の比較}
|
|
105 TCPはデフォルトで、Nagleアルゴリズムを使用している。Nagleアルゴリズムは、小さいパケットを集めてまとめて送信することで、送信するパケット数を減らし効率性をあげるアルゴリズムである。このアルゴリズムにより、実験結果に影響があるか調査した。
|
10
|
106
|
11
|
107 \begin{figure}[htbp]
|
|
108 \begin{center}
|
|
109 \includegraphics[width=140mm]{images/compareTcpDelay.pdf}
|
|
110 \end{center}
|
|
111 \caption{TCP\_NODELAYの有無の比較}
|
|
112 \label{fig:TcpNoDelay}
|
|
113 \end{figure}
|
|
114
|
|
115 図\ref{fig:TcpNoDelay}からTCP\_NODELAYにおける影響はないことがわかる。
|
|
116
|
|
117 \subsection{考察}
|
|
118 今回の
|
|
119 \section{TreeVNCとのCodeの比較}
|
|
120
|