docs/docs/cn/get-started/installation/env.md
在项目根目录下的 .env 文件里设置环境变量,修改环境变量之后需要 kill 应用进程,重新启动。
修改 docker-compose.yml 配置,在 enviroment 参数里设置环境变量。示例:
services:
app:
image: nocobase/nocobase:latest
environment:
- APP_ENV=production
也可以使用 env_file, 即可在 .env 文件中设置环境变量。示例:
services:
app:
image: nocobase/nocobase:latest
env_file: .env
修改环境变量之后,需要重建 app 容器。
docker compose up -d app
用于设置应用的时区,默认为操作系统时区。
https://en.wikipedia.org/wiki/List_of_tz_database_time_zones
:::warning 与时间相关的操作会依据该时区进行处理,修改 TZ 可能会影响数据库里的日期值,详情查看「日期 & 时间概述」 :::
应用环境,默认值 development,可选项包括:
production 生产环境development 开发环境APP_ENV=production
应用的密钥,用于生成用户 token 等,修改为自己的应用密钥,并确保不对外泄露
:::warning 如果 APP_KEY 修改了,旧的 token 也会随之失效 :::
APP_KEY=app-key-test
应用端口,默认值 13000
APP_PORT=13000
NocoBase API 地址前缀,默认值 /api/
API_BASE_PATH=/api/
v1.6.0+
多核(集群)启动模式,如配置了该变量,会透传至 pm2 start 命令中作为 -i <instances> 的参数。可选项与 pm2 -i 参数一致(参考 PM2: Cluster Mode),包括:
max:使用 CPU 最大核数-1:使用 CPU 最大核数 -1<number>:指定核数默认值为空,代表不开启。
:::warning{title="注意"} 该模式需要配合集群模式相关的插件使用,否则应用的功能可能出现异常。 :::
更多可参考:集群模式。
插件包名前缀,默认为:@nocobase/plugin-,@nocobase/preset-。
例如,添加 hello 插件到 my-nocobase-app 项目,插件的完整包名则为 @my-nocobase-app/plugin-hello。
PLUGIN_PACKAGE_PREFIX 可以配置为:
PLUGIN_PACKAGE_PREFIX=@nocobase/plugin-,@nocobase-preset-,@my-nocobase-app/plugin-
则插件名称和包名对应关系如下:
users 插件的包名为 @nocobase/plugin-usersnocobase 插件的包名为 @nocobase/preset-nocobasehello 插件的包名为 @my-nocobase-app/plugin-hello数据库类型,可选项包括:
mariadbmysqlpostgresDB_DIALECT=mysql
数据库主机(使用 MySQL 或 PostgreSQL 数据库时需要配置)
默认值 localhost
DB_HOST=localhost
数据库端口(使用 MySQL 或 PostgreSQL 数据库时需要配置)
DB_PORT=3306
数据库名(使用 MySQL 或 PostgreSQL 数据库时需要配置)
DB_DATABASE=nocobase
数据库用户(使用 MySQL 或 PostgreSQL 数据库时需要配置)
DB_USER=nocobase
数据库密码(使用 MySQL 或 PostgreSQL 数据库时需要配置)
DB_PASSWORD=nocobase
数据表前缀
DB_TABLE_PREFIX=nocobase_
数据库表名、字段名是否转为 snake case 风格,默认为 false。如果使用 MySQL(MariaDB)数据库,并且 lower_case_table_names=1,则 DB_UNDERSCORED 必须为 true
:::warning
当 DB_UNDERSCORED=true 时,数据库实际的表名和字段名与界面所见的并不一致,如 orderDetails 数据库里的是 order_details
:::
数据库日志开关,默认值 off,可选项包括:
on 打开off 关闭DB_LOGGING=on
数据库连接池最大连接数,默认值 5。
数据库连接池最小连接数,默认值 0。
数据库连接池空闲时间,默认值 10000(10 秒)。
数据库连接池获取连接最大等待时间,默认值 60000(60 秒)。
数据库连接池连接最大存活时间,默认值 1000(1 秒)。
连接在被丢弃并替换之前可被使用的次数,默认值 0(不限制)。
日志输出方式,多个用 , 分隔。开发环境默认值 console, 生产环境默认值 console,dailyRotateFile.
可选项:
console - console.logfile - 文件dailyRotateFile - 按天滚动文件LOGGER_TRANSPORT=console,dailyRotateFile
输出日志级别,开发环境默认值 debug, 生产环境默认值 info. 可选项:
errorwarninfodebugtraceLOGGER_LEVEL=info
数据库日志输出级别为 debug, 由 DB_LOGGING 控制是否输出,不受 LOGGER_LEVEL 影响。
最大保留日志文件数。
LOGGER_TRANSPORT 为 file 时,默认值为 10.LOGGER_TRANSPORT 为 dailyRotateFile, 使用 [n]d 代表天数。默认值为 14d.LOGGER_MAX_FILES=14d
按大小滚动日志。
LOGGER_TRANSPORT 为 file 时,单位为 byte, 默认值为 20971520 (20 * 1024 * 1024).LOGGER_TRANSPORT 为 dailyRotateFile, 可以使用 [n]k, [n]m, [n]g. 默认不配置。LOGGER_MAX_SIZE=20971520
日志打印格式,开发环境默认 console, 生产环境默认 json. 可选项:
consolejsonlogfmtdelimiterLOGGER_FORMAT=json
参考:日志格式
使用缓存方式的唯一标识,指定服务端默认缓存方式,默认值 memory, 内置可选项:
memoryredisCACHE_DEFAULT_STORE=memory
内存缓存项目最大个数,默认值 2000。
CACHE_MEMORY_MAX=2000
Redis连接,可选。示例:redis://localhost:6379
CACHE_REDIS_URL=redis://localhost:6379
启动遥测数据收集,默认为 off.
TELEMETRY_ENABLED=on
启用的监控指标采集器,默认为 console. 其他值需要参考对应采集器插件注册的名字,如 prometheus. 多个使用 , 分隔。
TELEMETRY_METRIC_READER=console,prometheus
启用的链路数据处理器,默认为 console. 其他值需要参考对应处理器插件注册的名字。多个使用 , 分隔。
TELEMETRY_TRACE_PROCESSOR=console
用于配置集群模式下进行服务拆分时,不同节点的工作模式,详情查看「服务拆分:如何拆分服务」。
服务端对外发送 HTTP 请求的目标白名单,用于限制由 NocoBase 服务端主动发出的请求。逗号分隔,支持精确 IP、CIDR 范围、精确域名和通配符子域名(单级)。
SERVER_REQUEST_WHITELIST=api.example.com,*.trusted.com,10.0.0.0/8,127.0.0.1
适用范围:工作流「HTTP 请求」节点、自定义操作按钮的「自定义请求」、AI 服务等服务端请求。相对路径(调用 NocoBase 自身 API)不受此限制影响。
未配置时:所有 http / https 请求均放行(保持原有行为)。不过,如果目标是 loopback、内网、link-local、metadata 地址,或者域名解析到了这些地址,服务端日志会输出 warning。
配置后:仅允许匹配白名单的请求,不匹配的请求会报错。后续版本可能会逐步收紧默认策略,如果你的部署需要访问内网服务,建议提前配置明确的白名单。
支持的格式:
| 格式 | 示例 | 匹配规则 |
|---|---|---|
| 精确 IPv4 | 1.2.3.4 | 仅匹配该 IP |
| IPv4 CIDR | 10.0.0.0/8 | 匹配该网段内所有 IP |
| 精确 IPv6 | ::1 | 仅匹配该 IP |
| IPv6 CIDR | fc00::/7 | 匹配该网段内所有 IP |
| 精确域名 | api.example.com | 仅匹配该域名 |
| 通配符子域名 | *.example.com | 匹配一级子域名,如 foo.example.com,不匹配 example.com 或 a.b.example.com |
:::warning 注意
如果白名单中配置的是域名,白名单判断会以请求 URL 中的 host 为准。也就是说,配置 internal.example.com 后,即使该域名解析到 127.0.0.1 或内网地址,也会被视为显式允许。
:::
用于附加预置的未激活插件,值为插件包名(package.json 的 name 参数),多个插件英文逗号分隔。
:::info
node_modules 目录里可以找到,更多内容查看 插件的组织方式。nocobase install 或升级 nocobase upgrade 后才会在插件管理器页面里显示。:::
APPEND_PRESET_LOCAL_PLUGINS=@my-project/plugin-foo,@my-project/plugin-bar
用于附加内置并默认安装的插件,值为插件包名(package.json 的 name 参数),多个插件英文逗号分隔。
:::info
node_modules 目录里可以找到,更多内容查看 插件的组织方式。nocobase install 或升级 nocobase upgrade 时会自动安装或升级插件。:::
APPEND_PRESET_BUILT_IN_PLUGINS=@my-project/plugin-foo,@my-project/plugin-bar
安装 NocoBase 时,可以通过设置临时的环境变量来辅助安装,如:
yarn cross-env \
INIT_APP_LANG=zh-CN \
[email protected] \
INIT_ROOT_PASSWORD=admin123 \
INIT_ROOT_NICKNAME="Super Admin" \
nocobase install
# 等同于
yarn nocobase install \
--lang=zh-CN \
[email protected] \
--root-password=admin123 \
--root-nickname="Super Admin"
# 等同于
yarn nocobase install -l zh-CN -e [email protected] -p admin123 -n "Super Admin"
安装时的语言,默认值 en-US,可选项包括:
en-USzh-CNyarn cross-env \
INIT_APP_LANG=zh-CN \
nocobase install
Root 用户邮箱
yarn cross-env \
INIT_APP_LANG=zh-CN \
[email protected] \
nocobase install
Root 用户密码
yarn cross-env \
INIT_APP_LANG=zh-CN \
[email protected] \
INIT_ROOT_PASSWORD=admin123 \
nocobase install
Root 用户昵称
yarn cross-env \
INIT_APP_LANG=zh-CN \
[email protected] \
INIT_ROOT_PASSWORD=admin123 \
INIT_ROOT_NICKNAME="Super Admin" \
nocobase install
工作流 JavaScript 节点可用的模块列表,详情查看「JavaScript 节点:使用外部模块」。
工作流循环节点的最大循环次数限制,详情查看「循环节点」。