Skip to content
Mark Metcalfe edited this page Oct 9, 2021 · 9 revisions

Databases

Like any CMS, you will need a database to run Totara.

The easiest way to set up a database is via the tdb command. It allows you to easily interact with any of the 4 supported DBMSes in a simple and consistent way. The script allows you to create, drop, backup and restore any database without having to remember the specific commands for each dbms.

To get started, simply define which database type and host you wish to use in your config.php, then run:

cd sitefolder # must run the command from the root of your Totara repo
tdb # prints help - shows what commands are available
tdb create

Alternatively, you can manually configure your databases using these commands and credentials.

Once you have a database created, you should be able to access the site from the web - try visiting http://totara73/sitename/server (where sitename is the folder name of your Totara repo)

Using Containers

Starting Containers

It is recommended to specify the containers you really need. The minimum you probably need is the db and the php container of your choice, the nginx container is started automatically alongside the php container.

The scripts for the following commands are located in the bin/ folder of this project.

# equivalent to: docker-compose up -d pgsql php-7.3
tup pgsql php-7.3

If you need additional containers at a later point just run tup with the container you need:

tup php-5.6
tup mariadb
tup selenium-hub

Shell Sessions

For the PHP containers, you can use the z shell to run commands for your Totara site via tzsh:

cd sitefolder # must run the commands from the root of your Totara repo
tzsh php-7.3
# OR
tzsh php-7.3-debug # for XDebug support
# OR
tzsh php-5.6 # for older Totara versions

For detailed information about how to set up aliases and use the correct fonts, see the PHP Shell page.

You can also start a shell session for any container using tbash too, although note it doesn't have the same aliases and themes as the PHP containers:

# It doesn't matter where you run the tbash command from
tbash nginx
tbash pgsql
tbash apache

Stopping Containers

# stops the specified containers, equivalent to: docker-compose stop
tstop

# stops all containers, equivalent to: docker-compose down
# also pauses existing mutagen sessions
tdown

More Commands

This project comes with a few bash scripts to simplify usage across platforms. The scripts are located in the bin/ folder.

tbash [container]                 # log into a container via bash, i.e. nginx
tbuild [container]                # build (all) container(s)
tdb [options]                     # run common actions for your databases
tdocker                           # shortcut to general docker-compose ... command
tdown                             # shutdown all containers
tgrunt [options]                  # run grunt in container, supports running in subfolders
tngrok [host]                     # shortcut to running ngrok with a Totara host such as totara74.debug or totara56
tnpm [options]                    # run npm in container, supports running in subfolders
tpull                             # pull latest images (only those which you already have locally) 
trestart [container]              # restart (all) container(s)
tscale [container] [number]       # scale up the number of containers, i.e. `tscale selenium-chrome 6`
tstats                            # show docker stats including container names
tstop [container]                 # stop (all) container(s)
tunit [container] [folder] [init] # run or init unit tests in given container for given version
tup [containers]                  # start (all) container(s)
tzsh [container]                  # log into a php container via zsh, i.e. php-7.3

Further Setup

With the above information, you should now be able to set up and use your Totara site.

See here for a list of aliases for the PHP containers you can use to get started. There are many more features and productivity tools that totara-docker-dev has to offer, which can be found in the pages listed in the sidebar on the right.

Clone this wiki locally