1. 구매구매처HY320 빔프로젝터는 2월 초에 알리에서 쿠폰을 주길래 덥석 구매한 제품이다.그 당시에 HY300은 4~5만원, HY350은 9~10 만원이었기 때문에 쿠폰가로 5만원인 HY320을 안고를 이유가 없었다.제품 옵션을 보면 EU플러그로 선택했는데, 따라서 반드시 아래와 같은 어댑터가 필요하다.여기서 중요한 점은 무조건 독일플러그가 호환 되는 제품으로 사야 한다는 점. EU플러그는 우리나라 플러그와 아주 비슷하지만, 완벽하게 같지 않아서 유격이 반드시 발생하게 되어 있고독일플러그는 우리나라 플러그와 완전히 똑같다.배송배송 기간은 10일쯤 걸린것 같다. 2월 2일 주문해서 2월 13일 도착.배송상태도 양호. 2. 제품 상세 스펙구성품구성품은 본체, 전원연결선, 리모콘으로 심플한 편이다.크기 비..
1. 구매 배경P100 vs P100M vs P110 vs P110M스마트 플러그를 사야겠다고 마음먹고 제일 고민 했던 지점이 이거다.저 4개 모델 중에 뭘 사야하지? 4개 모델의 차이점은 이렇다.모델명에너지 모니터링Matter 지원최대 전류특징P100지원하지 않음지원하지 않음10A기본 스마트 플러그 기능P100M지원하지 않음지원10AMatter 지원, 기본 기능P110지원지원하지 않음16A에너지 모니터링, 높은 전류P110M지원지원16A에너지 모니터링, Matter 지원 분명히 살 때는 "난 애플홈에 연동해서 쓸거니까 Matter가 지원되는 M모델이어야 하고, 나중에 어떤 전자 기기를 연결하게 될지 혹시 모르니까 일단 110으로 사야겠다" 라는 마음이었는데, 현실은 침실 조명용으로 사용하고 있으니 가..
1. 프론트엔드 TracingTracing은 각 요청에 고유 식별자(traceId)를 부여하고, 이를 애플리케이션의 여러 계층과 서비스를 거치며 따라가는 과정입니다. 이는 복잡한 시스템에서 문제 해결과 성능 최적화에 큰 도움이 됩니다. 프론트엔드에서의 traceId 생성 이점전체 시스템 가시성: 사용자 인터랙션부터 백엔드 처리까지 전 과정을 추적할 수 있습니다.일관된 모니터링: 모든 서비스에서 동일한 traceId를 사용하여 요청을 추적합니다.세션 단위 분석: 사용자 세션 전체에 걸친 활동을 종합적으로 분석할 수 있습니다.2. 구현2.1. React에서 traceId 생성 및 전송프론트엔드 애플리케이션에서 traceId를 생성하고 API 요청에 포함시킵니다.// traceId 생성 유틸리티import {..
1. WebSocket을 이용한 실시간 알림 기능실시간 알림은 사용자가 새로 고침하거나 업데이트를 반복적으로 수행할 필요 없이 변경된 내용을 즉시 사용자에게 푸시합니다. 채팅앱이나 주식앱, 대시보드 알람같은 기능으로 사용할 수 있습니다. 이번 글에서는 Spring Boot와 WebSocket을 사용하여 실시간 알림 시스템을 구축하는 방법을 보여드리겠습니다. 2. Spring Boot 애플리케이션 설정2.1. 의존성 추가먼저 새 Spring Boot 프로젝트를 생성하거나 기존 프로젝트에 다음 의존성을 추가합니다.dependencies { implementation 'org.springframework.boot:spring-boot-starter-web' implementation 'org.springfra..
#1. Spring 캐싱캐싱은 자주 요청되는 데이터를 임시로 저장하여 애플리케이션 성능을 향상시키는 데 중요한 방법입니다. 데이터베이스 검색 및 API 요청과 같은 비용이 많이 드는 작업을 줄여 응답 시간을 단축하고, 백엔드 부담을 줄이며, 사용자 경험을 향상시킵니다. Spring Boot는 캐싱을 간편하게 구현할 수 있도록 다음과 같은 어노테이션을 제공합니다.@Cacheable: 메서드 파라미터를 기반으로 메서드 결과를 캐시합니다.@CachePut: 메서드 결과로 캐시를 업데이트합니다@CacheEvict: 캐시에서 데이터를 제거합니다@Caching: 단일 메서드에 여러 캐싱 어노테이션을 조합할 수 있습니다#2. Spring 캐시 구현Spring Boot 애플리케이션에서 캐싱을 활성화하려면 설정 클래스..