>  기사  >  웹 프론트엔드  >  pm2를 사용하여 도메인 이름 구입부터 node.js 프로젝트 배포까지 전체 과정에 대한 자세한 설명

pm2를 사용하여 도메인 이름 구입부터 node.js 프로젝트 배포까지 전체 과정에 대한 자세한 설명

亚连
亚连원래의
2018-05-31 17:20:271444검색

이 글에서는 주로 도메인 이름 구입부터 pm2를 사용한 node.js 프로젝트 배포까지의 전체 과정을 자세히 소개하고 참고하겠습니다.

프론트엔드로서 작성된 프로젝트를 서버에 배포하는 방법에 대해 혼란스러웠지만 여전히 관심이 많았고 한번 시도해 보기로 결정했습니다.

1. 도메인 이름 및 서버 구입

프로젝트를 배포하려면 도메인 이름을 구입해야 합니다. Tencent Cloud에는 무료 서버가 있다는 것을 알았습니다(7일 동안만 무료). , 그래서 Tencent Cloud에 들어갔습니다. Tencent Cloud에서 도메인 이름을 구입하고 무료 서버를 받았습니다. 물론 이 기간 동안 실명으로 인증을 받게 됩니다.

도메인 이름 구입

서버 구입

Tencent Cloud에서 CentOS 서버를 선택한 후 도메인 이름 확인을 수행하고 서버를 설정합니다(계정 비밀번호 등)

도메인 이름 확인

2. Node.js 환경 배포

(1) 서버에 로그인하여 먼저 업데이트(서버를 처음 사용할 때 먼저 업데이트)

yum update -y

(2) 노드 설치 그리고 pm2

wget 명령을 사용하여 Node.js 설치 패키지를 다운로드합니다. 설치 패키지는 압축 해제 후 bin 폴더에 이미 node와 npm이 존재하므로 다시 컴파일할 필요가 없습니다.

wget https://nodejs.org/dist/v8.9.3/node-v8.9.3-linux-x64.tar.xz

파일의 압축을 풀어주세요.

tar xvf node-v8.9.3-linux-x64.tar.xz

node 및 npm 명령을 전역적으로 유효하게 만드는 소프트 링크를 만듭니다. 소프트 링크를 생성하면 모든 디렉터리에서 node 및 npm 명령을 직접 사용할 수 있습니다.

ln -s /root/node-v8.9.3-linux-x64/bin/node /usr/local/bin/node
ln -s /root/node-v8.9.3-linux-x64/bin/npm /usr/local/bin/npm

노드 및 npm 버전 보기.

node -v
npm -v

이제 Node.js 환경이 설치되었습니다. 소프트웨어는 기본적으로 /root/node-v8.9.3-linux-x64/ 디렉토리에 설치됩니다. 소프트웨어를 다른 디렉토리(예: /opt/node/)에 설치해야 하는 경우 다음을 수행하십시오.

mkdir -p /opt/node/
mv /root/node-v8.9.3-linux-x64/* /opt/node/
rm -f /usr/local/bin/node
rm -f /usr/local/bin/npm
ln -s /opt/node/bin/node /usr/local/bin/node
ln -s /opt/node/bin/npm /usr/local/bin/npm

pm2 설치

npm install pm2@latest -g

pm2 명령을 전역적으로 유효하게 만드는 소프트 링크를 생성하세요

ln -s /root/node-v8.9.3-linux-x64/bin/pm2 /usr/local/bin/pm2

3. 프로젝트는 git

을 사용하여 서버에 배포됩니다. 먼저 서버 루트 디렉터리를 입력하고 루트 디렉터리 폴더의 내용을 표시한 다음 var 디렉터리를 입력하고 var 디렉터리 아래에 새 www 폴더를 만들고 내용을 표시합니다. var 폴더의 www 폴더로 이동하여

cd /
ls
cd var
ls
mkdir www
cd www

last picture

명령을 실행한 다음 웨어하우스의 프로젝트를 git clone

먼저 git을 설치하고 다음 명령

yum install git
y

을 사용하여 들어갑니다. your project

위 그림을 보면 Express 프로젝트가 아닌 파일이 있는 것을 볼 수 있습니다. pm2의 구성 파일은 http://pm2.keymetrics.io/입니다. docs/usage/cluster-mode/

다음은 내 프로젝트의 구성입니다. (초보자, 전문가도 궁금한 점이 있으면 조언을 해줄 수 있습니다.)

{
 "apps": [
  {
   "name": "app1",
   "script": "bin/www",
   "log_date_format": "YYYY-MM-DD HH:mm:SS",
   "log_file": "logs/app1.log",
   "error_file": "logs/app1-err.log",
   "out_file": "logs/app1-out.log",
   "pid_file": "pids/app1.pid",
   "instances": 1,
   "min_uptime": "200s",
   "max_restarts": 10,
   "max_memory_restart": "1M",
   "cron_restart": "1 0 * * *",
   "watch": false,
   "merge_logs": true,
   "exec_interpreter": "node",
   "exec_mode": "cluster_mode",
   "autorestart": true,
   "vizion": false
  }
 ]
}

넷째, 프로젝트 시작

pm2 start processes.json

프로젝트 닫기

先查找ID
pm2 status
然后,停止相应项目的id
pm2 stop id

그런 다음 해당 프로젝트를 시작합니다

先查找ID
pm2 status
然后,开启相应项目的id
pm2 start id

부팅 시 pm2가 자동으로 시작되도록 설정

pm2 startup
pm2 save

pm2를 사용하여 프로젝트를 시작하는 이유는 서버 연결이 종료된 후에도 노드 프로젝트가 계속 실행될 수 있기 때문입니다.

프로젝트가 배포되었지만 프로젝트의 포트는 포트 80만 가능합니다. 백엔드 마스터는 nginx를 프록시 서버로 사용할 수 있다고 말했습니다. 그리고 설치방법을 알려주셨어요.

5. nginx 설치 및 nginx 구성

nginx 설치

yum install nginx

nginx 구성

구성된 폴더 디렉터리에 들어가거나 nginx.conf 파일을 편집하거나 conf.d 폴더 아래에 새 접미사 이름을 만듭니다. conf 파일

cd /
cd etc/nginx
vim nginx.conf

여기 사진이 있습니다

여기서 vim 편집기를 사용합니다. 인터넷에서 사용법을 검색할 수 있습니다

몇 가지 사용법을 언급하고 키보드를 누르세요

i  编辑
Esc 退出编辑
:q  退出vim编辑器
:wq 保存并退出vim编辑器

다음은 내 nginx입니다. 구성 (초보자, 질문이 있는 경우 전문가가 조언을 제공할 수 있습니다)

nginx를 시작

service nginx start

하여 nginx가 실행되도록 하세요.

nginx 구성을 수정할 때마다 다음 명령을 사용하여

service nginx reload

부팅 시 nginx가 자동으로 시작되도록 설정하세요.

ln -s /bin/systemctl /usr/local/bin/systemcel
systemcel enable nginx

위 내용은 모든 사람에게 도움이 되기를 바랍니다. 미래에.

관련 기사:

웹업로더와 결합된 Vue2.0을 통해 슬라이스에서 파일 업로드 기능을 구현하는 방법(자세한 튜토리얼)

vue+vuex+axios 기술을 사용하여 로그인 및 등록 페이지 권한 차단 구현(자세한 튜토리얼)

반응에서 이벤트를 바인딩하는 네 가지 방법을 자세히 설명하세요

위 내용은 pm2를 사용하여 도메인 이름 구입부터 node.js 프로젝트 배포까지 전체 과정에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.