본문 바로가기

전체글112

단축 URL을 사용하는 이유는 무엇이고 구현해보자 목차개요나의 경험그래서 단축 URL에 장점이 뭔데?구현하기구현하기 1차구현하기 2차구현하기 3차결론1. 개요프로젝트를 진행하면서 게시글 공유하기 기능을 구현하던 중 단축 URL에 대한 이야기가 나왔다. 평소 유튜브나 네이버 블로그 등 공유하기 버튼을 누르면 길었던 URL 구조가 단축된 경우를 볼 수 있을 것이다.평소에는 그냥 가볍게 지나왔는데 이번 프로젝트를 통해서 단축 URL을 왜 사용하고 구현하는 방법에 대해서 차근차근 정리해보려고 한다.레츠고~2. 나의 경험먼저 나는 카카오톡 같이 URL 링크를 친구들과 대화방에서 주고 받을때 경험을 해봤다. 보통 PC 주소를 그대로 복사해서 전달할때 아래 쿠팡 링크 같이 길게 전달되는 경우가 종종 있었다. 그래서 카톡 대화창이 길어지면 아래에 있는 전체보기 버튼이.. 2025. 4. 16.
좋아요 수를 이용해 동시성 처리 비교하기 목차개요좋아요 설계좋아요 수 설계동시성 문제비관적 락(Pessimistic Lock) 낙관적 락(Optimistic Lock)비관적 락(Pessimistic Lock) vs 낙관적 락(Optimistic Lock)결론1. 개요좋아요 기능을 구현하면서 마주할 수 있는 문제들과 상황을 정리해보려고 한다.특히, 좋아요 기능뿐만 아니라 데이터의 무결성을 보장하기 위해 동시성 처리를 어떻게 해야할지는 중요한 과제인데 이번 정리를 통해 차근차근 알아보자.2. 좋아요 설계기본적인 요구사항은 다음과 같다.각 사용자는 게시글마다 좋아요를 누를 수 있다.좋아요를 했다면 취소도 가능하다.idPKpost_id게시글 아이디user_id사용자 아이디created생성일시좋아요는 별도 테이블로 관리되며 post_id와 user_id.. 2025. 3. 9.
댓글 알고리즘으로 무한 depth 구현하기 목차개요최대 2depth 댓글댓글 생성 삭제댓글 목록 조회무한 depth 댓글댓글 생성 삭제댓글 목록 조회결론1. 개요처음에는 최대 2depth의 대댓글을 구현하고 이후 추가적으로 무한 depth의 대댓글을 구현해보았다.depth가 늘어날수록 계층 구조를 효율적으로 관리하고 성능, 댓글 정렬등 고려해야 할 상황이 많다.아래 어떤 알고리즘을 사용했고 구현했는지 차근차근 정리를 해보았다. 2. 최대 2depth 댓글2-1. 댓글 생성 삭제기본적인 요구사항은 다음과 같다.계층별로 오래된순으로 정렬을 한다.하위 댓글이 모두 삭제되어야 상위 댓글을 삭제할 수 있다.하위 댓글이 X, 댓글 즉시 삭제하위 댓글이 O, 댓글 삭제 표시여기서 댓글 2를 삭제하게 돠면 아래와 같다.댓글2 하위 계층에 댓글5가 존재하기 때문.. 2025. 2. 20.
Github Actions으로 Sonar Cloud와 Slack 알림 설정하기 목차개요시나리오 소개사전 작업 구성워크플로우 구성마치며1. 개요Github Actions를 이용하여 CI/CD 파이프라인 구성에 대한 이해를 해보려고 한다.Github Actions는 Github 레포지토리를 이용해 간단하게 설정하고 사용하기 쉽다. 별도의 서버나 외부서비스를 구축할 필요 없이 Github에서 제공하는 기능으로 CI를 실행할 수 있기에 Github Actions를 선택하였다.2. 시나리오 소개요구사항특정 path 에 대해서만 실행 (multi-board에 src/**)main branch로 PR이 생성 & 동기화 될 때 테스트 작업 실행 (CI)PR이 main으로 merge 되면 배포 (CD)배포 성공 여부 슬랙으로 전송위에 요구사항을 반영한 대략적인 플로우는 다음과 같다.main bra.. 2025. 1. 23.
운영환경에서 안전하게 테이블 칼럼을 추가하려면 어떤 방법이 좋을까? 목차개요한 번에 처리하는 방법왜 3단계로 나눠서 작업해야 할까?결론1. 개요진행하고 있는 프로젝트는 게시판 프로젝트인데, 한 번에 생각으로 설계하고 만드는 것이 아닌 요구사항이 추가된다고 생각하고 점진적인 게시판을 만드는 프로젝트이다. 기본적인 게시판에 필요한 API를 만들었고 해당 테이블의 칼럼은 아래와 같다.  post 테이블의 식별자인 id, 제목인 title, 내용인 content 만 가지고 있었다. 근데 클라이언트 측에서 조회 수 기능이 있으면 좋겠다고 하면서 요구사항을 던져주셨다. Client : “post 테이블에 조회수 칼럼 넣어주세요~”Server : “네~”Server : 뚜따뚜따 “ALTER TABLE post ADD COLUMN view_count”Server : “반영했습니다~”C.. 2025. 1. 12.
2024년 개인 회고 올 한해는 내가 했던 결정들에 대해 다시 되돌아 보는 일이 많았다.0. 퇴사2023년 12월말 다니던 회사에 희망퇴직을 했고 1년이 지났다.퇴사 직후, 2024년의 시작은 고민과 설렘이 함께 공존했다. “개발자로써 지금 잘하고 있는 걸까?”“퇴사를 선택한 것은 좋은 선택이었을까?”“올해는 내 자신이 더 성장할 수 있을까?”등등..1. 생활여행여러가지 복합적인 생각을 하며 1월에 제주도로 계획없이 여행을 떠났다.제주도 가면서 저가비행 위주로 탑승하였고 이번에 처음으로 아시아나를 타봤는데 확실히 달랐다. 앞 의자에 스크린이 있었고, 비행시간이 짧은데도 쥬스를 챙겨주었다. 제주도 비행하면서 쥬스를 처음 먹어봤다..(진에어, 티웨이, 제주항공 등등.. 제주도가면서 쥬스를 먹은적이…?)제주도에 도착하자 먹으러 갔.. 2025. 1. 3.