웹 페이지는 어떻게 변하는가 ? 새로고침을 한다는 것은 새로운 요청을 보낸다는 뜻인데, 요청없이 응답이 오는 경우가 있다. 온라인 체스 게임에 임할 때, 우리는 새로고침을 하지 않아도 상대가 말을 움직이는 것을 볼 수 있다. 하지만 http 프로토콜에서는 요청이 있어야 응답을 보낼 수 있다. 전통적인 http 프로토콜에서, 클라이언트에서 응답이 없는데 서버에서 요청을 보낼 수 있을까? 그것은 불가능하다. 전통적인 http 통신서버와 유저가 데이터를 주고받는 방법에는 여러가지가 있다 (ex) http 요청) 유저가 http 요청을 날리면, 서버가 데이터를 보내주는 식으로 구현이 된다. http 요청을 쉽게 비유하자면 문자메세지와 비슷하다. 서버가 문자를 확인하면 답장으로 데이터를 보낸다. 고유한 특징이 ..
Express + TypeScript 사용하여 bun 환경에서 프로젝트 : 1. bun --help를 통해 bun설치여부 확인 2. bun init -y 로 기본 프로젝트 3. bun run index.ts Hello via Bun! 출력 확인하면 끝. Express 는 자유롭다.하지만 그 자유로움에는 책임이 따른다.. NestJS ? NestJS는 서버 개발 시의 아키텍처를 누구든 비슷하게 설계하도록 아키텍처 문제를 해결하는 데 중점을 두고 있다. - Node.JS 에서 실행하는 서버사이드 프레임워크 - 타입스크립트 완벽 지원 - 자바스크립트의 최신 스펙을 사용하므로, 바닐라 자바스크립트를 사용한다면 babel 사용이 필수 - HTTP요청 부분은 추상화된 코드를 제공해, 익스프레스와 Fastify를 사..
Bun에 대하여... 자바스크립트 엔진이란 우리가 작성한 자바스크립트 코드를 컴퓨터가 특정 작업을 수행할 수 있는 기계어 코드로 변환하는 프로그램. Node.js는 크롬 브라우저를 구동하는 구글의 V8 엔진을 사용하는 반면, Bun은 애플에서 사파리용으로 개발한 오픈 소스 자바스크립트 엔진인 JavaScriptCore(JSC)를 사용 JSC는 실행 시간은 약간 느리지만, 시작시간이 빠르며 메모리 사용량 감소를 우선시한다. V8은 런타임 최적화를 통해 빠른 실행을 우선시 하기 때문에, 메모리 사용량이 늘어날 수 있다.따라서Bun 은 Node.js보다 최대 4배 더 빠르게 시작할 수 있다. Bun은 런타임에 자바스크립트 트랜스파일러가 통합되어 있어 .js, .ts, .jsx, .tsx파일을 직접 실행할 수 ..
모든 API 는 async await 을 사용해 구분한다. MongoDB 연결 유틸리티 만들기 API 호출시 데이터를 저장, 조회, 삭제하려면 DB와 연결해야한다. 몽고디비 커넥션을 반환하는 유틸리티 함수를 만들어서 사용 mongodb-connection.js const {MongoClient}= require('mongodb'); const url = "mongodb+srv://wjdwwidz:@cluster0.5fd3khr.mongodb.net/board" module.exports = function(callback){ return MongoClient.connect(url, callback); } app.js ... let collection; app.listen(3000, async()=>{ c..
익스프레스 설치 npm i express@4.17.3 npm i mongodb@4.13.0 프로젝트 디렉터리 구조 잡기 보통 모든 기능을 제공하는 풀스택 프레임워크는 디렉터리 구조를 강제한다. (ex)Django) 반면 마이크로 프레임워크는 디렉터리 구조를 강제하지 않는다. 익스프레스 또한 강제하는 부분이 거의 없다. 보편적으로 사용되는 3계층구조 아키텍처(컨트롤러, 서비스, 데이터 엑세스) 를 사용하여 개발 (웹 프레임워크에서 사용하는 MVC 패턴을 적용하기에도 좋음) - 컨트롤러 : 뷰에서 넘어온 요청을 받아서 권한 체크, 유효성 검증을 한 후에 서비스 계층으로 넘어감 - 서비스 : 비즈니스 로직 처리 - 데이터 엑세스 : 서비스 계층과 데이터를 주고받음 API들이 많지 않으므로 라우터와 컨트롤러 코..
npm uninstall 명령어로 라이브러리를 제거했지만, package.json를 확인했을 때 dependencies 태그 안에서는 삭제되지 않았다. npm uninstall 명령은 패키지를 제거하지만, package.json파일을 업데이트 하지 않는다고 한다. 이것은 명시적으로 명령을 내려야만 package.json파일을 업데이트 할 수 있다는 뜻.. 1. 수동으로 제거 npm uninstall명령을 실행한 후에, package.json파일을 열고 해당 패키지가 여전히 나열되어 있는지 확인한다. 이후 수동으로 제거한다. 2. --save 또는 -s 옵션과 함께 사용 npm uninstall 패키지이름 --save 3. npm prune 패키지 제거 (uninstall) 실행 이후 npm prune 을..