이 시리즈는 3개월간 Spring, Docker, Jetbrains ide, Non-standard libraries etc 하이레벨 기술을 사용하지 않고 서비스를 구현해보는 시리즈입니다. 누구보다 자동화, 숏컷, 프레임워크를 좋아하지만 너무 맹목적으로 기술에 의존하지 않기 위해 공부합니다. 또한, 개인이 작성한 블로그 글을 읽지 않고 공식 문서만을 읽으면서 공부하며 자동완성, 붙여넣기 기능을 사용하지 않습니다. 이 시리즈에서 주제는 웹을 주로 다루며 Stream과 Tomcat을 통해 서버를 구축할 것이고 Redhat 계열의 Linux을 이용하여 온프레미스 서버를 구축할 것입니다. 이 과정 중 문제가 발생하면 구글링보다는 공식문서를 더 읽어볼 것 입니다. 당연한 말이지만 AI는 절대로 이용하지 않습니다.
![[회고록] 2023년의 경험으로 가는 인생 방향성](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FcXhcm4%2FbtsBojc1k3U%2F3T3EEgPT96WUAJy7g2J3H1%2Fimg.png)
지방 기술 컨퍼런스 참여 이번년도 들어서 기술 컨퍼런스에 대해 많은 관심이 생겼습니다. 학술동아리(이후 메가브레인.) 선배들과 어떻게하면 지방에서 좋은 개발자가 될 수 있을까 이야기를 나누던 중 저희는 애초에 경남권에서 진행하는 기술 컨퍼런스조차 찾아보려 하지 않았다는 것을 깨달았습니다. 뉴스와 유튜브에서 항상 지역 인프라의 차이, 지방 소멸만 이야기하니 우리 지역 진행하는 개발 행사는 별로일거라고만 생각하고 있었습니다. 그래서 근처 지역인 부산권 기술 컨퍼런스에 최근 1주간 참여했습니다. 센텀 디지털 위크 2023(부산 센텀을 판교 뛰어넘는 디지털 혁신 중심지로 만든다는 바로 그 사업), DevFest Busan 2023 에 참여했습니다. 실제로 참가해보고 느낀점은 제 생각보다 부산권의 컨퍼런스는 질이..

rB - e - e - x - j - j - ^x - w - w - l - rt - e - x
![[MySQL 복구 2] binlog를 통해 데이터베이스 복구하기](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2F93GAi%2Fbtstksvewaj%2FpjsI6IXblUGg86HndqQCe0%2Fimg.png)
로컬 환경에서 ibd 파일을 이용하여 데이터를 복구하려고 했습니다. 일부 테이블이 스키마 불일치 문제로 복구되지 않아서 바이너리 로그로 복구를 진행해봤습니다.혹시 저처럼 DB를 날려버리신 분들을 위해 제 삽질과 더 빠른 DB 복구를 위한 본 글을 작성합니다. 도움이 되었으면 좋겠습니다. 이해하기MySQL에는 바이너리 로그라는 파일이 존재합니다. 사용자가 사용했던 쿼리들이 기록되어 있는 파일입니다. (SELECT는 예외)DB 생성 시부터 binlog.000001으로 매일 binlog 파일이 생성되며 1씩 증가합니다.MySQL에 설정되어 있는 binlog 보존 기간만큼만 저장되다, 보존 기간을 초과한 파일은 삭제됩니다. 때문에 binlog 파일이 1부터 시작하지 않는다면.. 이미 옛 binlog 파일들은 삭..
![[MySQL 복구 1] .ibd 파일을 이용하여 데이터 복구하기](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FBDMyl%2FbtstlkXNWNS%2FpQs3NJMOVsjkBBT6xu6UAK%2Fimg.png)
혹시 저처럼 DB를 날려버리신 분들을 위해 제 삽질과 더 빠른 DB 복구를 위한 본 글을 작성합니다. 도움이 되었으면 좋겠습니다. 이해하기데이터 복구를 시작하기 전에 복구에 필요한 데이터를 설명드리겠습니다..ibd 파일: 각 테이블의 데이터가 저장된 파일(InnoDB)MySQL: ibd파일을 생성했던 MySQL 동일한 버전의 MySQL(완전히 동일해야 합니다.).frm 파일: 각 테이블의 스키마가 저장된 파일(8.0 버전부터 삭제됨).ibd파일은/var/lib/mysql/{database_name}/{table}.idb 이런 경로로 존재합니다. 데이터베이스 구동 환경 구축삽질을 하며 시간이 DB 구축과 삭제를 너무 많이 하게 되어서 docker-compose.yml으로 환경을 구축하였습니다. # dock..
![[NestJS] eslint를 작성해보자.](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2F3Euz2%2Fbtsr5hfNOKs%2FI4QLFgjXtubf7SQ7XfBYyK%2Fimg.png)
eslint 수정을 결심하게 된 계기기존의 eslint는 프론트 중심적으로 작성되어있거나, git diff 리딩에 불편하게 되어있어요. 개요tab indent를 4로 변경했어요.javascript는 tab indent를 2로 권장하지만, 백엔드에서는 early return 패턴을 사용하기 때문에 tab depth가 깊어질 일이 없어요.코드 가독성은 향상시키고 node.js 특유의 코드 편집기 우측이 텅텅 비어있는 것을 해결했어요.array, object 구조를 설정했어요.백엔드는 array, object가 길어질 경우가 많은데, 이런 경우 예외처리가 되어있지 않아요.eslint 기능을 사용하여 제약을 걸어 해결했어요.그 외도 코드리딩을 고려해서 작성했어요.git diff를 읽을 때 온점이나 쉼표 혹은 괄..

