Nest.js部署记录

Nest项目部署一般有两种做法,一种是在本地打包后上传到服务器,一种是docker容器化部署。这次采用的是第一种。但是,Nest在本地打包时,不会将依赖给打包进去,所以需要把package.json也带上,然后在服务器上安装依赖:

css 复制代码
npm install --omit-dev

接着,使用pm2后台运行node.js. 通过pm2 ecosystem生成配置文件:

js 复制代码
module.exports = {
  apps: [
    {
      name: '', //应用名称
      script: './main.js',  //入口文件
      instances: 'max',  // 根据需求设置实例数量
      exec_mode: 'cluster',
      autorestart: true,
      watch: false,
      max_memory_restart: '1G',
      env: {
        NODE_ENV: 'production',
      },
    },
  ]
 }

启动:pm2 start ecosystem.config.js, 最后通过nginx转发到node监听的端口。

实际部署过程遇到的问题:

1) CentOS7内缺少支持node 18以上版本的C标准库:

解决办法:需要升级到glibc-2.28

shell 复制代码
wget http://ftp.gnu.org/gnu/glibc/glibc-2.28.tar.gz
tar xf glibc-2.28.tar.gz
cd glibc-2.28/ && mkdir build && cd build
../configure --prefix=/usr --disable-profile --enable-add-ons --with-headers=/usr/include --with-binutils=/usr/bin

在安装升级过程中,又遇到了

2) 第二个问题:

解决办法::升级gcc与make

shell 复制代码
wget http://ftp.gnu.org/gnu/glibc/glibc-2.28.tar.gz 
tar xf glibc-2.28.tar.gz 
cd glibc-2.28/ && mkdir build && cd build 
../configure --prefix=/usr --disable-profile --enable-add-ons --with-headers=/usr/include --with-binutils=/usr/bin

# 升级GCC(默认为4 升级为8)</span> 
yum install -y centos-release-scl 
yum install -y devtoolset-8-gcc* 
mv /usr/bin/gcc /usr/bin/gcc-4.8.5 
ln -s /opt/rh/devtoolset-8/root/bin/gcc /usr/bin/gcc 
mv /usr/bin/g++ /usr/bin/g++-4.8.5 
ln -s /opt/rh/devtoolset-8/root/bin/g++ /usr/bin/g++ 
# 升级 make(默认为3 升级为4) 
wget http://ftp.gnu.org/gnu/make/make-4.3.tar.gz 
tar -xzvf make-4.3.tar.gz && cd make-4.3/ 
./configure --prefix=/usr/local/make make && make install cd /usr/bin/ && mv make make.bak 
ln -sv /usr/local/make/bin/make /usr/bin/make

在yum安装devtoolset-8-gcc时,遇到

第三个问题:

解决办法:更换为阿里的源

bash 复制代码
cd /etc/yum.repos.d
wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo

执行上面步骤后,yum makecache还是报错:

还是使用了centos的源,原来还需要更新SCL的源。

vim 复制代码
vim /etc/yum.repos.d/CentOS-SCLo-scl.repo

修改如下:

shell 复制代码
[centos-sclo-sclo]
name=CentOS-7 - SCLo sclo
baseurl=https://mirrors.aliyun.com/centos/7/sclo/x86_64/sclo/
# mirrorlist=http://mirrorlist.centos.org?arch=$basearch&release=7&repo=sclo-sclo
gpgcheck=0
enabled=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-SIG-SCLo

修改/etc/yum.repos.d/CentOS-SCLo-scl-rh.repo:

ini 复制代码
[centos-sclo-rh]
name=CentOS-7 - SCLo rh
baseurl=https://mirrors.aliyun.com/centos/7/sclo/x86_64/rh/
# mirrorlist=http://mirrorlist.centos.org?arch=$basearch&release=7&repo=sclo-rh
gpgcheck=0
enabled=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-SIG-SCLo

刷新缓存:

css 复制代码
yum repolist
yum clean all
yum makecache

解决完第三个问题,回到前面继续安装devtoolset-8-gcc,解决第二个问题。最后回到解决第一个问题,安装升级glibc-2.28.

bash 复制代码
cd /root/glibc-2.28/build 
../configure --prefix=/usr --disable-profile --enable-add-ons --with-headers=/usr/include --with-binutils=/usr/bin

接着遇到第四个问题:

4)bison版本太旧:

解决办法:

复制代码
yum install -y bison

最后安装更新所有软件:

go 复制代码
make && make instal

参考资料:

www.cnblogs.com/yuwen01/p/1...

www.cnblogs.com/Jedi-Pz/p/1...

相关推荐
灰子学技术25 分钟前
go response.Body.close()导致连接异常处理
开发语言·后端·golang
Gogo8161 小时前
BigInt 与 Number 的爱恨情仇,为何大佬都劝你“能用 Number 就别用 BigInt”?
后端
fuquxiaoguang1 小时前
深入浅出:使用MDC构建SpringBoot全链路请求追踪系统
java·spring boot·后端·调用链分析
毕设源码_廖学姐2 小时前
计算机毕业设计springboot招聘系统网站 基于SpringBoot的在线人才对接平台 SpringBoot驱动的智能求职与招聘服务网
spring boot·后端·课程设计
野犬寒鸦4 小时前
从零起步学习并发编程 || 第六章:ReentrantLock与synchronized 的辨析及运用
java·服务器·数据库·后端·学习·算法
逍遥德4 小时前
如何学编程之01.理论篇.如何通过阅读代码来提高自己的编程能力?
前端·后端·程序人生·重构·软件构建·代码规范
MX_93595 小时前
Spring的bean工厂后处理器和Bean后处理器
java·后端·spring
程序员泠零澪回家种桔子6 小时前
Spring AI框架全方位详解
java·人工智能·后端·spring·ai·架构
源代码•宸6 小时前
大厂技术岗面试之谈薪资
经验分享·后端·面试·职场和发展·golang·大厂·职级水平的薪资
晚霞的不甘7 小时前
CANN 编译器深度解析:UB、L1 与 Global Memory 的协同调度机制
java·后端·spring·架构·音视频