VPS 配置
约 1308 字大约 4 分钟...
环境部署
部署应用前,为服务器配置好包管理工具,以便节省部署时间。主流的前端包管理工具有 npm、yarn、pnpm、以及国内的镜像 cnpm、tyarn 等,这些包管理器都是基于 nodejs。
包管理安装
通过集成了 npm 的 Node.js 来安装 npm,然后执行 npm i 命令安装其他。
全局安装 yarn 是 npm i yarn -g
,pnpm 是 npm i pnpm -g
。如果不想全局安装,则去除 -g
。
包管理源
包管理源的修改命令类似,将下方的 npm 替换 yarn 或 pnpm 即可修改包管理源。
#查看源
npm config get registry
#更换国内源
npm config set registry https://registry.npmmirror.com/
#换回默认源
npm config set registry https://registry.npmjs.org/
部署包
npm、yarn 和 pnpm 的包安装及管理命令。
#全局安装
npm i 包 -g
yarn global add 包
pnpm add 包 -g
#移除全局包
pnpm remove 包 --global
#更新全局包
pnpm upgrade 包 --global
#升级当前目录的依赖以确保你的项目只包含单个版本的相关包
#本方法能解决大部分的部署报错
npm i && npm update
yarn && yarn upgrade
pnpm i && pnpm up
你也可以安装 npm-check-updates 来检查和更新依赖。
# 全局安装 npm-check-updates
yarn global add npm-check-updates
# package.json 的 scripts 中添加 update 脚本
ncu -u && yarn install
本地测试
有些静态文件不支持直接打开,可以用 anywhere 架构本地服务器来进行测试。
# 安装静态服务 anywhere
npm install anywhere -g
# 进入静态页面存放目录,执行 anywhere
anywhere -p 8081
服务器 ECS
服务器系统为 Debian 11,配置包管理器 nodejs 和 yarn。[1]
apt-get update # 从数据源更新软件包的列表,运行产生软件包数据库
apt-get install wget && apt-get install sudo # 安装 wget 和 sudo
# 大版本升级必须先建立快照(有次我在 CentOS 上使用本命令后,引发大量依赖错误)
apt-get upgrade # 更新所有软件包(慎用,不要用!)
# 新建用户,非 root 权限
adduser xxx
# 为新用户设置密码
passwd xxx
# 安装 Node.js 20 和 yarn
curl -fsSL https://deb.nodesource.com/setup_20.x | bash -
apt-get install -y nodejs
sudo apt-get install yarn
如果服务器的 Node.js 安装遇到问题,可以用宝塔面板的 Node.js 版本管理器来进行部署。
服务器从零配置
推荐基础环境:Nginx、MySQL 5.7、PHP 8。可选:Redis、phpMyAdmin、Pure-Ftpd。
- 安装宝塔面板。
- 配置阿里云端口开放,导入安全规则。
- 宝塔上修改默认账号密码,并修改登录 22 的默认 SSH 端口。如果开通了 FTP,修改 FTP 端口。
- 选择「网站」>「添加站点」,将站点根目录放在 /www/wwwroot/xxx,同时新建数据库。
- 上传全站文件并解压,然后按照安装提示重新安装一次,最后导入备份数据库。
- 网站 Nginx 配置:
- 设置 SSL 证书,选择开启强制 HTTPS
- 添加 301 重定向
- 将静态文件缓存改为 365d(该修改不适合小白)
- 取消
error_page 404 /404.html;
前的注释符号#
,让 404.html 生效。
- ECS 设置优化:
- 打开 Linux 工具箱,添加 Swap(推荐设为物理内存的一半)。
- 添加计划任务,定期释放内存,建议设置每周释放一次,执行时机为半夜,如:03:00。
- 尽量使用更高的 PHP 版本,扩展推荐 opcache(脚本缓存)、redis(内容缓存)、imagemagick、fileinfo、exif。
- Redis 优化:(此操作可能不成功)使用
sudo vim /etc/sysctl.conf
修改net.core.somaxconn = 2048
,然后终端运行sudo sysctl -p
。
- 防火墙白名单(自定义),如:添加 url 规则
^/rss.php
到防火墙 URL 白名单,防止 rss 服务被屏蔽。
完成以上步骤,参考 Nginx、PHP 来进行服务器配置优化,以提升网站速度和降低服务器负载。
服务器迁移
- 购买按量付费服务器。
- 用服务器迁移中心 SMC 将旧服务器同步到临时服务器。
- 将域名解析到临时系统,确定服务基本正常。
- 对旧服务器先建立云盘快照,然后更换操作系统,进行全新部署。
- 对比新旧服务器,确认配置正常。
常见问题
CPU 100%
当服务器 CPU 或内存突然飙升 100% 时,依次排除当前运行进程,检查是否安装更新了插件、应用或服务。
如果找不到原因,可以临时设置定期任务。每隔 3 小时重启一次 nginx/apache。有时重启不正常,因此重启命令后 10 秒,再启动一次 nginx/apache。
/etc/init.d/nginx restart
sleep 10s
/etc/init.d/nginx start
CORS 跨域
POST 表单等操作需要涉及第三方 API,需要添加扩域域名,避免 CORS 报错。
add_header Access-Control-Allow-Origin "*";
add_header Access-Control-Allow-Credentials "true";
add_header Access-Control-Allow-Methods "GET, POST, OPTIONS";
add_header Access-Control-Allow-Headers "DNT,web-token,app-token,Authorization,Accept,Origin,Keep-Alive,User-Agent,X-Mx-ReqToken,X-Data-Type,X-Auth-Token,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Range";
add_header Access-Control-Expose-Headers "Content-Length,Content-Range";