전체 글(341)
-
더 똑똑한 기술 블로그 운영하기 (feat. 카일스쿨)
예상 독자글쓰기의 벽을 마주한 4년차 기술 블로거의 고민과 향후 Action Item 을 읽고 싶은 분카일스쿨의 인프런 "실용주의 기술 블로그 글쓰기" 강의 후기가 궁금하신 분 서론 : 강의 수강 계기기술 블로그를 운영한지 어연 4년차, 관성으로 블로그를 운영하고 있지만 스스로 운영 방식이나 글쓰기 파이프라인에 대해 깊은 고민을 해 본 경험이 적다. 그간 글또 운영 기간에만 글을 발행한 것은 아니니 강제성이 없어도 글은 잘 발행하는 편이라 생각하지만, 그 빈도나 주기가 불규칙하여 스스로 글쓰기 시스템을 만들고 싶었다. 그리하여 시스템 없이 냅다 글 부터 쓰기 바빴던 습관을 조금씩 체계화 하고자 실용주의 글쓰기 강의를 수강하게 됐다. 수강 후 모든 내용을 정리한 것은 아니며, 내가 4년동안 블로그를 운영하..
2024.12.13 -
네 번째 회사에 이르기 까지
2022년 8월 8일은 두 번째 입사 보다 강남 대홍수의 날로 또렷이 기억한다. 물난리 속에서 사당에 자리 잡은 고시원으로 몸을 옮겼고, 내 몸 하나 딱 채울 수 있는 작은 침대와 적어도 이 물난리에 쓰러질 일 없는 고시원 천장에 감사하며 서울의 삶을 시작했다. 그게 이토록 지난한 서울살이의 시작일 것이라곤 생각도 못 했다. 2024년 11월 25일, 네 번째 회사의 최종 오퍼 메일을 받았다. 10월 초의 서류 접수를 시작으로 근 2달간의 채용 과정을 마무리할 수 있었다. 다른 회사의 전형은 아직 끝나지 않았지만, 오퍼를 받은 회사는 이전부터 관심을 가진 곳이라 최종 선택하게 됐다. 사실 이직 기간이 생각보다 길어지면서 정신도 점점 지치는걸 느껴 여기까지 하는 게 맞다고 생각했다. 2년 전 첫 이직 회..
2024.11.30 -
Raft 합의 알고리즘
https://hugehoo-blog.vercel.app/blog/DistributedSystems/Raft%20Consensus%20Algorithm https://hugehoo-blog.vercel.app/blog/DistributedSystems/Raft%20Consensus%20AlgorithmRaft 논문을 선택한 이유 작년에 참여한 카프카 소모임에서 zookeeper 대신 kraft 가 등장할 것 이란 얘길 들은적이 있다. 카프카도 kraft도 모르던 시절이라 어떻게 주키퍼를 대체한다는 건지, 막연한hugehoo-blog.vercel.app⬆️ 위 블로그에 내용을 보완하여 새로 작성했습니다. 해당 링크를 누르시면 더 가독성 좋은 아티클을 읽으실 수 있습니다 😃 Raft 논문을 선택한 이유작..
2024.11.09 -
테크 블로그 모아보기 개발 기록 (2) : Go 언어와 서버리스 프레임워크
서론이 글은 Golang 어플리케이션을 Serverless framework 를 이용해 AWS Lambda 에 배포하는 과정을 다룬다.현재 운영중인 사이드 프로젝트(🔗 테크 블로그 모아보기) 는 Go 언어를 기반으로 AWS Lambda(이하 람다)에 배포되어 있다. 처음 람다를 배울 땐 AWS Console 에서 일일이 API Gateway 를 설정하고 Lambda 함수의 코드를 직접 작성한 기억이 나는데, 당시만 해도 간단한 파이썬 함수를 호출하는 정도라 AWS Console 에 코드를 복붙하는 정도로 람다를 맛보기 했다. 하지만 실제로 운영할 애플리케이션 코드는 단순 복사 붙여넣기로 람다에 배포할 수 없었다. 파일 수도 많을 뿐더러 매번 배포할 때 마다 그런 번거로운 일을 할수도 없기 때문이다. ..
2024.10.22 -
테크 블로그 모아보기 개발 기록 (1)
서론글또 4년 차면 글을 쓰는 것뿐만 아니라 좋은 글을 찾아 읽는 것도 즐기게 된다. 여러 회사의 테크 블로그를 자주 챙겨 읽는데 매번 업데이트가 되는지, 안되는지 알 수 없으니 직접 페이지를 방문하는 수밖에 없었다. 카카오페이 같은 경우는 감사하게도 새로운 글이 올라올 때마다 링크드인에 노티를 주지만 그렇다고 모든 회사를 팔로우 할 순 없는 노릇이었다.해결해야 할 문제가 얼마나 고통스러운지, 이걸 해결하면 얼마나 많은 사람들이 편안해지는 지에 따라 문제의 중요성을 파악하곤 하는데, 냉정하게 말해서 직접 블로그를 방문하여 새로운 글을 확인하는 게 그리 고통스러운 일은 아니다. 단지 조금 귀찮았을 뿐.. 그래서 나도 아주 약간의 노력만 들여 이 문제를 조금 편하게 만들어보자는 마음에 🔗 테크 블로그 모아..
2024.09.30 -
[Go] goroutine 과 channel 로 API 실행 시간 개선하기
목차- 서론- 동기식 호출- 비동기 호출 : Goroutine 활용- 비동기 호출 개선 : Channel 활용- 결론 서론여러 테크 기업의 기술 블로그를 읽기 좋아합니다. 다만 매번 여러 블로그 홈페이지를 방문하다 보니 자주 가는 블로그는 따로 모아서 읽고 싶은 생각이 들더라고요. 이를 위해 Go를 활용한 테크 블로그 스크래퍼를 개발하기로 했습니다. 이미 그런 서비스는 많지 않냐고요? 맞습니다. 그래도 한번 직접 해보고 싶었습니다🙃.기업의 블로그들은 다양한 플랫폼을 활용합니다. Medium 부터 자체 블로그를 운영하는 곳까지, 다양한 방식의 기술 블로그를 제공합니다. 각기 다른 형태의 플랫폼을 사용하기 때문에 그에 맞는 스크래핑 방식을 사용해야 합니다. 저는 블로그 플랫폼에 맞는 스크래핑 구현체를 만..
2024.09.13 -
[후기] DB Internals 책 스터디 후기
주절주절 기록하는 8주간의 기록 (책 얘기 별로 없어용) 작년 글또에서 진행한 스터디 뒷풀이가 정기 술 모임으로 변질된지 1년째.간만에 모인 스터디원들과 신나게 떠들다가 동인님의 추천으로 새로운 스터디에 (갑자기) 참여하게 됐다.마침 백수 기간이라 시간적 여유도 있었고 평소에 들어보지 못한 생소한 책이라 호기심도 생겼다.내가 참여한 스터디는 LIVID 에서 주관하는 DB Internals 책 스터디로 총 8주간의 커리큘럼이 예정되어 있었다. 결론부터 말하면, 8주간의 스터디가 끝나고 딱 아래의 짤이 떠올랐다.합의 알고리즘... 해치웠나? (아니요)분산 시스템.. 해치웠나? (nope) 3년을 겨우 채운 백엔드 개발자가 읽기엔 아직 버거운 책이라 느꼈졌다.불과 3달 전에 겨우겨우 데이터 중심 애플리케이션..
2024.09.10 -
도커 컨테이너 Go 서버가 SIGTERM 을 무시한 이유 (feat. PID 1)
배경Go 애플리케이션을 종료할 때 특정 로직을 수행하고자 했습니다.사용자가 수동으로 (로컬) 서버를 종료하면 syscall.SIGINT 값이 channel 에 할당되면서 goroutine 내부가 실행되어로직 수행 후 애플리케이션이 종료(os.Exit(1)) 됩니다.실제로 로컬에서 서버를 실행하고 ctrl + C 명령어로 서버를 종료하면 goroutine 내부 로직이 잘 실행됐습니다.func (s *Server) StartServer() error { s.setServerInfo() channel := make(chan os.Signal, 1) signal.Notify(channel, syscall.SIGINT) // (1) 단순 종료 시그널 go func() { 도커 컨테이너화 후에도 잘..
2024.09.10 -
[DB] Select For Update 란? (feat. 조회와 업데이트)
SELECT ~ FOR UPDATE 란일반적인 SELECT 구문은 락을 사용하지 않습니다. 락을 획득하지 않아도 데이터를 조회할 수 있죠.하지만 간혹 조회 시점에도 락이 필요한 경우가 있습니다. 예를 들어 정산 시점을 생각해보면, 정산시간 동안은 해당 조회 트랜잭션에서 read 중인 데이터를 다른곳에서 수정하면 안됩니다. 이럴 경우엔 SELECT FOR UPDATE 구문을 사용해 조회 중 수정을 방지할 수 있습니다.쉽게 말해 '내가 데이터를 조회하는 동안은 이 데이터를 수정하지마!' 라고 표현할 수 있고,기술적으로 표현하면 동시성 제어를 위해 특정 Row 에 배타적 LOCK 을 거는 것이라 할 수 있습니다. 실습 server_info 테이블 대상으로 Select for update 쿼리를 실험해보겠..
2024.09.06