분류 전체보기 344

판교 퇴근길 밋업 with 인프런 #04 사이드 프로젝트 참가후기

판교 퇴근길 밋업 with 인프런 #04 사이드 프로젝트 참가후기얼마전에 판교 퇴근길 밋업을 갔다왔다.뭔가 회사에서 일도 많고... 뭔가 좀 일에 대한 열정도 떨어지고 하던 와중에 인프런에서 퇴근길 밋업이 있어서 신청해 봤다. https://www.inflearn.com/course/offline/%ED%8C%90%EA%B5%90-%ED%87%B4%EA%B7%BC%EA%B8%B8%EB%B0%8B%EC%97%85-%EC%9D%B8%ED%94%84%EB%9F%B0-%EC%82%AC%EC%9D%B4%EB%93%9C%ED%94%84%EB%A1%9C%EC%A0%9D%ED%8A%B8 [지금 무료] 판교 퇴근길 밋업 with 인프런 #04 사이드 프로젝트 | 인프런 - 인프런인프런 | , [사진]   옆자리 동료와 ..

기타/일상 2024.06.29

Blocking, non-blocking, sync, async 간략한 정리와 합쳐 사용하기

Blocking, non-blocking, sync, async 간략한 정리와 합쳐 사용하기간단한 정리Blocking작업이 완료될 때 까지 호출한 쓰레드가 대기한다.Non-blocking작업이 완료되지 않아도 쓰레드가 대기하지 않는다.즉, 응답이 돌아오지 않아도 다른 작업을 할 수 있다.Sync작업이 완료될 때 까지 호출한 함수의 실행을 블로킹.제어권 반환 XAsync작업이 완료되기 전에 제어권을 반환하여 호출한 함수의 실행을 블로킹하지 않는 방식.뭐 이렇다고 한다.이렇게 보면 뭔소리야? 싶은데 조금 더 상세히 알아보자.세부적인 차이저 둘의 차이는 결국 "호출된 함수" 와 "호출한 함수" 에서 온다고 생각한다.Blocking / Non-blocking이 둘은 호출한 쪽이 대기하는지 여부가 중요하다.즉, ..

이론 정리 2024.06.24

TDD 장단점 - Bob martin 과 Jim Coplien 토론을 보고

TDD 장단점 - Bob martin 과 Jim Coplien 토론을 보고https://www.youtube.com/watch?v=eRxc4PD6RN0일단 Bob은 TDD 신봉 Jim은 정반대TDD 3가지 법칙실패하는 단위 테스트 작성 전까지는 한 줄의 상용 코드를 작성할 수 없다.실패하기에 충분한 양의 단위 테스트만 작성해야 한다. (컴파일이 안되는것도 실패에 해당)현댖 실패하는 테스트 코드들을 성공시킬 만큼만 상용 코드를 작성해야 한다.즉 지금 실패하는 코드에 해당하는것 이상의 코드는 작성할 수 없다는 것위의 내용은 30초단위로 실패코드-상용코드를 한꺼번에 작성한다는것을 의미한다.TDD의 2가지 문제(Jim이 경험한)아키텍처나 프레임워크 없이 TDD를 사용한다.kent(아마 켄트백?) 이 얘기한 내용..

이론 정리 2024.05.25

github vscode mode

github vscode modePR 코드리뷰를 하거나 다른 사람의 코드를 살펴볼 일이 은근 있다.그 때 깃허브로 그냥 보면 뭔가 상당히 불편하다.이거를 vscode 모양으로 볼 수 있게 해주는게 있는데, 그냥 github.com 을 github1s.com 으로 써주면 된다.예를 들어https://github.com/RyooChan/nyam-nyam-good이런 레포가 있을 때https://github1s.com/RyooChan/nyam-nyam-good이렇게 써주면 되는 식이다.이러면 알아보기가 매우 쉽다.

잡다한 기능들 2024.05.25

MySQL 8.0부터 추가된 explain analyze 에 대해 ARABOZA!

MySQL 8.0부터 추가된 explain analyze 에 대해 ARABOZA!MySQL에서 쿼리 인덱스랑 실제 동작 관련 테스트를 하는데... 엄청 많은 조건이 있어서 대체 어디서 시간이 오래걸리는지 이런거가 매우 헷갈렸다.이 때에 아주 유용한게 explain analyze 이다.사실 이거 보면 매우매우 잘 설명되어있기는 한데 걍 정리해본다.실제로 경험한 일인데, 상세한 내용을 말하기는 어렵고 통해 그냥 이거의 장점만 훑으려 한다.일단 기존의 explain 과 다른 점은explain은 실제로 SQL 쿼리를 실행하지 않은 상태에서 옵티마이저가 계획한 쿼리 실행 계획을 보여준다.explain analyze 는 쿼리를 실제로 실행한 뒤에 그 결과를 통해 실행 계획을 보여준다. 또, 실제로 실행하면서 각 단..

