본문 바로가기

CS4

@Transactional 도대체 언제 쓰고 언제 안써야해? 알아보게된 이유수정을 하는 로직이 있다면 무조건 Transactional을 붙여야하는가?언제 Transactional을 붙여야하는건지Transactional에 대한 이해 부족 @Transactional이란?spring에서 메서드의 원자성을 보장하기 위해 정의된 annotation interface입니다.Spring으로 원자성을 보장하기 위해서는 persistence layer를 구성하여 수행하는데요, 이는 보통 DB 연결로 수행 하기 때문에 구현체로 DB 관련 TransactionManager를 많이 사용하게 됩니다.하지만 @Transactional은 DB에 한정되서 사용하는 것이 아니라 기능 동작에 관한 원자성을 보장하는 interface입니다. 하지만 Spring은 데이터 저장소가 아니라서 어떤 솔루.. 2025. 2. 26.
로드밸런싱 알고리즘과 SPOF에 의한 DNS 로드밸런싱 개념로드 밸런서 (Switch/LB)이름 그대로, 사용자의 요청을 서버에 분배하는 역할을 한다.서버에 가해지는 트래픽을 여러 대의 서버에 고르고 분배하서, 특정 서버의 부하를 막아준다.짚고 넘어갈것 💡DNS에서 알려주는 IP주소는 최종 목적지 서버의 IP 주소야? 아니면 로드밸런서의 IP 주소야? 🗣️ 일반적인 대규모 서비스에서는 로드밸런서의 IP 주소를 가리키고 있다. ⇒ 이후 로드밸런서가 적합한 최종 목적지 서버로 요청을 전달한다. 로드밸런싱의 이점로드 밸런싱은 여러 서버나 컴퓨터 자원에 작업을 고르게 분산하는 기술이다.로드밸런싱으로 인해 아래와 같은 이점을 얻을 수 있다.가용성로드 밸런서는 서버 문제를 자동으로 감지하고 클라이언트 트래픽을 사용 가능한 서버로 리다이렉션하여 시스템의 내결함성을 높.. 2025. 2. 11.
[운영체제] ThreadPool /Blocking Queue의 종류들은 각각 언제 사용할까 기본 개념프로세스실행중인 프로그램, 메모리에 적재되어 있음, 메모리 공유X쓰레드 (Thread)프로세스 내에서 실행되는 단위이며, CPU의 실행단위같은 프로세스내에서 메모리 공간을 공유하며 작업을 병렬로 수행가능쓰레드 풀이란동시에 실행되는 작업(쓰레드)를 관리하는 데 사용되는 기법현재 풀이 corePoolSize보다 많은 수의 스레드들을 가지고 있다면 초과된 스레들은 keep-alive Time시간보다 더 오래 할 일이 없다면 제거된다.쓰레드 풀을 쓰는 이유 & 주의 할 점원인 다중 스레드를 사용하는 경우, 특정 서비스가 실행될 때마다 스레드를 생성하는데 소요되는 시간이 문제가된다.과정 그래서 프로세스를 시작할 때, 아예 일정한 수의 쓰레드들을 미리 풀로 만들어 두는 것이다.결과 새 스레드를 매번 만들기.. 2025. 2. 4.
[DB] 데이터베이스와 SQL 01-1 데이터베이스 알아보기데이터베이스와 DBMS데이터베이스는 ‘데이터의 집합’DBMS의 정의데이터베이스를 관리하고 운영하는 소프트웨어데이터 베이스를 여러명의 사용자나 응용 프로그램과 공유하고 동시에 접근이 가능해야 한다.DBMS의 종류MYSQL, MariaDB, PostgreSQL, Oracle 등 DBMS의 발전 과정종이에 펜으로 기록 → 컴퓨터에 파일로 저장 → DBMS의 대두와 보급DBMS에 데이터를 구축, 관리하고 활용하기 위해서 사용되는 언어가 SQL DBMS의 분류현재 사용되는 DBMS 중에는 관계형 DBMS가 가장 많은 부분을 차지계층형 DBMS각 계층은 트리 형태를 갖는다처음 구성을 완료한 후에 이를 변경하기가 까다롭다.[ex - 사장 1명과 이사 3명 - 이사 아래로 각각 재무팀1,2.. 2022. 9. 19.