1장 들어가며
코딩을 할 수 있게 된 것일 뿐
2장 느려진 서비스, 어디부터 봐야 할까
처리량과 응답 시간
서버 성능 개선 기초
3장 성능을 좌우하는 DB 설계와 쿼리
성능에 핵심인 DB
조회 트래픽을 고려한 인덱스 설계
몇 가지 조회 성능 개선 방법
알아두면 좋을 몇 가지 주의 사항
실패와 트랜잭션 고려하기
4장 외부 연동이 문제일 때 살펴봐야 할 것들
우리는 문제가 없는데
타임아웃
재시도
동시 요청 제한
서킷 브레이커
외부 연동과 DB 연동
HTTP 커넥션 풀
연동 서비스 이중화
5장 비동기 연동, 언제 어떻게 써야 할까
동기 연동과 비동기 연동
별도 스레드로 실행하기
메시징
트랜잭션 아웃박스 패턴
배치 전송
CDC(Change Data Capture)
6장 동시성, 데이터가 꼬이기 전에 잡아야 한다
서버와 동시 실행
잘못된 데이터 공유로 인한 문제 예시
프로세스 수준에서의 동시 접근 제어
DB와 동시성
잠금 사용 시 주의 사항
단일 스레드로 처리하기
7장 IO 병목, 어떻게 해결하지
네트워크 IO와 자원 효율
가상 스레드로 자원 효율 높이기
논블로킹 IO로 성능 더 높이기
언제 어떤 방법을 택할까
8장 실무에서 꼭 필요한 보안 지식
중요한 보안
인증과 인가
데이터 암호화
HMAC을 이용한 데이터 검증
방화벽으로 필요한 트래픽만 허용하기
감사 로그(audit log) 남기기
데이터 노출 줄이기
비정상 접근 처리
시큐어 코딩
개인 보안
9장 최소한 알고 있어야 할 서버 지식
개발자와 서버
OS 계정과 권한
프로세스 확인하기
백그라운드 프로세스
디스크 용량 관리
파일 디스크립터 제한
시간 맞추기
크론으로 스케줄링하기
alias 등록하기
네트워크 정보 확인
10장 모르면 답답해지는 네트워크 기초
네트워크 기초를 모르면
노드, 네트워크, 라우터
IP 주소와 도메인
NAT
VPN
프로토콜과 TCP, UDP, QUIC
11장 자주 쓰는 서버 구조와 설계 패턴
MVC 패턴
계층형 아키텍처
DDD와 전술 패턴
마이크로서비스 아키텍처
이벤트 기반 아키텍처
CQRS 패턴
부록 A: 처음 해보는 성능 테스트를 위한 기본 정리
성능 테스트 종류
포화점과 버클존
주요 측정 지표
성능 테스트 설계 시 고려 사항
성능 테스트 도구
성능 테스트 실행 시 주의 사항
부록 B: NoSQL 이해하기
NoSQL이란
NoSQL 종류
NoSQL 도입 시 고려 사항
CAP 정리
부록 C: DB로 분산 잠금 구현하기
잠금 정보 저장 테이블
분산 잠금 동작
DB 잠금 구현