2022/07 4

5년차 개발자의 이직 회고록

제목을 저렇게 쓰니 거창해 보이는데 어쩌다 보니 벌써 만 4년 동안 개발자로서 직장생활을 하였다. 두 번째 직장 1년 반 만에 원하는 직무가 아닌 곳에서 고여가는 나를 되돌아보며 이 정도면 충분히 쉬었다 판단하고 원하는 직무로의 이직 결심을 하였다. 그렇게 세 번째 직장을 찾은 도전기를 두서없이 적어보려 한다. 지원한 회사가 10군데가 넘는다. 올해 2월 말 처음 서류접수부터 최종 합격 이메일을 받은 7월 말까지 총 6개월이 걸렸고, 중간에 최종면접에서 탈락하면서 현타로 잠시 쉬기도 했었다. 서류나 코테 탈락은 스킬셋이 안 맞았거나 내 역량이 애초에 부족했던 것이니 패스하고 면접까지 갔었던 회사들 위주로 적어보겠다. 공교롭게도 면접 본 회사명이 모두 N사이다. 먼저, 이직 팁은 다음과 같다. 정말 가고 ..

일상/리뷰 2022.07.30

gRPC

무엇인가? Google에서 개발한 RPC(Remote Procedure Call) 시스템 전송을 위해 TCP/IP 프로토콜과 HTTP 2.0 프로토콜 사용 IDL(Interface Definition Language)로 ProtoBuf 사용 어떨 때 사용하나? 최근 많은 회사에서 MSA구조로 서비스를 개발하고 있다. MSA 단점 중 하나로 동일 머신에 존재하지 않는 분리된 모듈끼리의 네트워크 통신 overhead 이슈가 있는데 이에 REST API 대신 gRPC를 도입하는 것으로 해결한다고 한다. 어떻게 해결하는지 알아보도록 한다. HTTP 2.0 프로토콜 HTTP1.1 은 기본적으로 client가 server로 요청을 보내고 응답을 받는 구조이다. 요청 단위가 client와 server를 왕복하고, c..

develop/etc 2022.07.21

실행계획 explain

쿼리 튜닝 및 최적화시 사용하는 explain에 대해 복습해보려 한다. DB는 mysql/mariadb 기준이다. - 실행할 쿼리 앞에 EXPLAIN 키워드를 붙이면 각 단계별 실행 계획 결과가 출력된다. EXPLAIN Format = JSON을 추가하면 cost 등 더 자세한 정보를 알 수 있다. 주요 키워드들을 나열해본다. table 어떤 테이블에 대한 접근을 표시하고 있는지 id select에 붙은 번호, 보통 join을 하나의 단위로 실행하기 때문에 id는 그 쿼리 실행 단위를 식별하는 것이다. 따라서 조인만 수행하는 쿼리에서는 id는 항상 1이다. partitions 파티셔닝이 되어 있는 경우에 사용되는 필드이다. 파티셔닝 안되어 있는 경우엔 NULL type 접근방식을 표시하는 필드로 테이블에..

develop/etc 2022.07.12

REST API

정의 REST 아키텍쳐 스타일에 부합하는 API 그렇다면 API란: client와 server 사이 대화의 규칙 URI를 통해 자원을 지정하고, HTTP 메서드를 통해 자원에 대한 행위(CRUD)를 표현한다. post, get, put, delete 자원이란: 이름을 지닐 수 있는 모든 정보, 개념적인 대상, 객체라고 볼 수 있으며, 상태 변화 가능하다. → 변하지 않는 식별자가 필요하다 → URI를 통해 자원을 식별해야 한다! 표현을 통한 자원에 대한 조작 (REpresentational State Transfer) 자원의 현재 상태와 자원의 기대되는 상태를 URI로 표현함 표현을 client와 server가 서로 주고 받게 된다 서버가 변해서 Response Data가 변경되었다. 그럼 클라이언트에서..

develop/etc 2022.07.09