줄맞춤
This commit is contained in:
6
.gitignore
vendored
6
.gitignore
vendored
@@ -60,6 +60,7 @@ Thumbs.db
|
|||||||
.env.*.local
|
.env.*.local
|
||||||
application-local.yml
|
application-local.yml
|
||||||
application-secret.yml
|
application-secret.yml
|
||||||
|
metrics-collector/.env
|
||||||
|
|
||||||
### Docker (local testing) ###
|
### Docker (local testing) ###
|
||||||
.dockerignore
|
.dockerignore
|
||||||
@@ -72,3 +73,8 @@ docker-compose.override.yml
|
|||||||
*.swo
|
*.swo
|
||||||
*~
|
*~
|
||||||
!/CLAUDE.md
|
!/CLAUDE.md
|
||||||
|
|
||||||
|
### Metrics Collector ###
|
||||||
|
metrics-collector/venv/
|
||||||
|
metrics-collector/*.pid
|
||||||
|
metrics-collector/wheels/
|
||||||
|
|||||||
@@ -13,10 +13,9 @@ public enum LayerType implements EnumType {
|
|||||||
TILE("배경지도"),
|
TILE("배경지도"),
|
||||||
GEOJSON("객체데이터"),
|
GEOJSON("객체데이터"),
|
||||||
WMTS("타일레이어"),
|
WMTS("타일레이어"),
|
||||||
WMS("지적도")
|
WMS("지적도"),
|
||||||
, KAMCO_WMS("국유인WMS")
|
KAMCO_WMS("국유인WMS"),
|
||||||
, KAMCO_WMTS("국유인WMTS")
|
KAMCO_WMTS("국유인WMTS");
|
||||||
;
|
|
||||||
|
|
||||||
private final String desc;
|
private final String desc;
|
||||||
|
|
||||||
|
|||||||
@@ -58,8 +58,8 @@ public class LayerService {
|
|||||||
@Transactional
|
@Transactional
|
||||||
public UUID saveLayers(String type, LayerDto.AddReq dto) {
|
public UUID saveLayers(String type, LayerDto.AddReq dto) {
|
||||||
LayerType layerType =
|
LayerType layerType =
|
||||||
LayerType.from(type)
|
LayerType.from(type)
|
||||||
.orElseThrow(() -> new CustomApiException("BAD_REQUEST", HttpStatus.BAD_REQUEST));
|
.orElseThrow(() -> new CustomApiException("BAD_REQUEST", HttpStatus.BAD_REQUEST));
|
||||||
|
|
||||||
switch (layerType) {
|
switch (layerType) {
|
||||||
case TILE, KAMCO_WMS, KAMCO_WMTS -> {
|
case TILE, KAMCO_WMS, KAMCO_WMTS -> {
|
||||||
@@ -169,21 +169,21 @@ public class LayerService {
|
|||||||
public List<LayerMapDto> findLayerMapList(String type) {
|
public List<LayerMapDto> findLayerMapList(String type) {
|
||||||
List<LayerMapDto> layerMapDtoList = mapLayerCoreService.findLayerMapList(type);
|
List<LayerMapDto> layerMapDtoList = mapLayerCoreService.findLayerMapList(type);
|
||||||
layerMapDtoList.forEach(
|
layerMapDtoList.forEach(
|
||||||
dto -> {
|
dto -> {
|
||||||
if (dto.getLayerType().equals("WMS")) {
|
if (dto.getLayerType().equals("WMS")) {
|
||||||
dto.setUrl(
|
dto.setUrl(
|
||||||
String.format(
|
String.format(
|
||||||
"%s/%s/%s",
|
"%s/%s/%s",
|
||||||
trimSlash(geoserverUrl), trimSlash(wmsPath), dto.getLayerType().toLowerCase()));
|
trimSlash(geoserverUrl), trimSlash(wmsPath), dto.getLayerType().toLowerCase()));
|
||||||
} else if (dto.getLayerType().equals("WMTS")) {
|
} else if (dto.getLayerType().equals("WMTS")) {
|
||||||
dto.setUrl(
|
dto.setUrl(
|
||||||
String.format(
|
String.format(
|
||||||
"%s/%s/%s",
|
"%s/%s/%s",
|
||||||
trimSlash(geoserverUrl),
|
trimSlash(geoserverUrl),
|
||||||
trimSlash(wmtsPath),
|
trimSlash(wmtsPath),
|
||||||
dto.getLayerType().toLowerCase()));
|
dto.getLayerType().toLowerCase()));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
return layerMapDtoList;
|
return layerMapDtoList;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -11,37 +11,94 @@ import lombok.Getter;
|
|||||||
import lombok.Setter;
|
import lombok.Setter;
|
||||||
import org.hibernate.annotations.ColumnDefault;
|
import org.hibernate.annotations.ColumnDefault;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* GPU 메트릭 엔티티
|
||||||
|
*
|
||||||
|
* <p>서버의 GPU 성능 및 자원 사용량 메트릭 데이터를 저장하는 JPA 엔티티입니다. GPU 연산 사용률 및 메모리 사용량 등 GPU 리소스 모니터링 데이터를 관리합니다.
|
||||||
|
*
|
||||||
|
* <p>데이터 소스: nvidia-smi 명령어 또는 NVML (NVIDIA Management Library)
|
||||||
|
*
|
||||||
|
* <p>활용 사례:
|
||||||
|
*
|
||||||
|
* <ul>
|
||||||
|
* <li>AI/ML 학습 모니터링: 딥러닝 작업 중 GPU 활용도 추적
|
||||||
|
* <li>리소스 최적화: GPU 메모리 부족 또는 유휴 상태 감지
|
||||||
|
* <li>용량 계획: GPU 추가 필요 시점 예측
|
||||||
|
* <li>알림 설정: gpuUtil > 95% 또는 gpuMemUsed/gpuMemTotal > 90% 시 경고
|
||||||
|
* </ul>
|
||||||
|
*/
|
||||||
@Getter
|
@Getter
|
||||||
@Setter
|
@Setter
|
||||||
@Entity
|
@Entity
|
||||||
@Table(name = "gpu_metrics")
|
@Table(name = "gpu_metrics")
|
||||||
public class GpuMetricEntity {
|
public class GpuMetricEntity {
|
||||||
|
|
||||||
|
/** 기본 키 (UUID, 자동 생성) */
|
||||||
@Id
|
@Id
|
||||||
@ColumnDefault("gen_random_uuid()")
|
@ColumnDefault("gen_random_uuid()")
|
||||||
@Column(name = "uuid", nullable = false)
|
@Column(name = "uuid", nullable = false)
|
||||||
private UUID id;
|
private UUID id;
|
||||||
|
|
||||||
|
/** 시퀀스 기반 보조 ID */
|
||||||
@NotNull
|
@NotNull
|
||||||
@ColumnDefault("nextval('gpu_metrics_id_seq')")
|
@ColumnDefault("nextval('gpu_metrics_id_seq')")
|
||||||
@Column(name = "id", nullable = false)
|
@Column(name = "id", nullable = false)
|
||||||
private Integer id1;
|
private Integer id1;
|
||||||
|
|
||||||
|
/** 메트릭 수집 시각 (시간대 포함, 기본값: 현재 시각) */
|
||||||
@NotNull
|
@NotNull
|
||||||
@ColumnDefault("now()")
|
@ColumnDefault("now()")
|
||||||
@Column(name = "\"timestamp\"", nullable = false)
|
@Column(name = "\"timestamp\"", nullable = false)
|
||||||
private OffsetDateTime timestamp;
|
private OffsetDateTime timestamp;
|
||||||
|
|
||||||
|
/** 모니터링 대상 서버 이름 */
|
||||||
@NotNull
|
@NotNull
|
||||||
@Column(name = "server_name", nullable = false, length = Integer.MAX_VALUE)
|
@Column(name = "server_name", nullable = false, length = Integer.MAX_VALUE)
|
||||||
private String serverName;
|
private String serverName;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* GPU 연산 사용률 (백분율)
|
||||||
|
*
|
||||||
|
* <p>GPU 코어의 연산 처리 활용도를 나타냅니다.
|
||||||
|
*
|
||||||
|
* <p>범위: 0.0 ~ 100.0
|
||||||
|
*
|
||||||
|
* <p>예시: 85.5 = GPU가 85.5% 활용되어 연산 중
|
||||||
|
*
|
||||||
|
* <p>데이터 소스: nvidia-smi의 'utilization.gpu' 또는 NVML의 nvmlDeviceGetUtilizationRates
|
||||||
|
*
|
||||||
|
* <p>참고: 높은 사용률(>90%)은 GPU가 충분히 활용되고 있음을 의미하며, 낮은 사용률은 병목 지점이 다른 곳(CPU, I/O)에 있을 수 있음
|
||||||
|
*/
|
||||||
@Column(name = "gpu_util")
|
@Column(name = "gpu_util")
|
||||||
private Float gpuUtil;
|
private Float gpuUtil;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* GPU 메모리 사용량 (MB 단위)
|
||||||
|
*
|
||||||
|
* <p>현재 GPU에 할당되어 사용 중인 메모리 양
|
||||||
|
*
|
||||||
|
* <p>예시: 10240.0 = 약 10GB의 GPU 메모리 사용 중
|
||||||
|
*
|
||||||
|
* <p>데이터 소스: nvidia-smi의 'memory.used' 또는 NVML의 nvmlDeviceGetMemoryInfo
|
||||||
|
*
|
||||||
|
* <p>용도: 딥러닝 모델 크기, 배치 사이즈 최적화, OOM(Out Of Memory) 에러 예측
|
||||||
|
*/
|
||||||
@Column(name = "gpu_mem_used")
|
@Column(name = "gpu_mem_used")
|
||||||
private Float gpuMemUsed;
|
private Float gpuMemUsed;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* GPU 총 메모리 용량 (MB 단위)
|
||||||
|
*
|
||||||
|
* <p>GPU에 장착된 전체 메모리 용량
|
||||||
|
*
|
||||||
|
* <p>예시: 16384.0 = 16GB VRAM 장착
|
||||||
|
*
|
||||||
|
* <p>데이터 소스: nvidia-smi의 'memory.total' 또는 NVML의 nvmlDeviceGetMemoryInfo
|
||||||
|
*
|
||||||
|
* <p>계산식: 메모리 사용률(%) = (gpuMemUsed / gpuMemTotal) × 100
|
||||||
|
*
|
||||||
|
* <p>활용: 여유 메모리 = gpuMemTotal - gpuMemUsed
|
||||||
|
*/
|
||||||
@Column(name = "gpu_mem_total")
|
@Column(name = "gpu_mem_total")
|
||||||
private Float gpuMemTotal;
|
private Float gpuMemTotal;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -11,48 +11,101 @@ import lombok.Getter;
|
|||||||
import lombok.Setter;
|
import lombok.Setter;
|
||||||
import org.hibernate.annotations.ColumnDefault;
|
import org.hibernate.annotations.ColumnDefault;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 시스템 메트릭 엔티티
|
||||||
|
*
|
||||||
|
* <p>서버 시스템의 성능 메트릭 데이터를 저장하는 JPA 엔티티입니다. CPU 및 메모리 사용량 등 시스템 리소스 모니터링 데이터를 관리합니다.
|
||||||
|
*
|
||||||
|
* <p>데이터 소스: Linux sar 명령어 또는 /proc/meminfo 파일
|
||||||
|
*
|
||||||
|
* <p>활용 사례:
|
||||||
|
*
|
||||||
|
* <ul>
|
||||||
|
* <li>용량 계획: 메모리 추가 필요 시점 예측
|
||||||
|
* <li>성능 모니터링: 메모리 부족 상황 감지
|
||||||
|
* <li>트렌드 분석: 시간대별 메모리 사용 패턴 파악
|
||||||
|
* <li>알림 설정: memused > 90% 시 경고
|
||||||
|
* </ul>
|
||||||
|
*/
|
||||||
@Getter
|
@Getter
|
||||||
@Setter
|
@Setter
|
||||||
@Entity
|
@Entity
|
||||||
@Table(name = "system_metrics")
|
@Table(name = "system_metrics")
|
||||||
public class SystemMetricEntity {
|
public class SystemMetricEntity {
|
||||||
|
|
||||||
|
/** 기본 키 (UUID, 자동 생성) */
|
||||||
@Id
|
@Id
|
||||||
@ColumnDefault("gen_random_uuid()")
|
@ColumnDefault("gen_random_uuid()")
|
||||||
@Column(name = "uuid", nullable = false)
|
@Column(name = "uuid", nullable = false)
|
||||||
private UUID id;
|
private UUID id;
|
||||||
|
|
||||||
|
/** 시퀀스 기반 보조 ID */
|
||||||
@NotNull
|
@NotNull
|
||||||
@ColumnDefault("nextval('system_metrics_id_seq')")
|
@ColumnDefault("nextval('system_metrics_id_seq')")
|
||||||
@Column(name = "id", nullable = false)
|
@Column(name = "id", nullable = false)
|
||||||
private Integer id1;
|
private Integer id1;
|
||||||
|
|
||||||
|
/** 메트릭 수집 시각 (시간대 포함) */
|
||||||
@NotNull
|
@NotNull
|
||||||
@Column(name = "\"timestamp\"", nullable = false)
|
@Column(name = "\"timestamp\"", nullable = false)
|
||||||
private OffsetDateTime timestamp;
|
private OffsetDateTime timestamp;
|
||||||
|
|
||||||
|
/** 모니터링 대상 서버 이름 */
|
||||||
@NotNull
|
@NotNull
|
||||||
@Column(name = "server_name", nullable = false, length = Integer.MAX_VALUE)
|
@Column(name = "server_name", nullable = false, length = Integer.MAX_VALUE)
|
||||||
private String serverName;
|
private String serverName;
|
||||||
|
|
||||||
|
/** 사용자 프로세스가 사용한 CPU 사용률 (%) - 응용 프로그램 실행 */
|
||||||
@Column(name = "cpu_user")
|
@Column(name = "cpu_user")
|
||||||
private Float cpuUser;
|
private Float cpuUser;
|
||||||
|
|
||||||
|
/** 시스템 프로세스가 사용한 CPU 사용률 (%) - 커널 작업 */
|
||||||
@Column(name = "cpu_system")
|
@Column(name = "cpu_system")
|
||||||
private Float cpuSystem;
|
private Float cpuSystem;
|
||||||
|
|
||||||
|
/** I/O 대기로 소모된 CPU 사용률 (%) - 디스크/네트워크 대기 */
|
||||||
@Column(name = "cpu_iowait")
|
@Column(name = "cpu_iowait")
|
||||||
private Float cpuIowait;
|
private Float cpuIowait;
|
||||||
|
|
||||||
|
/** 유휴 상태 CPU 사용률 (%) - 사용 가능한 여유 CPU */
|
||||||
@Column(name = "cpu_idle")
|
@Column(name = "cpu_idle")
|
||||||
private Float cpuIdle;
|
private Float cpuIdle;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 사용 가능한 여유 메모리 (KB 단위)
|
||||||
|
*
|
||||||
|
* <p>시스템에서 즉시 사용 가능한 물리 메모리 양
|
||||||
|
*
|
||||||
|
* <p>예시: 4194304 = 약 4GB의 여유 메모리
|
||||||
|
*
|
||||||
|
* <p>데이터 소스: /proc/meminfo의 MemFree
|
||||||
|
*/
|
||||||
@Column(name = "kbmemfree")
|
@Column(name = "kbmemfree")
|
||||||
private Long kbmemfree;
|
private Long kbmemfree;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 현재 사용 중인 메모리 (KB 단위)
|
||||||
|
*
|
||||||
|
* <p>시스템이 현재 할당하여 사용 중인 물리 메모리 양
|
||||||
|
*
|
||||||
|
* <p>예시: 8388608 = 약 8GB의 사용 중인 메모리
|
||||||
|
*
|
||||||
|
* <p>계산: MemTotal - MemFree
|
||||||
|
*/
|
||||||
@Column(name = "kbmemused")
|
@Column(name = "kbmemused")
|
||||||
private Long kbmemused;
|
private Long kbmemused;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 메모리 사용률 (백분율)
|
||||||
|
*
|
||||||
|
* <p>전체 메모리 대비 사용 중인 메모리 비율
|
||||||
|
*
|
||||||
|
* <p>계산식: (kbmemused / (kbmemused + kbmemfree)) × 100
|
||||||
|
*
|
||||||
|
* <p>예시: 66.7 = 전체 메모리의 66.7% 사용 중
|
||||||
|
*
|
||||||
|
* <p>관계식: 총 메모리 = kbmemused + kbmemfree
|
||||||
|
*/
|
||||||
@Column(name = "memused")
|
@Column(name = "memused")
|
||||||
private Float memused;
|
private Float memused;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user