mirror of
https://github.com/guilhermewerner/tcc
synced 2025-06-15 06:25:04 +00:00
Initial tests and analysis
This commit is contained in:
4
scripts/test.sh
Normal file
4
scripts/test.sh
Normal file
@ -0,0 +1,4 @@
|
||||
#!/usr/bin/env bash
|
||||
|
||||
sudo tshark -a duration:60 -f "port 25565" -w ./trace/java-60s.pcap
|
||||
sudo tshark -a duration:60 -f "port 19132" -w ./trace/bedrock-60s.pcap
|
0
servers/java/run.sh
vendored
Normal file → Executable file
0
servers/java/run.sh
vendored
Normal file → Executable file
137
src/graphs.py
Normal file
137
src/graphs.py
Normal file
@ -0,0 +1,137 @@
|
||||
# Copyright (c) 2024 Guilherme Werner
|
||||
# SPDX-License-Identifier: MIT
|
||||
|
||||
import pyshark
|
||||
import pandas as pd
|
||||
import matplotlib.pyplot as plt
|
||||
|
||||
max_packets = 10000
|
||||
trace_files = ["bedrock-60s", "java-60s"]
|
||||
|
||||
metrics_dict = {
|
||||
"test_name": [],
|
||||
"total_packets": [],
|
||||
"average_packet_size_kb": [],
|
||||
"total_acks": [],
|
||||
"total_syns": [],
|
||||
"average_latency_ms": []
|
||||
}
|
||||
|
||||
for trace_file in trace_files:
|
||||
capture = pyshark.FileCapture(f"./trace/{trace_file}.pcap", keep_packets=False)
|
||||
|
||||
data = []
|
||||
packet_count = 0
|
||||
|
||||
for packet in capture:
|
||||
if "IP" in packet:
|
||||
try:
|
||||
timestamp = float(packet.sniff_timestamp)
|
||||
# Tamanho do pacote em bytes
|
||||
packet_size = int(packet.length)
|
||||
|
||||
if "TCP" in packet:
|
||||
ack_flag = int(packet.tcp.flags_ack) if hasattr(packet.tcp, "flags_ack") else 0
|
||||
syn_flag = int(packet.tcp.flags_syn) if hasattr(packet.tcp, "flags_syn") else 0
|
||||
else:
|
||||
ack_flag = 0
|
||||
syn_flag = 0
|
||||
|
||||
data.append({
|
||||
"timestamp": timestamp,
|
||||
"packet_size": packet_size,
|
||||
"ack_flag": ack_flag,
|
||||
"syn_flag": syn_flag
|
||||
})
|
||||
|
||||
packet_count += 1
|
||||
|
||||
if packet_count >= max_packets:
|
||||
break
|
||||
except AttributeError:
|
||||
continue
|
||||
|
||||
df = pd.DataFrame(data)
|
||||
|
||||
# Calcular a latência em segundos e converter para milissegundos
|
||||
df["latency"] = df["timestamp"].diff() * 1000
|
||||
|
||||
total_packets = len(df)
|
||||
average_packet_size = df["packet_size"].mean()
|
||||
total_acks = df["ack_flag"].sum()
|
||||
total_syns = df["syn_flag"].sum()
|
||||
average_latency = df["latency"].mean()
|
||||
|
||||
metrics_dict["test_name"].append(trace_file)
|
||||
metrics_dict["total_packets"].append(total_packets)
|
||||
metrics_dict["average_packet_size_kb"].append(average_packet_size)
|
||||
metrics_dict["total_acks"].append(total_acks)
|
||||
metrics_dict["total_syns"].append(total_syns)
|
||||
metrics_dict["average_latency_ms"].append(round(average_latency, 2))
|
||||
|
||||
metrics_df = pd.DataFrame([{
|
||||
"total_packets": total_packets,
|
||||
"average_packet_size_kb": average_packet_size,
|
||||
"total_acks": total_acks,
|
||||
"total_syns": total_syns,
|
||||
"average_latency_ms": round(average_latency, 2)
|
||||
}])
|
||||
|
||||
metrics_df.to_csv(f"./trace/{trace_file}.csv", index=False)
|
||||
|
||||
metrics_df_all = pd.DataFrame(metrics_dict)
|
||||
|
||||
test_labels = {"java-60s": "Java (60s)", "bedrock-60s": "Bedrock (60s)"}
|
||||
|
||||
# Gráfico do total de pacotes
|
||||
plt.figure(figsize=(12, 6))
|
||||
metrics_df_all.plot(kind="bar", x="test_name", y="total_packets", legend=False)
|
||||
plt.title("Total de Pacotes por Teste")
|
||||
plt.xlabel("Teste")
|
||||
plt.ylabel("Total de Pacotes")
|
||||
plt.xticks(ticks=range(len(test_labels)), labels=[test_labels[file] for file in trace_files], rotation=45)
|
||||
plt.tight_layout()
|
||||
plt.savefig("./trace/total_packets_comparison.png")
|
||||
plt.close()
|
||||
|
||||
# Gráfico do tamanho médio dos pacotes
|
||||
plt.figure(figsize=(12, 6))
|
||||
metrics_df_all.plot(kind="bar", x="test_name", y="average_packet_size_kb", legend=False)
|
||||
plt.title("Tamanho Médio dos Pacotes por Teste")
|
||||
plt.xlabel("Teste")
|
||||
plt.ylabel("Tamanho Médio dos Pacotes (kB)")
|
||||
plt.xticks(ticks=range(len(test_labels)), labels=[test_labels[file] for file in trace_files], rotation=45)
|
||||
plt.tight_layout()
|
||||
plt.savefig("./trace/average_packet_size_comparison.png")
|
||||
plt.close()
|
||||
|
||||
# Gráfico da latência média
|
||||
plt.figure(figsize=(12, 6))
|
||||
metrics_df_all.plot(kind="bar", x="test_name", y="average_latency_ms", legend=False)
|
||||
plt.title("Latência Média por Teste")
|
||||
plt.xlabel("Teste")
|
||||
plt.ylabel("Latência Média (ms)")
|
||||
plt.xticks(ticks=range(len(test_labels)), labels=[test_labels[file] for file in trace_files], rotation=45)
|
||||
plt.tight_layout()
|
||||
plt.savefig("./trace/average_latency_comparison.png")
|
||||
plt.close()
|
||||
|
||||
# Gráfico de Pizza para TCP - Dados vs Controle
|
||||
# Filtrar apenas pacotes TCP
|
||||
tcp_df = df[df["ack_flag"] > 0]
|
||||
|
||||
# Calcular os pacotes de dados (não são ACKs)
|
||||
data_packets = len(df) - tcp_df.shape[0]
|
||||
control_packets = tcp_df.shape[0] # Inclui ACKs, SYNs, etc.
|
||||
|
||||
# Proporções
|
||||
sizes = [data_packets, control_packets]
|
||||
labels = ['Dados', 'Controle']
|
||||
|
||||
plt.figure(figsize=(8, 8))
|
||||
plt.pie(sizes, labels=labels, autopct='%1.1f%%', startangle=140, colors=['#ff9999','#66b3ff'])
|
||||
plt.title('Distribuição dos Pacotes TCP: Dados vs Controle')
|
||||
plt.savefig("./trace/tcp_packet_distribution.png")
|
||||
plt.close()
|
||||
|
||||
print("Métricas e gráficos comparativos salvos.")
|
BIN
trace/average_latency_comparison.png
Normal file
BIN
trace/average_latency_comparison.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 20 KiB |
BIN
trace/average_packet_size_comparison.png
Normal file
BIN
trace/average_packet_size_comparison.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 24 KiB |
2
trace/bedrock-60s.csv
Normal file
2
trace/bedrock-60s.csv
Normal file
@ -0,0 +1,2 @@
|
||||
total_packets,average_packet_size_kb,total_acks,total_syns,average_latency_ms
|
||||
10000,1101.6974,0,0,0.99
|
|
2
trace/java-60s.csv
Normal file
2
trace/java-60s.csv
Normal file
@ -0,0 +1,2 @@
|
||||
total_packets,average_packet_size_kb,total_acks,total_syns,average_latency_ms
|
||||
10000,707.9825,9800,400,0.1
|
|
BIN
trace/tcp_packet_distribution.png
Normal file
BIN
trace/tcp_packet_distribution.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 29 KiB |
BIN
trace/total_packets_comparison.png
Normal file
BIN
trace/total_packets_comparison.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 22 KiB |
Reference in New Issue
Block a user