express.js 환경에서 사용하십시오. 어떤 제안?
express.js 환경에서 사용하십시오. 어떤 제안?
답변:
앱을 실행하기 전에 콘솔에서이 작업을 수행 할 수 있습니다.
export NODE_ENV=production
또는 창문에 있다면 이것을 시도 할 수 있습니다.
SET NODE_ENV=production
또는 다음과 같이 앱을 실행할 수 있습니다.
NODE_ENV=production node app.js
js 파일에서 설정할 수도 있습니다.
process.env.NODE_ENV = 'production';
그러나 서버에서 VIM을 열고 프로덕션으로 변경하는 것은 쉽지 않기 때문에 런타임 파일에서 수행하지 않는 것이 좋습니다. 디렉토리에 config.json 파일을 만들 수 있으며 앱이 실행될 때마다 파일을 읽고 구성을 설정합니다.
process.env.NODE_ENV
앱 자체에서 안정적으로 설정하는 것이 까다로울 것입니다. Daniel이 아래에 링크 한대로 환경 변수를 올바르게 설정하십시오.
NODE_ENV
두 번째 예 ( NODE_ENV=production node app.js
) 와 같이 앱을 실행할 때마다 명시 적으로 설정하는 팬입니다 . 그렇게하면 지역을 NODE_ENV
다시로 설정하는 것을 잊어 버린 경우 미래의 헤어 풀림으로부터 자신을 구할 수 development
있습니다.
cross-env NODE_ENV=production
Windows 및 Linux / Mac에서 작동합니다.
NODE_ENV=production forever app.js
가 작동해야합니다.
package.json에서 :
{
...
"scripts": {
"start": "NODE_ENV=production node ./app"
}
...
}
그런 다음 터미널에서 실행하십시오.
npm start
NODE_ENV=production
package.json을 넣는 것은별로 의미가 없습니다. 실행 npm start
개발하는 것은 생산에서 실행됩니다. 항상 그런 식으로 코드를 실행하기 때문에 코드가 항상 프로덕션 인 것처럼 코드를 작성할 수 있습니다. 이 작업을 수행하는 한 가지 이유는 다른 모듈 (예 : Express)이 프로덕션 모드에서 실행되도록하기위한 것입니다. 절대 변하지 않는 환경 변수를 사용하는 이유는 무엇입니까?
.env
아직 여기에 언급 된 사람이 없습니까? 메이크업 .env
후, 앱 루트에 파일을 require('dotenv').config()
하고 값을 읽습니다. 쉽게 변경하고 쉽게 읽을 수있는 크로스 플랫폼.
"mode": "production"
위해 .env
파일 설정 이 효과가있었습니다.
export NODE_ENV=production
나쁜 해결책이며 다시 시작한 후에 사라집니다.
해당 변수에 대해 더 이상 걱정하지 않으려면이 파일에 추가하십시오.
/etc/environment
내보내기 구문을 사용하지 말고 작성하십시오 (일부 내용이 이미있는 경우 새 줄로 작성).
NODE_ENV=production
다시 시작한 후에 작동합니다. 언제 어디서나 export NODE_ENV = production 명령 을 다시 입력하지 않아도되고 원하는 노드 만 사용하면됩니다. pm2 ...
헤 로쿠의 경우 :
heroku config:set NODE_ENV="production"
실제로 기본값입니다.
NODE_ENV=production gulp bundle-production-app
프로덕션 준비 스크립트를 번들로 사용 하는데, NODE_ENV 서버는 서버 환경에 있고 dev 머신에는 없습니다. 일부 컴퓨터에서는 설정되지 않은 경우 항상 악의적 입니다. 어떤 경우에는 가지고 있지 않을 것으로 예상되므로 추가하지 마십시오. 어쨌든 UI를 수행하는 동안 개발 모드에 있는지 명확하게 알려주므로 UI가 켜져 있는지 꺼져 있는지에 대한 질문이 없습니다. 만약 NODE_ENV가! == production이라면 그것은 당신이 다른 모드에있는 것이기 때문에 악몽이 아닙니다. 모두 명확하고 좋습니다.
/etc/environment
및 실행 export NODE_ENV=production
?
Windows, Mac 또는 Linux에서 스크립트를 실행 중인지 걱정하지 않으려면 cross-env 패키지를 설치하십시오 . 그러면 다음과 같이 스크립트를 쉽게 사용할 수 있습니다.
"scripts": {
"start-dev": "cross-env NODE_ENV=development nodemon --exec babel-node -- src/index.js",
"start-prod": "cross-env NODE_ENV=production nodemon --exec babel-node -- src/index.js"
}
이 패키지의 개발자에게 대규모 소품.
npm install --save-dev cross-env
heroku config:set NODE_ENV="production"
NODE_ENV=production
이제 Heroku node.js 배포의 기본값입니다.
당신이 창문에 있다면. 오른쪽 폴더에서 cmd를 연 다음 먼저
set node_env={your env name here}
Enter 키를 누르면 노드를 시작할 수 있습니다
node app.js
그것은 당신의 환경 설정으로 시작됩니다
여러 환경을 유지하려면 이전에 모든 답변이 필요하지만 (NODE_ENV 매개 변수 및 내보내기) 아무것도 설치하지 않고도 매우 간단한 방법을 사용합니다. package.json에 필요한 각 환경에 대한 스크립트를 다음과 같이 넣으십시오.
...
"scripts": {
"start-dev": "export NODE_ENV=dev && ts-node-dev --respawn --transpileOnly ./src/app.ts",
"start-prod": "export NODE_ENV=prod && ts-node-dev --respawn --transpileOnly ./src/app.ts"
}
...
그런 다음 npm start
use 를 사용 하는 대신 앱을 시작하십시오 npm run script-prod
.
코드에서을 사용하여 현재 환경에 액세스 할 수 있습니다 process.env.NODE_ENV
.
짜잔
Daniel은 올바른 배치 (설정 및 잊어 버림) 프로세스를위한 더 나은 접근 방식 인 환상적인 답변을 제공합니다.
급행을 사용하는 사람들을 위해. 당신은 또한 환상적인 grunt-express-server를 사용할 수 있습니다. https://www.npmjs.org/package/grunt-express-server