Github 컨벤션은 목적에 따라 필요할수도 있고, 오히려 과할 수도 있습니다. 팀단위로 진행하는 프로젝트에서 컨벤션이라는 추상화를 통해 불필요한 커뮤니케이션을 줄일 수 있어 유용하며, 이후 취업 준비 중에는 본인의 역량을 github issue, PR에 깔끔하게 정리하여 깔끔하고 매력적인 포트폴리오를 만들 수 있습니다. 글에 들어가기 앞서 본 컨벤션이 적용된 Repository와 Github Convention 정리 글을 알려드립니다. 경남 경매 서버 레퍼지토리(Spring boot) 경남 경매 서버 레퍼지토리 서버 코드 github.com Code Convention 경남 경매 서버 레퍼지토리 컨벤션 Wiki github.com 내가 선정한 올바른 Github Convention의 조건 각자가 맡은 ..

서론 학교 애플리케이션을 개발 중, 학생증 사본을 통해 학생 인증을 하는 기능을 구현하려고 합니다. 사용 기술: nest.js 9.4.1 node-telegram-bot-api 0.61.0 aws s3, ec2 결과물: 실제 운영되는 프로덕션입니다. 1. telegram 봇 발급 이번에 구현 방식을 조사해보며 telegram을 선택하게 된 이유는 아래와 같다. p2p 방식으로 높은 기밀성 빠르게 개발할 수 있는 개발자 친화적 플랫폼 1. BotFather 검색 후 추가 2. /start 명령어를 입력하여 채팅을 시작해주세요. 3. /newbot 명령어를 입력하여 새로운 봇을 만들어주세요. 4. 봇 이름을 입력해주세요. 네이밍 규칙은 마지막이 bot으로 끝나면 됩니다. (대소문자 무관) 이름이 이미 존재하..

서론 면접 질문으로 크롬의 탭은 프로세스인지 스레드인지, 그리고 왜 그렇게 생각하는지에 대해 질문이 왔다. 이 글에서는 브라우저가 탭을 어떻게 관리하는지, 그리고 왜 그렇게 관리하는지를 조사해보려구 한다. 고맙게도 Chrome Developer Blog에서 브라우저 관련 내부 동작 원리를 설명해주는 글이 있다. 이 글에서도 설명하겠지만, 자세한 내용은 아래 내용 참고. 웹 브라우저의 내부 살펴보기 크롬의 탭은 프로세스다. (멀티 프로세스) (나는 프로세스로 답했다가, 경량화 문제를 의심하고 멀티 스레드라고 답을 바꿨다.) 크롬은 멀티 프로세스를 사용하며 IPC(Inter Process Communication, 프로세스 간 통신)을 사용한다. 만약, 특정 탭이 응답하지 않을 때는 동작하지 않는 탭의 프로..

