1. 유용한 개발 관련 아티클 및 영상 #13 스타트업에서 4년간 인프라를 운영하며 좋았던/후회하는 (거의) 모든 인프라 결정들 AWS 선택 AWS 대 Google Cloud 선택: AWS를 선택한 것을 지지함. AWS는 고객에 중점을 두고 있음. Google Cloud는 로봇과 자동화에 의존하는 느낌이 있음. EKS: EKS 사용을 지지함. EKS는 AWS 서비스와의 깊은 통합을 제공하며, Kubernetes도 많은 방면에서 따라잡았음(외부dns를 사용하여 Route53과 통합하는 등) EKS 관리형 애드온: EKS 관리형 애드온 사용을 후회함. 설치를 커스터마이즈해야 할 필요가 있었고, helm 차트로 전환한 이후 더 나은 운영을 경험 데이터베이스 및 캐싱 RDS: RDS 사용을 지지함. 데이터는 인..
1. JIT 컴파일러(Just-In Time Compiler)의 최적화 과정 자세히 살펴보기 [ Inlining(인라인) ] 앞선 포스팅에서 살펴보았듯 Inlining은 호출되는 메서드를 본문으로 인라인하여 메서드 호출에 대한 오버헤드를 줄일 수 있고, 이를 통해 다른 최적화를 적용할 수도 있다. 하지만 인라인은 코드 크기를 늘리기 때문에 신중하게 적용되어야 한다. 왜냐하면 컴파일된 코드는 제한된 코드 캐시라는 힙 공간에 저장되는데, 공간이 부족해지면 더 이상 코드를 컴파일 할 수 없기 때문이다. 따라서 JVM은 휴리스틱하게 메서드의 인라인 여부를 결정하는데, 대표적으로 자주 호출되는 메서드나 Getter와 Setter 같은 간소한 메서드들을 인라인하려고 시도한다. 인라인 정책은 JVM 매개변수로 변경할..
1. 유용한 개발 관련 아티클 및 영상 #12 Java Process 메모리 추적기 자바 애플리케이션의 힙 사이즈를 1g로 조정(Java Heap = -Xms1g -Xmx1g)해도 프로세스의 메모리 크기는 2g가 넘는 경우가 보임 남은 메모리 사용량은 네이티브 메모리 영역이며, 애플리케이션 실행 과정에서 사용된 정보들이 아닌 압축 해제된 jar 내용들이 메모리에 남아 길을 잃고 있었음 Springboot의 Bug로 ZipInflaterInputStream.close() 가 Native Memory 를 해제하지 못했고 이로 인해 불필요하게 Gb 단위로 메모리를 점유하고 있었음 스프링 부트 레포지토리에 버그로 등록된 건이고, 1.5.16 버전에서 패치됨 출처: https://www.whatap.io/ko/b..
1. JIT 컴파일러(Just-In Time Compiler)란? [ JIT 컴파일러(Just-In Time Compiler)란? ] 자바 컴파일러(javac)는 자바 파일을 읽고 클래스 파일로 컴파일한다. 바이트코드는 모든 연산 코드가 단일 바이트로 표시되며 플랫폼에 종속되지 않는(portable) 명령어 집합으로 구성된다. 이들은 자바 가상 머신(JVM)에서 실행되며 실행 시점에 기계어로 번역한다. 덕분에 특정 아키텍처에 종속적되지 않지만 성능은 훨씬 떨어진다. JVM 초기에는 실행 시점에 모든 바이트코드를 직접 기계어로 해석했기 때문에 성능 문제가 있었다. 이를 위해 JDK 1.3에 HotSpot VM이 도입되어 런타임에 바이트코드를 느리게 해석하는 대신 최적화된 코드를 실행할 수 있는 JIT(Ju..
1. 유용한 개발 관련 아티클 및 영상 #11 브랜치 관리를 도와줄 gitbutler 파일들이 각각의 virtual branches에 들어가는 방식으로 브랜치가 관리됨 기존에 깃을 사용하면서 겪었던 리베이스 등의 문제를 혁신적으로 해결해준다고 함 출처: https://twitter.com/BahkChanhee/status/1763080997892198729?s=20 오픈소스 생태계의 명과암 Node.js의 오래된 웹 프레임워크인 Express.js 저장소에 대량으로 스팸 PR이 등록되는 문제가 발생했음 구독자가 486만명인 인기 유튜버가 GitHub에서 Pull Request로 기여하는 방법을 설명하면서 express.js 저장소를 대상으로 설명한게 발단이 되었음 유튜버는 Express.js를 포크해서 ..