배경 보통 우리들은 코딩할 대 로그를 찍는다. 개발할 때는 로그를 직접 볼 수 있지만 배포하고 나서는 그렇지 않다. 우리는 24시간 컴퓨터 앞에서 어디서 오류가 나는지 확인할 수 없다. 이걸 효율적으로 하기 위해서는 어떻게 해야할까?? 바로 기록이다. 로그를 기록하면 된다. 사실 이전에 node교과서를 보면서 공부했었지만 대충 쓰고 넘어갔던 기억이 난다. 그때 제대로 공부해놨다면 우아한테크캠프에서 프로젝트를 하면서 winston으로 로그를 기록했을 것이다. 앞으로 그런 기회가 있다면 내가 나서서 winston을 적용해야겠다. winston 무작정 사용해보기 일단 문서를 보다가 생각보다 좀 길어서 적용부터 해보기로 했다. 일단 해보고 이런거구나 먼저 알아보자 logger.js const winston = ..
mysql installer를 눌러서 체크한부분으로 수정 아래 코드로 비밀번호를 바꾸거나 생성 후 FLUSH PRIVILEGES로 변경사항 즉시 변경 ALTER USER '[user]'@'localhost' IDENTIFIED WITH mysql_native_password BY 'password'; -- or CREATE USER '[user]'@'%' IDENTIFIED WITH mysql_native_password BY '[password]'; -- then FLUSH PRIVILEGES;
보통 react에서 서버에 axios로 요청을 한다. 그때 react와 서버에 각각 작업을 해줘야 한다. 이 글은 같은 컴퓨터의 다른포트로 사용하는 법을 적었다. 먼저 react에서 서버에 연결하기 위해서는(CRA사용 기준) package.json에 "proxy": "http://localhost:3001", 이렇게만 입력해주면 된다. proxy에 대해서는 다른 글에서 올리겠다. express에는 const corsOptions = { origin: "http://localhost:3000", }; app.use(cors(corsOptions)); 이렇게만 입력하면 된다.
오늘은 저번시간에 이어서 콜백지옥 탈출하는 법을 살펴보겠습니다. 저번에는 기본 내장 모듈으로만 탈출했습니다. 오늘은 mysql2를 이용해서 async await를 사용하겠습니다. 아래는 최근(현시점) mysql과 mysql2의 다운로드 숫자입니다. mysql2도 mysql만큼이나 사용자가 많은 것을 알 수 있습니다. asyn await을 사용하지 않는다면 기본적인 문법은 mysql2도 mysql과 같습니다. 정말인가? 하시는 분들은 npm install mysql2 로 설치하시고 var mysql = require("mysql"); => var mysql = require("mysql2"); 해보시면 됩니다. 이제 async await를 사용해보겠습니다. async function main() { con..
callback 지옥이란 callback함수의 중첩 때문에 코드가 너무 복잡해지는 것을 말합니다. 아마 자바스크립트를 사용하시는 분들은 한번 쯤 겪었을 문제입니다. 오늘은 express mysql에서 콜백지옥을 탈출하는 법을 쓸려고 합니다. 저번 글에서 promise와 async await를 다루었습니다. 오늘은 조금 더 응용해서 nodejs express mysql에서 promise, asyn await를 사용하는 방법을 알아보겠습니다. (nodejs express, mysql, promise, asyn await 중 하나라도 모르시는 것이 있으면 코드를 이해하기 힘들 수 있습니다.) 일단 mysql이외의 특별한 모듈은 사용하지 않겠습니다. (이 글은 promise, async await 입문자들을 위..
promise에 이어서 async await 사용법을 살펴보겠습니다. promise에 대해 모르신다면 https://ms3864.tistory.com/22 를 보고 오는것을 추천합니다. promise 사용법 오늘은 자바스크립트를 사용한다면 꼭 알아야만 하는 promise에 대해 알아보겠습니다. Promise는 프로미스가 생성될 때 꼭 알 수 있지는 않은 값을 위한 대리자로, 비동기 연산이 종료된 이후의 결�� ms3864.tistory.com async function 선언은 AsyncFunction객체를 반환하는 하나의 비동기 함수를 정의합니다. 비동기 함수는 이벤트 루프를 통해 비동기적으로 작동하는 함수로, 암시적으로 Promise를 사용하여 결과를 반환합니다. 그러나 비동기 함수를 사용하는 코드의 ..
오늘은 자바스크립트를 사용한다면 꼭 알아야만 하는 promise에 대해 알아보겠습니다. Promise는 프로미스가 생성될 때 꼭 알 수 있지는 않은 값을 위한 대리자로, 비동기 연산이 종료된 이후의 결과값이나 실패 이유를 처리하기 위한 처리기를 연결할 수 있도록 합니다. 프로미스를 사용하면 비동기 메서드에서 마치 동기 메서드처럼 값을 반환할 수 있습니다. 다만 최종 결과를 반환하지는 않고, 대신 프로미스를 반환해서 미래의 어떤 시점에 결과를 제공합니다. Promise는 다음 중 하나의 상태를 가집니다. 대기(pending): 이행하거나 거부되지 않은 초기 상태. 이행(fulfilled): 연산이 성공적으로 완료됨. 거부(rejected): 연산이 실패함. 콜백지옥을 탈출하기 위해서는 promise를 알아..