Улучшение производительности

This commit is contained in:
serega6531
2020-03-13 00:40:52 +03:00
parent a112d55496
commit 8d327608ba
9 changed files with 23 additions and 69 deletions

View File

@@ -136,8 +136,10 @@ public class PcapWorker implements PacketListener {
servicesService.findService(sourceIp, sourcePort, destIp, destPort); servicesService.findService(sourceIp, sourcePort, destIp, destPort);
if (serviceOptional.isPresent()) { if (serviceOptional.isPresent()) {
final long time = System.currentTimeMillis();
listenerExecutorService.execute(() -> { listenerExecutorService.execute(() -> {
UnfinishedStream stream = addNewPacket(sourceIp, destIp, sourcePort, destPort, ttl, content, Protocol.TCP); UnfinishedStream stream = addNewPacket(sourceIp, destIp, time, sourcePort, destPort, ttl, content, Protocol.TCP);
if (log.isDebugEnabled()) { if (log.isDebugEnabled()) {
log.debug("tcp {} {}:{} -> {}:{}, номер пакета {}", log.debug("tcp {} {}:{} -> {}:{}, номер пакета {}",
@@ -173,8 +175,10 @@ public class PcapWorker implements PacketListener {
servicesService.findService(sourceIp, sourcePort, destIp, destPort); servicesService.findService(sourceIp, sourcePort, destIp, destPort);
if (serviceOptional.isPresent()) { if (serviceOptional.isPresent()) {
final long time = System.currentTimeMillis();
listenerExecutorService.execute(() -> { listenerExecutorService.execute(() -> {
UnfinishedStream stream = addNewPacket(sourceIp, destIp, sourcePort, destPort, ttl, content, Protocol.UDP); UnfinishedStream stream = addNewPacket(sourceIp, destIp, time, sourcePort, destPort, ttl, content, Protocol.UDP);
if (log.isDebugEnabled()) { if (log.isDebugEnabled()) {
log.debug("udp {} {}:{} -> {}:{}, номер пакета {}", log.debug("udp {} {}:{} -> {}:{}, номер пакета {}",
@@ -189,7 +193,7 @@ public class PcapWorker implements PacketListener {
} }
} }
private UnfinishedStream addNewPacket(Inet4Address sourceIp, Inet4Address destIp, private UnfinishedStream addNewPacket(Inet4Address sourceIp, Inet4Address destIp, long time,
int sourcePort, int destPort, byte ttl, byte[] content, Protocol protocol) { int sourcePort, int destPort, byte ttl, byte[] content, Protocol protocol) {
var incoming = destIp.equals(localIp); var incoming = destIp.equals(localIp);
var stream = new UnfinishedStream(sourceIp, destIp, sourcePort, destPort, protocol); var stream = new UnfinishedStream(sourceIp, destIp, sourcePort, destPort, protocol);
@@ -197,7 +201,7 @@ public class PcapWorker implements PacketListener {
var packet = ru.serega6531.packmate.model.Packet.builder() var packet = ru.serega6531.packmate.model.Packet.builder()
.tempId(packetIdCounter++) .tempId(packetIdCounter++)
.ttl(ttl) .ttl(ttl)
.timestamp(System.currentTimeMillis()) .timestamp(time)
.incoming(incoming) .incoming(incoming)
.content(content) .content(content)
.build(); .build();

View File

@@ -7,7 +7,6 @@ import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController; import org.springframework.web.bind.annotation.RestController;
import ru.serega6531.packmate.model.Packet; import ru.serega6531.packmate.model.Packet;
import ru.serega6531.packmate.model.Stream; import ru.serega6531.packmate.model.Stream;
import ru.serega6531.packmate.service.PacketService;
import ru.serega6531.packmate.service.StreamService; import ru.serega6531.packmate.service.StreamService;
import java.util.Collections; import java.util.Collections;
@@ -19,19 +18,17 @@ import java.util.Optional;
public class PacketController { public class PacketController {
private final StreamService streamService; private final StreamService streamService;
private final PacketService packetService;
@Autowired @Autowired
public PacketController(StreamService streamService, PacketService packetService) { public PacketController(StreamService streamService) {
this.streamService = streamService; this.streamService = streamService;
this.packetService = packetService;
} }
@PostMapping("/{streamId}") @PostMapping("/{streamId}")
public List<Packet> getPacketsForStream(@PathVariable long streamId) { public List<Packet> getPacketsForStream(@PathVariable long streamId) {
final Optional<Stream> stream = streamService.find(streamId); final Optional<Stream> stream = streamService.find(streamId);
if (stream.isPresent()) { if (stream.isPresent()) {
return packetService.getPacketsForStream(stream.get()); return stream.get().getPackets();
} else { } else {
return Collections.emptyList(); return Collections.emptyList();
} }

View File

@@ -38,7 +38,7 @@ public class Pattern {
private PatternDirectionType directionType; private PatternDirectionType directionType;
@ManyToMany(mappedBy = "foundPatterns", cascade = CascadeType.ALL, fetch = FetchType.LAZY) @ManyToMany(mappedBy = "foundPatterns", fetch = FetchType.LAZY)
@JsonIgnore @JsonIgnore
private List<Stream> matchedStreams; private List<Stream> matchedStreams;

View File

@@ -33,8 +33,7 @@ public class Stream {
private Protocol protocol; private Protocol protocol;
@OneToMany(mappedBy = "stream", cascade = CascadeType.ALL, orphanRemoval = true) @OneToMany(mappedBy = "stream", cascade = CascadeType.ALL)
@OrderColumn
@JsonIgnore @JsonIgnore
private List<Packet> packets; private List<Packet> packets;
@@ -42,13 +41,14 @@ public class Stream {
private long endTimestamp; private long endTimestamp;
@ManyToMany(cascade = CascadeType.ALL, fetch = FetchType.EAGER) @ManyToMany(cascade = CascadeType.ALL)
private Set<Pattern> foundPatterns; private Set<Pattern> foundPatterns;
private boolean favorite; private boolean favorite;
private byte ttl; private byte ttl;
@Column(columnDefinition = "char(3)")
private String userAgentHash; private String userAgentHash;
} }

View File

@@ -1,13 +0,0 @@
package ru.serega6531.packmate.repository;
import org.springframework.data.jpa.repository.JpaRepository;
import ru.serega6531.packmate.model.Packet;
import ru.serega6531.packmate.model.Stream;
import java.util.List;
public interface PacketRepository extends JpaRepository<Packet, Long> {
List<Packet> findAllByStream(Stream stream);
}

View File

@@ -1,29 +0,0 @@
package ru.serega6531.packmate.service;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import ru.serega6531.packmate.model.Packet;
import ru.serega6531.packmate.model.Stream;
import ru.serega6531.packmate.repository.PacketRepository;
import java.util.List;
@Service
public class PacketService {
private final PacketRepository repository;
@Autowired
public PacketService(PacketRepository repository) {
this.repository = repository;
}
public List<Packet> getPacketsForStream(Stream stream) {
return repository.findAllByStream(stream);
}
public List<Packet> saveAll(List<Packet> packets) {
return repository.saveAll(packets);
}
}

View File

@@ -2,7 +2,6 @@ package ru.serega6531.packmate.service;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Lazy;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional; import org.springframework.transaction.annotation.Transactional;
import ru.serega6531.packmate.model.FoundPattern; import ru.serega6531.packmate.model.FoundPattern;
@@ -21,17 +20,14 @@ import java.util.stream.Collectors;
public class PatternService { public class PatternService {
private final PatternRepository repository; private final PatternRepository repository;
private final StreamService streamService;
private final StreamSubscriptionService subscriptionService; private final StreamSubscriptionService subscriptionService;
private final Map<Integer, Pattern> patterns = new HashMap<>(); private final Map<Integer, Pattern> patterns = new HashMap<>();
@Autowired @Autowired
public PatternService(PatternRepository repository, public PatternService(PatternRepository repository,
@Lazy StreamService streamService,
StreamSubscriptionService subscriptionService) { StreamSubscriptionService subscriptionService) {
this.repository = repository; this.repository = repository;
this.streamService = streamService;
this.subscriptionService = subscriptionService; this.subscriptionService = subscriptionService;
repository.findAll().forEach(p -> patterns.put(p.getId(), p)); repository.findAll().forEach(p -> patterns.put(p.getId(), p));
@@ -63,10 +59,11 @@ public class PatternService {
for (Stream stream : pattern.getMatchedStreams()) { for (Stream stream : pattern.getMatchedStreams()) {
stream.getFoundPatterns().remove(pattern); stream.getFoundPatterns().remove(pattern);
streamService.save(stream); stream.getPackets().forEach(p ->
p.getMatches().removeIf(m ->
m.getPatternId() == pattern.getId()));
} }
pattern.getMatchedStreams().clear();
patterns.remove(id); patterns.remove(id);
repository.delete(pattern); repository.delete(pattern);
subscriptionService.broadcast(new SubscriptionMessage(SubscriptionMessageType.DELETE_PATTERN, id)); subscriptionService.broadcast(new SubscriptionMessage(SubscriptionMessageType.DELETE_PATTERN, id));
@@ -76,7 +73,7 @@ public class PatternService {
public Pattern save(Pattern pattern) { public Pattern save(Pattern pattern) {
log.info("Добавлен новый паттерн {} со значением {}", pattern.getName(), pattern.getValue()); log.info("Добавлен новый паттерн {} со значением {}", pattern.getName(), pattern.getValue());
final Pattern saved = repository.save(pattern); final Pattern saved = repository.save(pattern);
patterns.put(saved.getId(), pattern); patterns.put(saved.getId(), saved);
subscriptionService.broadcast(new SubscriptionMessage(SubscriptionMessageType.SAVE_PATTERN, saved)); subscriptionService.broadcast(new SubscriptionMessage(SubscriptionMessageType.SAVE_PATTERN, saved));
return saved; return saved;
} }

View File

@@ -68,7 +68,7 @@ public class ServicesService {
public CtfService save(CtfService service) { public CtfService save(CtfService service) {
log.info("Добавлен или изменен сервис {} на порту {}", service.getName(), service.getPort()); log.info("Добавлен или изменен сервис {} на порту {}", service.getName(), service.getPort());
final CtfService saved = repository.save(service); final CtfService saved = repository.save(service);
services.put(saved.getPort(), service); services.put(saved.getPort(), saved);
subscriptionService.broadcast(new SubscriptionMessage(SubscriptionMessageType.SAVE_SERVICE, saved)); subscriptionService.broadcast(new SubscriptionMessage(SubscriptionMessageType.SAVE_SERVICE, saved));
return saved; return saved;
} }

View File

@@ -7,6 +7,7 @@ import org.springframework.data.domain.PageRequest;
import org.springframework.data.domain.Sort; import org.springframework.data.domain.Sort;
import org.springframework.data.jpa.domain.Specification; import org.springframework.data.jpa.domain.Specification;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Propagation;
import org.springframework.transaction.annotation.Transactional; import org.springframework.transaction.annotation.Transactional;
import ru.serega6531.packmate.model.*; import ru.serega6531.packmate.model.*;
import ru.serega6531.packmate.model.enums.SubscriptionMessageType; import ru.serega6531.packmate.model.enums.SubscriptionMessageType;
@@ -29,7 +30,6 @@ public class StreamService {
private final StreamRepository repository; private final StreamRepository repository;
private final PatternService patternService; private final PatternService patternService;
private final ServicesService servicesService; private final ServicesService servicesService;
private final PacketService packetService;
private final StreamSubscriptionService subscriptionService; private final StreamSubscriptionService subscriptionService;
private final boolean ignoreEmptyPackets; private final boolean ignoreEmptyPackets;
@@ -40,13 +40,11 @@ public class StreamService {
public StreamService(StreamRepository repository, public StreamService(StreamRepository repository,
PatternService patternService, PatternService patternService,
ServicesService servicesService, ServicesService servicesService,
PacketService packetService,
StreamSubscriptionService subscriptionService, StreamSubscriptionService subscriptionService,
@Value("${ignore-empty-packets}") boolean ignoreEmptyPackets) { @Value("${ignore-empty-packets}") boolean ignoreEmptyPackets) {
this.repository = repository; this.repository = repository;
this.patternService = patternService; this.patternService = patternService;
this.servicesService = servicesService; this.servicesService = servicesService;
this.packetService = packetService;
this.subscriptionService = subscriptionService; this.subscriptionService = subscriptionService;
this.ignoreEmptyPackets = ignoreEmptyPackets; this.ignoreEmptyPackets = ignoreEmptyPackets;
} }
@@ -54,7 +52,7 @@ public class StreamService {
/** /**
* @return был ли сохранен стрим * @return был ли сохранен стрим
*/ */
@Transactional @Transactional(propagation = Propagation.NEVER)
public boolean saveNewStream(UnfinishedStream unfinishedStream, List<Packet> packets) { public boolean saveNewStream(UnfinishedStream unfinishedStream, List<Packet> packets) {
final var serviceOptional = servicesService.findService( final var serviceOptional = servicesService.findService(
unfinishedStream.getFirstIp(), unfinishedStream.getFirstIp(),
@@ -83,7 +81,7 @@ public class StreamService {
.filter(Packet::isIncoming) .filter(Packet::isIncoming)
.findFirst(); .findFirst();
Stream stream = new Stream(); final Stream stream = new Stream();
stream.setProtocol(unfinishedStream.getProtocol()); stream.setProtocol(unfinishedStream.getProtocol());
stream.setTtl(firstIncoming.isPresent() ? firstIncoming.get().getTtl() : 0); stream.setTtl(firstIncoming.isPresent() ? firstIncoming.get().getTtl() : 0);
stream.setStartTimestamp(packets.get(0).getTimestamp()); stream.setStartTimestamp(packets.get(0).getTimestamp());
@@ -97,7 +95,7 @@ public class StreamService {
Set<Pattern> foundPatterns = getFoundPatterns(packets, savedStream); Set<Pattern> foundPatterns = getFoundPatterns(packets, savedStream);
savedStream.setFoundPatterns(foundPatterns); savedStream.setFoundPatterns(foundPatterns);
savedStream.setPackets(packetService.saveAll(packets)); savedStream.setPackets(packets);
savedStream = save(savedStream); savedStream = save(savedStream);
subscriptionService.broadcast(new SubscriptionMessage(SubscriptionMessageType.NEW_STREAM, savedStream)); subscriptionService.broadcast(new SubscriptionMessage(SubscriptionMessageType.NEW_STREAM, savedStream));