aboutsummaryrefslogtreecommitdiff
path: root/doc/class-assignment/realisierung/verifysetup.tex
blob: 42d5c9110671b08185ce56b7c7afd1089282199a (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
\subsection{verifysetup}
Nachdem fsverify vollständig implementiert war und alle Speicherkonzepte vollständig entwickelt sind, braucht fsverify auch ein Programm, um alles richtig aufzusetzen.\\
Das Programm muss eine Datenbank von Nodes anhand der zu verifizierenden Partition erstellen, den Header entsprechend konfigurieren und alles auf eine Datei schreiben, die der Nutzer (oder eher Distributions-Entwickler) auf die für fsverify vorgesehene Partition schreiben kann.

\subsubsection{Optimierung}
Genauso wie fsverify benutzt verifysetup erstmal nur einen Thread, um die Datenbank zu erstellen. Dies führte zu einer Laufzeit von über 2 Stunden für 1 GB.\\
Die Schritte zur Optimierung sind die gleichen wie bei fsverify. Jedoch verbesserte sich die Laufzeit um einiges, bereits bei dem Wechsel zu 2 KB Blocks und sha1 hashing, von 2 Stunden zu einer Stunde.\\
Mit dem Wechsel zu Multithreading ging dies dann runter zu 19 Sekunden mit 12 Threads.
\\
Die Laufzeit von verifysetup verbesserte sich um 33846\% in einer Woche.
\begin{verbatim}
10.02.2024:
fsverify setup takes 110minutes to complete for 1gb
optimizations: none
\end{verbatim}
\begin{verbatim}
12.02.2024:
fsverify setup takes 71minutes to complete for 1gb
optimizations: block size 2k, sha1 instead of sha256
\end{verbatim}
\begin{verbatim}
12.02.2024:
fsverify setup takes ~9.54 seconds to complete for 1gb with 12 threads
optimizations: block size 2k, sha1 instead of sha256,
               multithreaded, db batch operations
\end{verbatim}
\begin{verbatim}
17.02.2024:
fsverify setup takes ~19.50 seconds to complete for 1gb with 12 threads
optimizations: block size 2k, sha1 instead of sha256,
               multithreaded, db batch operations
unoptimizations: enable database signing, header generation,
                 fsverify partition generation
\end{verbatim}
%%% Local Variables:
%%% mode: LaTeX
%%% TeX-master: "../fsverify"
%%% End: