bachelor-thesis/chapters/thesis/chapter03.tex

162 lines
6.7 KiB
TeX
Raw Normal View History

\chapter{Konzept}
\label{ch:concept}
\section{Aufbau der Umfrage}
2024-03-26 22:18:55 +01:00
\label{sec:concept:poll}
2024-03-21 21:05:04 +01:00
2024-03-29 11:36:34 +01:00
Die Umfrage wird über Email an die XX Personen verschickt. Als Basis für die Umfrage wird der aktuelle Prototyp
unter \href{https://briefedition.wedekind.h-da.de} verwendet. Hierbei wird die gleiche Umfrage für Bearbeiter
und Benutzer versendet.
Die erste Frage ist zur Unterscheidung ob die Antworten von einen Bearbeiter oder von einem Benutzer kommt. Dies ist
nur notwendig, um bei der Nachstellung zu unterscheiden welche Zugriffsrechte aktiv sind.
Die weiteren Fragen sind aufeinander aufgebaut. Hierbei wird zuerst überprüft, bei welchen Aktionen eine längere
Wartezeit auftritt. Zusätzlich soll noch dazu angegeben werden, wie häufig dies auftritt, also ob dies regelmässig
auftritt oder immer nur zu bestimmten Zeitpunkten. Des Weiteren wird die Information nachgefragt, ob die Probleme
immer bei der gleichen Abfolge von Aktionen auftritt.
Die Anfrage wird im Anhang \ref{ch:Umfrage} dargestellt.
\section{Allgemeine Betrachtung des Systems}
2024-03-26 22:18:55 +01:00
\label{sec:concept:viewsystem}
% Untersuchung des Servers
2024-03-27 19:23:22 +01:00
Für die Untersuchung des Systems wird der direkte Zugang zum Server benötigt. Hierbei werden zuerst die im Kapitel
\ref{sec:basics:services} beschriebenen Einstellungen überprüft.
2024-03-31 22:25:29 +02:00
Zuerst wird am PostgreSQL"=Server die Konfiguration der Speicher mit der Vorgabe für Produktivsystem abgeglichen.
2024-03-27 19:23:22 +01:00
Hierunter fallen die Einstellungen für die \textit{shared\_buffers}, der bei einem Arbeitsspeicher von mehr als 1 GB
ca. 25\% des Arbeitsspeicher definiert sein soll \cite{PostgresC20.4:2024}.
\mytodos{die anderen Speicher abarbeiten?}
2024-03-29 11:36:34 +01:00
Dann wird mit dem Systemtools, wie den Konsolenanwendungen \textit{htop} und \textit{free}, die Auslastung des Servers
2024-03-27 19:23:22 +01:00
überprüft. Hierbei ist die CPU-Leistung, der aktuell genutzte Arbeitsspeicher, sowie die Zugriffe auf die Festplatte
2024-03-29 11:36:34 +01:00
die wichtigen Faktoren zur Bewertung.
2024-03-27 19:23:22 +01:00
Die CPU-Leistung sollte im Schnitt nicht die 70\% überschreiten, für kurze Spitzen wäre dies zulässig. Da sonst der
Server an seiner Leistungsgrenze arbeitet und dadurch es nicht mehr schafft die gestellten Anfragen schnell genug
abzuarbeiten.
Da unter Linux der Arbeitsspeicher nicht mehr direkt freigegeben wird, ist hier die Page-Datei der wichtigere Indikator.
Wenn dieses in Verwendung ist, dann benötigt die aktuell laufenden Programme mehr Arbeitsspeicher als vorhanden, wodurch
der aktuell nicht verwendete in die Page-Datei ausgelagert wird. Hierdurch erhöhen sich die Zugriffszeiten auf diese
Elemente drastisch.
Die Zugriffsgeschwindigkeit, die Zugriffszeit sowie die Warteschlange an der Festplatte zeigt deren Belastungsgrenze auf.
Hierbei kann es mehrere Faktoren geben. Zum einem führt das Paging des Arbeitsspeicher zu erhöhten Zugriffen. Ein zu
klein gewählter Cache oder gar zu wenig Arbeitsspeicher erhöhen die Zugriffe auf die Festplatte, da weniger
zwischengespeichert werden kann und daher diese Daten immer wieder direkt von der Festplatte geladen werden müssen.
2024-03-31 22:25:29 +02:00
\mytodos{Bespreibung der untersuchung von Glassfisch? oder lieber später}
\section{Das Vorgehen der Optimierung}
2024-03-26 22:18:55 +01:00
\label{sec:concept:optimizing}
2024-03-31 22:25:29 +02:00
\mytodos{Beschreibung der Untersuchung von Glassfisch? oder lieber später, oder doch eher umbennen in Ermittlung der Performance-Probleme}
2024-03-27 19:23:22 +01:00
2024-03-26 22:18:55 +01:00
% Anhand der Umfragen werden die verschiedenen Seiten ermittelt und mit den Tools überprüft
% Während dessen kann über ein Script die Seite automatisiert abgefragt und das Trace aktiv sind
% je nach erkentnis mss dann der Lösungsweg beschritten werden
% Beachten des Speicherverbrauchs!
\section{Aktueller Aufbau der Software}
2024-03-26 22:18:55 +01:00
\label{sec:concept:softwarestructure}
% Hier vielleicht nochmal ein Verweis auf die Grundlagen, oder direkt auf die MVC-Technik
\section{Vergleich mit anderen Technologien}
2024-03-26 22:18:55 +01:00
\label{sec:concept:technologiecompare}
% Vergleich mit AspNetCore und vielleicht VueJS oder Konsorten, wobei hier der Serverteil fehlt
2024-03-31 22:25:29 +02:00
Damit eine Umsetzung mit einer anderen Technologie umgesetzt werden kann, muss dies den kompletten Aufbau unterstützen,
wie dies die \ac{JSP} unterstützen. Daher fallen reine FrontEnd"=Bibliotheken wie VueJS oder React aus der Betrachtung
heraus.
\subsection{ASP.NET Core}
\label{sec:concept:technologiecompare:aspnetcore}
\mytodos{Anpassen auf "Kernpunkte"?}
\noindent
Vorteile:
\begin{itemize}
\item Gute Entwicklungsumgebung
\item EntityFramework als \ac{ORM}
\item Große Auswahl an Erweiterungen durch NuGet-Pakete
\item Betriebssystem unabhängig
\end{itemize}
\noindent
Nachteile:
\begin{itemize}
\item
\end{itemize}
Beim Vergleich zu \ac{JSP} steht ASP.NET Core nicht hinten an. Im großen und ganzen ist der Funktionsumfang der gleiche
und mit EntityFramework gibt es ebenfalls einen sehr mächtigen \ac{ORM}. Hier sehe ich nur ebenfalls ein ähnliches
Problem beim Caching wie bei OpenJPA, dass diese zu Problemen führen kann, wenn der Speicher voll wird.
% Ersatz für EF?
C\# wird ebenfalls wie Java in einen Zwischencode übersetzt und erst bei der Ausführung auf die Zielplattform übersetzt.
Hierbei haben die meistens Test gezeigt, dass das .NET Framework hier um einiges Effizienter und schneller arbeitet als
die Java Runtime. Zusätzlich wird bei ASP.NET Core nicht noch ein zusätzlicher Server benötigt um die Anwendung aktiv
zu halten.
\subsection{Golang}
\label{sec:concept:technologiecompare:go}
\noindent
Vorteile:
\begin{itemize}
\item schnelle und einfache Entwicklung
\item Native Übersetzung der Anwendung (hohe Performance)
\item Betriebssystem unabhängig
\item Gut geeignet für Microservices
\end{itemize}
\noindent
Nachteile:
\begin{itemize}
\item Neue Programmiersprache, noch wenige Programmierer
\end{itemize}
Schnelle und einfache Entwicklung durch das grundsätzliche Konzept der neuen Sprache
Ist wiederrum aber der nachteil dass es noch nicht viele können.
Ist aber wiederrum sehr schnell und effizient und für Microservices gedacht.
Reiner \ac{ORM} vorhanden, ohne weitere Caching und halten von Daten.
\subsection{PHP}
\label{sec:concept:technologiecmopare:php}
\noindent
Vorteile:
\begin{itemize}
\item Text-Editor reicht
\end{itemize}
\noindent
Nachteile:
\begin{itemize}
\item Script-Sprache
\end{itemize}
\subsection{Fazit}
\label{sec:concept:technologiecompare:summary}
\mytodos{Noch entscheiden, ob der Compare direkt bei der Technologie gemacht \\ wird, oder allgemein am ende}
PHP fällt aufgrund der Script-Sprache raus, da dies nicht verteilbar ist und an den Uni keine Entwickler zu finden sind.
Bei Go sind es ebenfalls hauptsächlich die nicht vorhandenen Entwickler an der Uni
ASP.NET Core ist im Vergleich zu JSP identisch, aber auch hier werden aktuell die Entwickler fehlen, da Java in den
Vorlesungen dran genommen wird.