배민에서 대규모 트랜잭션 처리하는법

배민에서 대규모 트랜잭션 처리하는법사실 이번에 브런치에서 좀 정보성 데이터를 많이 가지고 이걸 전달해야 하는 개발사항이 있었다.뭔가 많은 조인과... 많은 데이터가 필요하고 약간의 실시간성을 가진 친구를 만들어야 하는데 이걸 어떻게 할까 하다가 여기까지 굴러들어왔다.근데 들어보니까 내가 고민한 것과 매우 비슷했던 것 같고 좋은 내용이 많아 간략히 정리해 보았다.https://www.youtube.com/watch?v=704qQs6KoUk요거배민 주문 시스템의 특징배민 주문 시스템장바구니, 주문하기, 주문내역 같은 애들을 만드는곳이다.여기 시스템은 12시, 18:30 같은 식사시간에 주문수 추이가 확 늘어난다.즉 트래픽이 특정 시간에 집중된다는것이다.MSA배민은 수많은 시스템으로 이루어져 있다.그냥 주문 ..

이론 정리 2024.05.20

한 권으로 읽는 컴퓨터 구조와 프로그래밍 5장 정리

기본적 구조 요소기본적으로 폰 노이만 구조, 하버드 구조 이렇게 있는데 둘의 차이는 메모리 배열뿐이다.폰 노이만 구조는 메모리 버스와 주소 버스가 하나뿐이다.폰 노이만 구조가 약간 더 느리지만 하버드 구조는 두번째 메모리 처리를 위한 버스가 더 필요하다.프로세서 코어위의 두 구조는 모두 CPU가 하나뿐이다.단일 CPU보다 성능을 높이기 위해 멀티프로세서가 도입됐는데 병렬화에서 문제가 있었다.예전에는 CPU라는거를 요즘은 프로세스 코어라고 하고, 이거를 여러개 쓰는거를 멀티코어라고 한다.마이크로프로세서와 마이크로컴퓨터마이크로프로세서메모리와 I/O가 프로세서 코어와 같은 패키지에 들어 있지 않음마이크로컴퓨터모든 요소를 한 칩 안에 패키징일단은 메모리가 차지하는 영역이 꽤 크기 때문에 마이크로프로세서보다 마이..

virtual thread 기본 공부

https://www.youtube.com/watch?v=BZMZIM-n4C0요거 보고 정리해 봤다.Virtual Thread안정성과 처리량에 대한 고민(전사 게이트웨이) -> 높은 트래픽에의 높은 처리량!!Kotlin의 coroutinejava project loom 에 도입된 virtual thread일단 virtual thread는 2018년에 project loom 으로 시작된 경량 스레드 모델이다.그리고 23년 JDK21에 정식 feature로 추가됨.장점스레드 생성 및 스케줄링 비용이 기존 스레드보다 저렴스레드 스케줄링을 통해 nonbloking I/O 지원기존 스레드를 상속해서 사용 가능스레드 생성 및 스케줄링 비용 저렴기존 자바 스레드는 생성 비용이 크다.자바에서 미리 여러 요청 처리를 위..

이론 정리/java 2024.04.27

SLASH22의 왜 은행은 무한스크롤이 안되나요 영상을 보고..

카카오 브런치에서 백엔드를 담당하고 있는데, 거기서 연재 작품 전체 라는 슬롯에서 무한스크롤을 적용해 보았다. 그리고 우연한 계기로 토스뱅크에서 무한스크롤을 도입한 계기가 있어서 이를 살펴 보았는데, 좀 신기하고 재밌어 보였다. SLASH22의 왜 은행은 무한스크롤이 안되나요 를 보고 정리해 보았다. 상황 보통 은행앱이 조회기간 설정을 한다(1주일, 1개월, 6개월 등등...) 그리고 지정된 기간만큼이 쫘라락 조회되는(그만큼만) 방식이다. -> 즉 스크롤은 있는데 무한스크롤로 페이지 조회 후 넘어가는 이런게 없다. 상황 이해 이 이유를 알려면 은행 시스템에 대한 이해가 필요한데 은행 앱 - 채널계 - 계정계 은행 시스템은 이렇게 분리되어 있다. 계정계는 실제로 유저의 돈을 다루며 원본 데이터가 저장되는 ..

백엔드 공부 2024.04.20