AWS Aurora RDS(MySQL 호환) 환경에서 HikariCP의 keepaliveTime 설정을 사용하지 않는 것이 더 좋다는 점에 대해 설명드립니다. Aurora는 일반적인 MySQL과는 다르게 커넥션을 관리하는 방식이 다르며, 이를 고려하여 커넥션 풀링 전략을 최적화하는 것이 중요합니다. 1. Aurora MySQL의 커넥션 관리 특성 Aurora MySQL은 MySQL과 호환되지만 내부적으로 분산 스토리지 아키텍처를 사용하고, 자동 장애 조치(Failover) 더 읽기
자바
EKS 환경에서 Pod 장애 발생 시 요청을 이어받아 처리하는 방법
1. 개요 EKS 환경에서 Spring Boot 애플리케이션이 여러 개의 Pod에서 실행되고 있을 때,특정 Pod가 요청을 처리하는 중 장애로 종료되면, 다른 Pod에서 동일 요청을 이어서 처리할 수 있는가? 이 문서에서는 일반적인 CRUD 요청과 파일 업로드 요청 모두에 대해Pod 장애 발생 시에도 중단 없이 이어서 처리할 수 있는 방법을 설명합니다. 2. 첫 더 읽기
AWS Aurora Failover 대비 Spring Boot 트랜잭션 유지 및 커넥션 폐기 대응 방법
AWS Aurora를 사용하는 Spring Boot 애플리케이션에서 Writer 장애(Failover) 발생 시 트랜잭션을 유지하면서 서비스 중단을 최소화하려면 어떻게 해야 할까?Aurora 클러스터에 연결된 상태에서 Writer 장애 발생 시 기존 커넥션이 유지되지 않으며, 트랜잭션 처리 방식은 autocommit 설정에 따라 다르게 동작한다. 이 글에서는 Aurora 장애 발생 시 트랜잭션이 어떻게 동작하는지와 애플리케이션에서 최적의 대응 방법을 더 읽기
KISA SEED ECB 암복호화 및 문자열 변환 방법
KISA SEED는 한국정보보호진흥원(KISA)에서 개발한 블록 암호 알고리즘으로, 국내에서 널리 사용되는 암호화 방식 중 하나입니다. SEED 알고리즘은 여러 운영 모드를 지원하는데, 그중 ECB(Electronic Codebook) 모드는 블록 단위로 독립적으로 암호화하는 방식입니다. SEED ECB 모드를 사용하여 데이터를 암·복호화하면 byte[] 형태의 결과값을 얻게 되는데, 이를 문자열(String)로 변환하여 저장하거나 전송하는 방법이 필요할 수 있습니다. 이 더 읽기
Kafka 컨슈머를 EKS에서 운영할 때 발생하는 문제와 해결 방법
1. 개요 Kafka 컨슈머를 Amazon EKS 환경에서 운영할 때, Pod가 생성 및 삭제되면서 중복 소비, 메시지 누락, Rebalance 지연 등의 문제가 발생할 수 있습니다. 이 글에서는 Kafka 컨슈머의 동작 방식과 안정적인 운영 방법을 정리합니다. 2. Kafka 컨슈머와 EKS의 배포 방식 EKS에서는 Rolling Update 방식으로 새로운 버전의 Pod를 배포하면 기존 Pod가 더 읽기
Spring Batch 5.1.2에서 HikariCP 연결 문제 해결 방법
Spring Batch 5.1.2를 사용하면서 HikariCP 연결 문제를 경험하는 경우가 많습니다. 특히, 데이터베이스 재시작 또는 세션 종료 후 커넥션이 끊기는 문제가 발생할 수 있습니다. 이 글에서는 이러한 문제의 원인을 분석하고, 해결 방법을 소개하겠습니다. 1. 문제 원인 분석 Spring Batch는 배치 작업을 실행하면서 데이터베이스와 지속적으로 연결을 유지합니다. 하지만 다음과 같은 상황에서 HikariCP의 더 읽기
Spring Application [applicationContext.xml] 오류
javax.xml.parsers.ParserConfigurationException: Unable to validate using XSD: Your JAXP provider [org.apache.crimson.jaxp.DocumentBuilderFactoryImpl@131f71a] does not support XML Schema. Are you running on Java 1.4 or below with Apache Crimson? Upgrade to Apache Xerces (or Java 1.5) for full XSD support. 이런 당황스런 오류를 발견 하게 되는 경우가 있는데 이것은 자바 1.4의 XML 더 읽기
자바(java) 기초 7편.
Connection Pool * : Connection을 반드시 연결해야 되는데 Connection을 맺는 시간이 많이 걸린다. * 예> dept를 select ==> 10초가 걸렸다. * ==> Connection 맺는 시간이 8초. * ==> 미리 처음에 Connection을 4개 정도를 미리 맺어서 * 특정 클래스(Connection Pool)에 저장한다. * 필요하면 특정클래스에 메소드를 호출해서 Connection을 얻어서 사용한다. * 사용한 후에 반드시 돌려줘야 한다. Connection Pool 더 읽기
자바(java) 기초 6편.
/*1. GUI ( Graphics User Interface ) – 자바의 GUI 구현 2가지 방법 가. AWT : 무겁다. : OS자원으로 화면구성. 나. Swing : 가볍다. : 자체적인 자원으로 화면구성. – java.awt 패키지 – 계층구조( 상속관계 ) Object | Component Container 일반 Component(Button, TextField, TextArea, CheckBox,…) ==> 반드시 Container에 얹혀서 보여진다. │ 더 읽기
자바(java) 기초 5편.
1. try~catch문 메커니즘 try{ 1. 2. (예외발생) int num = 3/0; 3. }catch(Exception e){ //다형성 4. } 5. 가. 2에서 예외발생됨 나. 발생된 예외를 JVM 에게 알린다. 다. JVM에서 발생된 예외를 처리 가능한 클래스를 찾는다. XXXException 을 찾았다. 라. XXXException 클래스를 객체생성한다. XXXException x = new XXXException(발생된예외정보 ); / by zero 더 읽기