Node.js + Express 项目完整搭建手册(Redis + MySQL + 常用中间件)

本文全程基于 Express 实现后端服务,包含 Redis 缓存配置、MySQL 连接、外网访问、安全加固、常用中间件,可直接用于生产环境,新手也能快速落地。

一、新建项目

快速初始化一个 Express 项目:

bash 复制代码
# 初始化 npm 项目(一路回车即可)
npm init -y
# 安装 Express 核心框架
npm install express
# 启动服务
node app.js

二、Redis 中间件

Redis 用于数据缓存、减轻数据库压力,是后端必备中间件。

1、安装 Redis

bash 复制代码
# 群晖 NAS:直接在套件中心安装
# macOS 本地安装:
brew install redis

# 临时启动(关闭终端即停止)
redis-server
# 后台启动 + 开机自启(推荐)
brew services start redis
# 关闭 + 取消自启
brew services stop redis

2、连通性测试

bash 复制代码
# 只测试端口通不通(网络层)
nc -zv zhanglei.nasfuns.fun 6379
# 真正连接 Redis 验证权限(最准确)
redis-cli ping
redis-cli -h zhanglei.nasfuns.fun -p 6379 ping

3、允许外网访问(群晖 / Linux 通用)

bash 复制代码
# 查找 redis.conf 配置文件位置
find / -name "redis.conf" 2>/dev/null
# 编辑配置(群晖示例路径)
vi /volume1/@appdata/redis/redis.conf

修改以下两项:

bash 复制代码
# 允许所有 IP 访问
bind 127.0.0.1 -::1
bind 0.0.0.0

# 关闭保护模式(必须改,否则外网连不上)
protected-mode yes
protected-mode no

修改完成后重启 Redis生效。

4、设置密码 + 安全加固

方式 1:修改配置文件(永久生效)
bash 复制代码
# redis.conf 添加密码
requirepass 123456

项目连接地址格式:

js 复制代码
# 无密码
url: 'redis://zhanglei.nasfuns.fun:6379'
# 有密码(格式:redis://:密码@主机:端口)
url: 'redis://:123456@zhanglei.nasfuns.fun:6379'

命令行带密码测试:

bash 复制代码
# 带密码
redis-cli -h zhanglei.nasfuns.fun -p 6379 -a 123456 ping
# 无密码
redis-cli -h zhanglei.nasfuns.fun -p 6379 ping
方式 2:redis-cli 动态设置(无需重启)

注意:密码建议纯字母 + 数字 ,特殊符号 ! # & 会导致连接报错

bash 复制代码
# 登录(无密码、有密码)
redis-cli
redis-cli -a 123456

# 不用重启 Redis,改完立即生效
CONFIG SET requirepass "123456"							 # 开启密码
CONFIG SET bind 0.0.0.0 										 # 允许外网访问(你必须要)
CONFIG SET protected-mode no           			 # 关闭保护模式(必须)
CONFIG SET rename-command CONFIG "DISABLED"  # 禁用改配置(防入侵)
CONFIG SET rename-command FLUSHDB "DISABLED" # 禁删库
CONFIG SET rename-command FLUSHALL "DISABLED"# 禁删全库

save 																				 # 不save重启redis就会丢失
exit

三、MySQL 连接与使用

bash 复制代码
# 查看 MySQL 版本
mysql --version
# MySQL 8.0 低版本登录
mysql -u root -p1234567890 -P 3307 --ssl=0
# MySQL 8.0 以上高版本登录
mysql -u root -p1234567890 -P 3307 --ssl-mode=DISABLED
# 修改密码
SET PASSWORD = PASSWORD('1234567890'); 				# mysql5.7低版本 
ALTER USER USER() IDENTIFIED BY '1234567890'; # mysql8.0+高版本
FLUSH PRIVILEGES;															# 立即生效
exit;


四、可运行Demo与git步骤

下载demo

附录:Express 常用中间件(必备)

4 类必备:web 服务 + 数据库 + 鉴权安全 + 工具日志

1、核心中间件(内置,无需安装)

中间件 作用
express.json() 解析 JSON 请求体
express.urlencoded() 解析表单格式数据
express.static() 托管静态资源
express.Router() 路由模块化拆分

2、常用第三方中间件(需安装)

中间件 作用
cors 解决跨域
morgan HTTP 请求日志
helmet 安全防护(XSS/CSRF)

3、项目必备工具库(必装依赖)

  • express ------ Web 框架(接口服务)
  • mysql2 ------ MySQL 数据库连接
  • redis ------ Redis 缓存
  • jsonwebtoken ------ JWT 登录鉴权
  • cors ------ 跨域处理
  • dotenv ------ 环境配置管理
  • morgan ------ 请求日志
  • bcryptjs ------ 密码加密
相关推荐
流星雨在线2 小时前
SpringBoot 从开发到打包发布完整教程(对比 Node.js)
spring boot·后端·node.js
:mnong11 小时前
ClawX 项目设计分析
node.js·skill
代码搬运媛15 小时前
NestJS 实战:TypeORM 从入门到精通(完整教程)
node.js
太难了啊16 小时前
5分钟实现你的第一个 Node.js 智能体
人工智能·node.js
一直都在57217 小时前
Redis (一)
数据库·redis·缓存
秦jh_18 小时前
【Redis】客户端使用
数据库·redis·缓存
我真会写代码18 小时前
Redis核心特性详解:事务、发布订阅与数据删除淘汰策略
java·数据库·redis
MingT 明天你好!18 小时前
trae中安装mcp报Cannot find package/ERR_MODULE_NOT_FOUND问题
node.js·trae
IT 行者18 小时前
LangChain4j 集成 Redis 向量存储:我踩过的坑和选型建议
java·人工智能·redis·后端