在Linux系统配置Nodejs环境的最简单步骤,部署多个thinkjsnodejs项目

为例进行部署,欢迎fork和start,源码地址:,展示地址:有问题一起交流。

1、去官网下载和自己系统匹配的文件:

 英文网址:

 中文网址:

建议去英文网站下载 ,因为中文这边没有给出稳定版,目前稳定版8点多。最新版是10点多

2、查看linux系统的位数 

通过  uname -a  命令查看到我的Linux系统位数是64位(备注:x86_64表示64位系统, i686 i386表示32位系统),如图

选择64位

3、下载下来的tar文件上传到服务器并且解压

我使用的xshell中的rz命令来上传文件

在xshell中输入rz命令,看是否已经安装了lrzsz,如果没有安装则执行  yum   -y  install  lrzsz命令进行安装。

安装成功后,输入rpm -qa lrzsz 命令确认是否正确安装

 

输入rz或者re -y,选择刚才下的压缩包

 

现在开始解压

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

 

修改文件夹(目录)的名字

mv node-v8.12.0-linux-x64 nodejs

 

4、执行软连接

注意:确认一下nodejs下bin目录是否有node 和npm文件,如果有执行软连接,如果没有重新下载执行上边步骤

 

确认有node和npm文件了

执行软链接

ln -s /home/cxs/install/nodejs/bin/npm /usr//bin/ ln -s /home/cxs/install/nodejs/bin/node /usr/local/bin/

发现自己没有权限,然后找老大要来root账号

下面是root权限下执行

ok了,回到自己用户下

ok了

 5、安装pm2,通过pm2启动node可以使关闭终端时node依然运行。

 

进入后端代码的跟目录,通过npm i 安装后端代码需要的库,启动node

pm2 start index.js

说明,没有配制到全局,虽然安装到全局,不知道为啥,linux下不像windows下能自动创造一个环境变量去实现我们的全局。所以我们需要创建一个linux下的软连接。

下面红框就是pm2的安装路径,连接到全局环境路径

下面出现的都是全局环境路径,选哪一个都可以,我选的是红框的全局环境变量/usr/local/bin

 建立连接

ln -s /home/cxs/install/nodejs/bin/pm2 /usr/local/bin/

使用pm2 list验证是否成功建立连接

pm2 list

 

说明pm2全局安装成功,并且可以随处访问pm2,我试试我的账号是不是也可以使用pm2命令

出现这个,说明其他账号也可以全局都可以使用pm2

 5、thinkjs项目,使用pm2 start pm2.json 来启动项目

切换到自己的账号上,需要全局变量时候没有权限的时候采用root账号

上传项目代码,使用xshell的rz -y来

执行

pm2 start pm2.json

出现上图应该就算启动起来了

但是我想看一下项目启动之后访问情况,怎么搞,这时候需要祭出nginx

6、nginx使用

 已经部署完成,但是公网访问出现问题,出现502,

发现是nginx配置的问题,

方案一:把nginx的实际访问地址172.31.231.103:8362修改为127.0.0.1:8362

upstream weekly_node

方案二:把项目node的启动主机host(127.0.0.1)修改为0.0.0.0

附上完整的nginx服务配置

error_log logs/<span style="color: #000000;">error.log;

error_log logs/<span style="color: #000000;">error.log notice;

error_log logs/<span style="color: #000000;">error.log info;

pid logs/<span style="color: #000000;">nginx.pid;

events <span style="color: #008000;">{<span style="color: #008000;">
worker_connections 1024;
<span style="color: #008000;">}<span style="color: #000000;">

http <span style="color: #008000;">{<span style="color: #008000;">
include mime.types;
default_type application/octet-stream;

sendfile        on;

keepalive_timeout  65;

upstream weekly_node {
    server 172.31.231.103:8362;
</span><span style="color: #008000;"&gt;}</span><span style="color: #000000;"&gt;          
server </span><span style="color: #008000;"&gt;{</span><span style="color: #008000;"&gt;
    listen  80;
    server_name  localhost;
    charset utf-8; 

    #weekly static
    location /weekly/ {
        #root   /home/fastdfs/nginx/weekly/dist;
        alias /home/fastdfs/nginx/weekly/dist/;
        index  index.html index.htm;
        try_files $uri $uri/ /index.html last;
        #root  html;
        #index   index.html;
    </span><span style="color: #008000;"&gt;}    #nodejs服务方向代理</span><span style="color: #000000;"&gt;
    location </span>/weekly_node/ <span style="color: #008000;"&gt;{</span><span style="color: #008000;"&gt;
        proxy_pass http://weekly_node;
        proxy_redirect off;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        client_max_body_size 10m;
        client_body_buffer_size 128k;
        proxy_connect_timeout 90;
        proxy_send_timeout 90;
        proxy_read_timeout 90;
        proxy_buffer_size 4k;
        proxy_buffers 4 32k;
        proxy_busy_buffers_size 64k;
        proxy_temp_file_write_size 64k;

    </span><span style="color: #008000;"&gt;}</span><span style="color: #000000;"&gt;

}   

}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


