配置
您可以使用环境变量更改 n8n 的设置。有关可用配置的完整列表,请参阅
环境变量 。
通过命令行设置环境变量
npm
对于 npm,使用以下命令在终端中设置所需的环境变量:
export <variable>= <value>
Docker
在 Docker 中,您可以从命令行使用该标志:
docker run -it --rm \
--name n8n \
-p 5678 :5678 \
-e N8N_TEMPLATES_ENABLED = "false" \
docker.n8n.io/n8nio/n8n
使用文件设置环境变量
您还可以使用配置文件配置 n8n。
只需在配置文件中定义需要与默认值不同的值即可。您可以使用多个文件。例如,您可以创建一个包含通用基本设置的文件,并创建多个包含针对不同环境的特定值的文件。
npm
使用环境变量设置 JSON 配置文件的路径:
# Bash - Single file
export N8N_CONFIG_FILES = /<path-to-config>/my-config.json
# Bash - Multiple files are comma-separated
export N8N_CONFIG_FILES = /<path-to-config>/my-config.json,/<path-to-config>/production.json
# PowerShell - Single file, persist for current user
# Note that setting scope (Process, User, Machine) has no effect on Unix systems
[ Environment] ::SetEnvironmentVariable( 'N8N_CONFIG_FILES' , '<path-to-config>\config.json' , 'User' )
示例文件:
{
"executions" : {
"saveDataOnSuccess" : "none"
},
"generic" : {
"timezone" : "Europe/Berlin"
},
"nodes" : {
"exclude" : "[\"n8n-nodes-base.executeCommand\",\"n8n-nodes-base.writeBinaryFile\"]"
}
}
格式化为 JSON
您无法总是从
环境变量参考 中得出正确的 JSON 。例如,要设置为,您需要执行以下操作:
{
"endpoints" : {
"metrics" : {
"enable" : true
}
}
}
有关预期设置的完整详细信息,请参阅
源代码中的 Schema 文件 。
Docker
在 Docker 中,您可以在文件元素中设置环境变量。
例如:
n8n :
environment :
- N8N_TEMPLATES_ENABLED=false
将敏感数据保存在单独的文件中
您可以附加到各个环境变量以在单独的文件中提供它们的配置,从而避免使用环境变量传递敏感详细信息。n8n 从具有给定名称的文件中加载数据,从而可以从
Docker-Secrets 和Kubernetes-Secrets 加载数据。
有关每个变量的详细信息,请参阅
环境变量 。
虽然大多数环境变量都可以使用后缀,但对于
凭据 和数据库配置等敏感数据来说,后缀更为有利。以下是一些示例:
1
2
3
4
5
6
7
8
9
10
11
12 CREDENTIALS_OVERWRITE_DATA_FILE=/path/to/credentials_data
DB_TYPE_FILE=/path/to/db_type
DB_POSTGRESDB_DATABASE_FILE=/path/to/database_name
DB_POSTGRESDB_HOST_FILE=/path/to/database_host
DB_POSTGRESDB_PORT_FILE=/path/to/database_port
DB_POSTGRESDB_USER_FILE=/path/to/database_user
DB_POSTGRESDB_PASSWORD_FILE=/path/to/database_password
DB_POSTGRESDB_SCHEMA_FILE=/path/to/database_schema
DB_POSTGRESDB_SSL_CA_FILE=/path/to/ssl_ca
DB_POSTGRESDB_SSL_CERT_FILE=/path/to/ssl_cert
DB_POSTGRESDB_SSL_KEY_FILE=/path/to/ssl_key
DB_POSTGRESDB_SSL_REJECT_UNAUTHORIZED_FILE=/path/to/ssl_reject_unauth