면접 막 끝나고 바로 면접 후기를 씁니다.. 면접 진행 zoom으로 비대면으로 진행 각 면접 대기실으로 입장되고 면접 시간이 되면 소 회의실로 옮겨짐. 2:2 30분으로 진행되었으며, 저와 면접을 같이본 분은 경험 많은 고수분.. 질문 목록 면접 안내 중 면접 질문 목록을 공유하지는 말라는건 없었으니 작성하겠습니당. 문제있으면 메일주세요! 면접은 개인의 포폴 및 자소서에 맞춰서 한다. 나는 CS공부를 했던것을 적어서 CS질문이 몇가지 왔고, Nest.js라는 비주류 개발언어를 써서 그런지 프레임워크에 대한 질문은 안왔다. 인성 질문 프로젝트를 같이하지 싫은사람은? 그리고 그 사람이랑 팀이 되었다면? 기술질문 DB 트랜잭션 ACID에 대해 설명해라. 사용한 데이터베이스를 선택한 이유는 무엇인가? DB 인덱..

면접을 앞두고.. 내일은 NEXTERS 23기 백엔드 면접일이다. 이게 첫 NEXTERS 준비는 아니다. 22기에 서류를 지원했다가 떨어졌었기 때문이다. 이번 글에서는 면접을 보기 전에 전에 떨어진 사유를 복기 해보려고 한다. 22기를 떨어질 때.. 그 당시의 나는 1학년으로써는 꽤나 나쁘지 않았다. 스스로 프로젝트도 진행해보고 다른 팀원들과의 원활한 커뮤니케이션을 위해 slack, notion, trello 등을 공부했다. 이를 잘 어필해서 컴퓨터공학과 신입생으로써 SW마에스트로에 합격했다. 거품거품 열매 근데 SW마에스트로를 수료할 때 쯤, 나는 컴공 1학년이 아니라 SW마에스트로 13기 최약체였다. 주변의 평과 실제 내 실력에 괴리감이 느껴질 때 NEXTERS 22기를 지원했다. 거품 인간은 서류탈..
![[GO]클래스 없는 객체지향 언어](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FedggFw%2FbtshaqCLX6n%2FUfMqbTR66IgW6HjsiQyjOK%2Fimg.png)
서론 객체지향 프로그래밍(OOP) 패러다임으로 개발하다보면 class를 잘 사용하는 것이 잘하는 개발자일 것이다. 이번에 공부해본 GO 언어는 class를 사용하지 않는 객체지향 언어이다. 어떻게 class 없이 객체지향 프로그래밍이 가능한지 살펴보자. OOP의 3요소 캡슐화: 정보 은닉 상속: 재사용 + 확장 다형성: 사용편의 클래스스럽게만 사고하고 개발했다면 GO를 만났을 때 충격받을 것이다. GO는 코드의 간결성과 성능을 위하여 클래스 문법을 직접적으로 제공하지 않는다. GO의 객체지향 인터페이스 (Interfaces): 인터페이스는 함수의 집합으로 정의되며, 해당 인터페이스를 구현하는 구조체는 자동으로 인터페이스를 따르게 . 인터페이스를 사용하여 다형성을 지원하고, 코드의 유연성과 재사용성을 향상..
![[NestJS] TypeORM을 통한 트랜잭션 관리](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FPpiwp%2Fbtsdhz3tjrw%2FhSRU8I76gbNfIa3hPOgpK1%2Fimg.png)
서론 NestJS에서 관계가 묶여있는 여러 테이블에 INSERT를 해야하는 경우가 있습니다. 이 글에서는 TypeORM을 통해 트랜잭션을 관리해보겠습니다. 트랜잭션 관련 글 https://puleugo.tistory.com/142 데이터베이스 트랜잭션이란? 트랜잭션(Transaction) 트랜잭션: 데이터베이스 관리 시스템에서의 최소 상호작용의 단위 개요 데이터베이스 트랜잭션은 데이터베이스에서 수행되는 일련의 작업이며 모두 단일한 논리적 작업 단 puleugo.tistory.com https://puleugo.tistory.com/143 트랜잭션 격리 수준 데이터베이스 트랜잭션 격리 수준 데이터베이스 트랜잭션의 격리 수준은 격리성(각각의 트랜잭션은 서로 간섭없이 독립적으로 수행되어야한다는 규칙)의 견고함..