系ubuntu 下面打开终端输入:sudo apt-get install sendmail一般就安装完成噶啦跟住进入 /etc/mail/目录输入:m4 sendmail.mc &gt; sendmail.cf意思系跟住.mc文件 生成 sendmial.cf文件输入呢个命令:ps aux | g
依家我有1个软件goagent目录(大家懂得) 放在/home/gateman/Programs/ 下 1. proxy.py 入面有1个 proxy.py 文件 放在/home/gateman/Programs/goagent/local/ 入面 2.breakwall.sh 我在 proxy.p
其实我想讲的是 cp -L关于-L参数的解释:-L, --dereference always follow symbolic links in SOURCE意思是如果复制目标是1个软链接,则复制链接的目标 不是链接本身做个例子: 例如 ~/tmp/fo1 入面有1个c.txt 文件 和 指向他的软
原地址:http://www.rjgc.net/control/content/content.php?nid=4418 1、将文件checkout到本地目录svn checkout path(path是服务器上的目录)例如:svn checkout svn://192.168.1.1/pro/do
chroot,即 change root directory (更改 root 目录)。在 linux 系统中,系统默认的目录结构都是以 `/`,即是以根 (root) 开始的。而在使用 chroot 之后,系统的目录结构将以指定的位置作为 `/` 位置。实例:用live CD ubuntu假设你的
简单解析下, stdin就是标准输入, stdout就是标准。举个例子, 在当前我要打包1个文件夹 /var/log/ 到当前目录下,并用zip压缩,那么我们可以分步执行#tar -cvf log.tar /var/log/#zip -r log.tar.zip log.tar#rm -rf log
转自:http://man.ddvip.com/linux/Mandrakelinuxref/process-priority.html系统中运行的每个进程都有一个优先级(亦称“nice 值”),其范围从 -20 (最高优先级)到 19 (最低优先级)。默认情况下,进程的优先级是 0 (“基本”调度
str=&quot;/home/gateman&quot; if [ ${str:0:1} = &quot;/&quot; ]; then echo &quot;yes&#39;fi ${str:0:1} 中0表示从第几个字符开始,1表示截取多长
转自:http://kwokchivu.blog.51cto.com/1128937/694347 在RedHat系统下用usermod 命令可把某用户添加进多个附属组,默认情况下,一次性添加多个附属组可用以下方式来添加: usermod -G 附属组1,附属组2,...,附属组X 用户名 但在添加
有个文件 test.txt 内容如下:bash-3.00$ cat test.txt user user user_hiuser #注:呢行系空行T JGATEMANGATTTTTEMANGABBEMANAAABbash-3.00$下面介绍下常用的通配符 配合grep 命令:1. &quot;.&q
linux系统为每1个文件都分配有i索引节点(inode),系统根据呢d节点从磁盘找出数据。 一般来讲,每1个文件名(包含全路径)实际上都链接住1个i索引节点。inode实际上系乜咧? 其实可以算系1个指向磁盘具体位置(柱面,扇区之类)的指针, 系统分析某个文件的inode,得出磁盘柱面,扇区等数据
grep 可以立即为筛选, 一般的用法系 grep + 要查询的字段 + 文件(或者内容 例如| 传递既内容)1.grep + 要查询的字段 + 文件gateman@GPC:~/shell/SQL_GSI$ grep OID a.sqlWHERE OID=@BuildNOWHERE OID INWH
原文转自:http://www.ibm.com/developerworks/cn/linux/l-cn-vimcolumn/index.html开始之前人类大脑对文字的处理是平面式的,所以我们浏览文章、查找资料或者重构代码,要么是横向读,要么是纵向读,要么使用搜索功能,将文字作为一个平面整体。而在
PS:偶很喜欢用scp这个命令来传输数据。scp命令跟cp命令类似,只不过cp命令是在同一台机器上用的,scp是在两台机器上复制传输数据的命令。scp实质相当于利用SSH协议来传输数据的cp命令。 用法举例: 1、复制远程服务器的文件到本地: scp -P888 root@120.18.50.33:
打开终端,进入/bin/ls 一下会见到 bash sh 呢两个文件。其实距地系两个唔同既shell 解析器。如果在脚本a.sh 开头写入#!/bin/sh那么执行./a.sh 时候 就相当于 sh a.sh同理 开头写入#!/bin/bash执行./a.sh 时候 就相当于 bash a.sh如果
find查找文件的时候排除某个或几个文件或目录转自:http://www.cnblogs.com/starspace/archive/2008/10/20/1315380.html比如要在/usr/sam目录下查找不在dir1子目录之内的所有文件find /usr/sam -path &quot;/
假设有变量 var=http://www.google.com/test.htm一 # 号截取,删除左边字符,保留右边字符。echo ${var#*//}其中 var 是变量名,# 号是运算符,*// 表示从左边开始删除第一个 // 号及左边的所有字符即删除 http://结果是 :www.goog
转自: http://edyfox.codecarver.org/html/_vimrc_for_beginners.htmlVIM 中可供用户定制的选项非常非常多,作为初学者,我们没有必要了解这么多东西。下面,滇狐简单列出了一些最常用的配置项,大家可以根据自己的需要将这些内容添加到自己的 .vim
转自:http://www.einit.com/user1/11/archives/2006/3603.htmlUnix/Linux下一般想让某个程序在后台运行,很多都是使用 &amp; 在程序结尾来让程序自动运行。比如我们要运行mysql在后台: /usr/local/mysql/bin/mysq
首先, mount是类unix系统, 挂载设备到1个文件夹的操作命令, 注意系设备阿正常来讲,mount 是不能挂在文件夹到文件夹的。例如, 在我的~/tmp/ 目录中有两个文件夹fo1 fo2其中fo1 中有3个文件a.txt b.txt c.txt fo2 有4个 e.txt d.txt e.t