服务器端通过nginx部署项目(含websoket)

前言:在某云购买的服务器,实现在服务器部署项目,nginx启动项目,并同时启动websocket

        只需部署项目:只看前四步

        连接实例准备

一、nginx安装及编译

 1、nginx安装

#登录服务器并进⼊/usr/local⽬录
cd /usr/local
#下载nginx
wget http://nginx.org/download/nginx-1.18.0.tar.gz
#解压nginx
tar -zxvf nginx-1.18.0.tar.gz
进入解压后的目录
cd nginx-1.18.0

 

2、编译(在刚才进去的nginx-1.18.0目录下继续执行)

#安装工具
yum install -y gcc pcre pcre-devel openssl openssl-devel gd gd-devel

#配置nginx编译环境
./configure --with-http_stub_status_module --with-http_ssl_module --with-http_v2_module --with-stream

#编译安装
make && make install

二、nginx配置nginx.conf

注意的是:

        修改的目录是:编译后生成的nginx目录下conf里面的nginx.conf

        执行命令的目录是:解压后nginx-1.18.0下objs

 1、只修改目录配置时(默认端口80不变)

        location / {
            root /usr/local/DongHao; #修改这⾥项⽬放置位置
            index  index.html;
        }

 效果

 2、目录修改好后,想换个端口时

worker_processes  1;
events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;
    server {
        listen       8883;
        server_name  localhost;
        location / {
            root /usr/local/DongHao; #修改这⾥项⽬放置位置
            index  index.html;
        }
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    }
}

 效果

  可以看到,换了端口重启nginx是并不生效的,还需要在购买服务器的厂家增加配置,

我这里是阿里云

效果

三、nginx使用

 

 在第“一”步完毕后,多了个objs的目录,进入objs目录后执行项目操作

#启动nginx 
./nginx

#重新加载nginx配置文件
./nginx -s reload

#关闭nginx
./nginx -s stop

 四、域名访问

购买域名解析后,默认通过域名是不可以访问的,要域名备案

需要备案,符合那个要求,那个要求,那个要求,那个要求,那个要求...

 备案实例需要购买3个月以上,先省略,以后再补上步骤

五、项目中如果有websocket时 (本地模拟启动websocket)

本地正常,部署后,运行会报错,websocket连接失败了

这是未启动websoket服务


本地使用websocket(模拟后台启动websocket)

    1、模拟后台启动websocket服务(本地通过nginx,启动websocket服务)

   2、第1步启动好可正常访问后,在服务器端启动nginx(以下为服务器端nginx配置)

map $http_upgrade $connection_upgrade {
        default upgrade;
        '' close;
    }

#项目里有websocket时
    server {
        listen 126;
        location / {
            proxy_pass http://192.168.6.58;
            proxy_set_header Upgrade $http_upgrade;
            proxy_set_header Connection "upgrade";
        }
    }

效果 

 


 线上环境使用websocket

1、修改成后端启动websocket的地址及端口

六、项目中如果有websocket时 (服务器端启动websocket)

前言: 先说一下本地启动websocket的两种方式,本地启动时,因已经提前安装过node环境,在              控制台直接执行命令即可

        1.单独websocket启动时:找到对应websocket服务程序目录,执行node app.js(如效果1)

        2.websocket在项目中时:在package.json中scripts配置,让node同时执行两个任务(如效果2)

效果1:单独websocket启动时

 效果2:websocket在项目中时


在服务端默认不能执行node来启动websocket,所有以下步骤是,先安装,再启动

  1、因Xshell默认不能执行node命令,先要安装node(在local目录下新建node文件夹)

参考

xshell安装node_Zoexyf的博客-CSDN博客

步骤1
curl --silent --location https://rpm.nodesource.com/setup_8.x | sudo bash -
步骤2
sudo yum install -y nodejs
步骤3 查看
node -v
步骤4 查看
npm -v

 2、执行完第1步后(就可以使用node命令)

   用node命令在服务器端启动websocket服务(在local目录下新建wesocket文件夹)

1) 安装nodejs-websocket 

npm i nodejs-websocket 

 2) 执行node app.js    

出现问题-不能识别import

 卒~~~~~~~~~~~~

3)参考:为什么nodejs不支持import - web开发 - 亿速云

全局安装babel-cli 

 npm install babel-cli -g

安装 babel-preset-env 

npm install babel-preset-env -D

原来是node app.js,改为这样调用:babel-node --presets env app.js

那么现在,在服务器端就已经启动好了websocket服务

但是,这一步只是单独启动了websocket

下一步就是,

修改服务端nginx配置,连接上这个实例,端口为3000的地址,

 4) 修改前端与配置

前端代码

nginx配置 

5) 同时启动项目和websocket

 同时打开两个Xshell窗口

        一个启动app.js    :  babel-node --presets env app.js

        一个启动项目       :./nginx

 端口占用了,为啥呢,websocket的端口的3000,nginx的端口是8883

只能执行一个任务,要么启nginx,要么启动websocket

 依然没有解决同时启动nginx和websocket

卒~~~~~~

参考Linux nohup、 &、2>&1以及/dev/null 2>&1_书香水墨的博客-CSDN博客

找到对应app.js路径执行以下 

nohup babel-node --presets env /usr/local/Websocket/app.js > logs/socket.log 2>&1 &

 nohup: 用途:不挂断地运行命令

logs/socket.log  自己的定义的一个文本输出

2>&1是指将标准错误重定向到标准输出,于是标准错误和标准输出都重定向到指定的socket.log文件中,从此终端彻底清静了。

 效果:开了4个浏览器窗口,执行日志会放入socket.log文件中

 后续

 

 这个时候,关闭nginx后,又重新启动,websocket依然有效

如果想单独只关闭websocket如何操作

 如图,启动会有一个SID的进程

查询后:关闭进程

查询进程

ps -aux|grep /usr/local/Websocket/app.js

关闭进程(例如SID为14621时)

kill 14621

后续
当关闭Xshell窗口的时候,websocket断开了

 解决

先exit退出,再关闭Xshell窗口

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值