Configuration
The key artifact that defines the tt
environment and various aspects of its
execution is its configuration file.
By default, the configuration file is called tt.yaml
. The location
where tt
searches for it depends on the launch mode.
You can also pass the configuration file explicitly in the --cfg
global option.
The tt
configuration file is a YAML file with the following structure:
env:
instances_enabled: path/to/available/applications
bin_dir: path/to/bin_dir
inc_dir: path/to/inc_dir
restart_on_failure: bool
tarantoolctl_layout: bool
modules:
directory: path/to/modules/dir
app:
run_dir: path/to/run_dir
log_dir: path/to/log_dir
wal_dir: path/to/wal_dir
vinyl_dir: path/to/vinyl_dir
memtx_dir: path/to/memtx_dir
repo:
rocks: path/to/rocks
distfiles: path/to/install
ee:
credential_path: path/to/file
templates:
- path: path/to/app/templates1
- path: path/to/app/templates2
Примечание
The tt
configuration format and application layout have been changed in version
2.0. Learn how to upgrade from earlier versions in Migrating from tt 1.* to 2.0 or later.
Примечание
The paths specified in env.*
parameters are relative to the current tt
environment’s root.
instances_enabled
– the directory where instances are stored. Default:instances.enabled
.bin_dir
– the directory where binary files are stored. Default:bin
.inc_dir
– the base directory for storing header files. They will be placed in theinclude
subdirectory inside the specified directory. Default:include
.restart_on_failure
– restart the instance on failure:true
orfalse
. Default:false
.tarantoolctl_layout
– use a layout compatible with the deprecatedtarantoolctl
utility for artifact files: control sockets,.pid
files, log files. Default:false
.
directory
– the directory where external modules are stored.
Примечание
The paths specified in app.*_dir
parameters are relative to the application
location inside the instances.enabled
directory specified in the env
configuration section. For example, the default location of the myapp
application’s logs is instances.enabled/myapp/var/log
.
Inside this location, tt
creates separate directories for each application
instance that runs in the current environment.
run_dir
– the directory for instance runtime artifacts, such as console sockets or PID files. Default:var/run
.log_dir
– the directory where log files are stored. Default:var/log
.wal_dir
– the directory where write-ahead log (.xlog
) files are stored. Default:var/lib
.memtx_dir
– the directory where memtx stores snapshot (.snap
) files. Default:var/lib
.vinyl_dir
– the directory where vinyl files or subdirectories are stored. Default:var/lib
.
rocks
– the directory where rocks files are stored.distfiles
– the directory where installation files are stored.
credential_path
– a path to the file with credentials used for downloading Tarantool Enterprise Edition.
path
– a path to application templates used for creating applications with tt create. May be specified more than once.
tt
launch mode defines its working directory and the way it searches for the
configuration file. There are three launch modes:
- default
- system
- local
Global option: none
Configuration file: searched from the current directory to the root.
Taken from /etc/tarantool
if the file is not found.
Working directory: The directory where the configuration file is found.
Global option: --system
or -S
Configuration file: Taken from /etc/tarantool
.
Working directory: Current directory.
Global option: --local=DIRECTORY
or -L=DIRECTORY
Configuration file: Searched from the specified directory to the root.
Taken from /etc/tarantool
if the file is not found.
Working directory: The specified directory. If tarantool
or tt
executable files are found in the working directory, they will be used.
The tt
configuration and application layout were changed in version 2.0.
If you are using tt
1.*, complete the following steps to migrate to tt
2.0 or later:
Update the tt configuration file. In tt 2.0, the following changes were made to the configuration file:
- The root section
tt
was removed. Its child sections –app
,repo
,modules
, and other – have been moved to the top level. - Environment configuration parameters were moved from the
app
section to the new sectionenv
. These parameters areinstances.enabled
,bin_dir
,inc_dir
, andrestart_on_failure
. - The paths in the
app
section are now relative to the app directory ininstances.enabled
instead of the environment root.
You can use tt init to generate a configuration file with the new structure and default parameter values.
- The root section
Move application artifacts. With
tt
1.*, application artifacts (logs, snapshots, pid, and other files) were created in thevar
directory inside the environment root. Starting fromtt
2.0, these artifacts are created in thevar
directory inside the application directory, which isinstances.enabled/<app-name>
. This is how an application directory looks:instances.enabled/app/ ├── init.lua ├── instances.yml └── var ├── lib │ ├── instance1 │ └── instance2 ├── log │ ├── instance1 │ └── instance2 └── run ├── instance1 └── instance2
To continue using existing application artifacts after migration from
tt
1.*:- Create the
var
directory inside the application directory. - Create the
lib
,log
, andrun
directories insidevar
. - Move directories with instance artifacts from the old
var
directory to the newvar
directories in applications“ directories.
- Create the
Move the files accessed from the application code. The working directory of instance processes was changed from the
tt
working directory to the application directory insideinstances.enabled
. If the application accesses files using relative paths, move the files accordingly or adjust the application code.