By. 공자 생각 없이 배우기만 하면 얻는 것이 없고, 생각만 하고 배우지 않으면 오류나 독단에 빠질 위험이 있다. 잘하는 개발자는 도적질을 일삼는다. 코드의 유지보수성보다 빨리 굴러가야하는 경우가 있다. 애자일이나 배포가 시급한 경우.. 그리고 항상 살아남는 코드는 동작하는 코드들이다. 코드 도적질은 빠르게 동작하는 코드를 얻을 수 있으며, 사고의 확장까지 할 수 있다는 이점이 있다. 이번 글에서는 어떻게 효율적으로 도적질을 하며 최신 도적질 트렌드를 알아보려고 한다. 글 컨셉 때문에 성장은 레벨업이라고 표현하겠다. 개발자가 되고 싶은 자는 나에게... 좋은 선례를 도적질하라. 회사의 기술 블로그나 공신력있는 개발자의 코드를 도적질해라. 코드가 없다면, 그 사람의 학습 방식을 도적질하라. 회사의 기술블..

개요 리프레시 토큰을 Redis에 저장한다는 사례를 들어서 직접 구현해봤습니다. Token Based Authenticaion, Refresh Token을 공부해보았습니다. 결론: 해당 방식은 비효율적이고 보안적 가치가 없는 방식이었습니다. What is Redis? 레디스는 인메모리 방식의 데이터베이스입니다. Diff Basic DB vs In-Memory DB 기존 DB(e.g. mysql, postgreSQL)은 보조기억장치에 데이터를 저장합니다. 그래서 많은 양의 데이터를 오래 저장하는 데에 적절합니다. 인메모리 DB(e.g. Redis, MemCache)는 주기억장치에 데이터를 저장합니다. 그렇기에 데이터 조회 성능이 월등히 빠릅니다. 주기억장치를 이용하기 때문에 RAM의 휘발성 메모리의 특징도..

서론 학교 백엔드 CS 스터디 중 카디널리티라는 키워드가 나왔습니다. 설명 들었을 때 처음듣는데 중요하다고 생각되어 조사해보고 정리해본 후, 개발했던 프로젝트 리팩토링을 진행하였습니다. 카디널리티(cardinality)이란? 우리 레코드를 조회할 때 인덱스를 정의합니다. 인덱스를 정의할 때 우리는 카디널리티가 높은 것을 사용합니다. 카디널리티란? 해당 컬럼의 중복된 수치를 말합니다. "성별, 학년, 국적 등은 카디널리티가 낮다"라고 말하며, 반대로 "학번, 주민등록번호 등은 카디널리티가 높다"라고 말합니다. 우리가 성별, 학년같은걸 인덱스로 잡진 않죠? 그렇다면 복합키(여러 컬럼을 인덱스로 구성)를 사용한다면 어떻게 될까요? 우선, 복합키의 예시를 가져와보겠습니다. 위 이미지의 user-auths 테이블..

팀원이 설정/수정한 알림이 내 폰에서 울려야한다. 서론 프로젝트를 전부 구현해놨더니 기획을 엎어버렸다. 내가 기획팀한테 타 서비스와의 차별성과 방향성이 애매하다고 하긴했지만, 이런 결과를 원한 것은 아니다.. ㅠㅠ 지인들은 기획팀을 엎으라고 했지만, 더 나은 결과물을 위한 것이니 좋게 생각하고 있다. 개선된 기획안은 이렇다. "열정은 있지만 팀프로젝트를 할 사람이 필요한 사람들에게 마음맞는 팀원을 구할 수 있는 TODO 및 캘린더 기능과 커뮤니티를 제공해준다." 여기서 TODO, 캘린더 기능이 팀 단위로도 설정할 수 있기 때문에 본인이 아닌 다른 팀원이 추가, 수정한 알람이 내 폰에서 울려야한다. 본론 FCM쓰면 되긴하는데 학생이니 구현 경험을 쌓고 싶었다.. 내가 조사해본 결과 우리 프로젝트에 가장 ..