Kaiser Documentation
Command Reference
This is a reference for commands available in Kaiser. It is sorted by importance but not necessarily by how one would use them.
Global Options
These options can be used with any of the commands below.
-v
--verbose
Verbose mode
Verbose mode. This tells Kaiser to spit out all the output of the commands it runs so it is clear if something went wrong. By default, Kaiser simply writes a period character for each line of output to avoid being noisy.
kaiser init
This initializes an environment in Kaiser. In reality this assigns your current directory to a particular environment name. For example
kaiser init hats
Will assign this directory to the name hats
.
This is an important first step because this will determine the domain name you can use to access this environment. For example if you start it up the domain will be hats.lvh.me
if you did not set the suffix. If you did set the suffix the domain will be hats.<whatever the suffix is>
. More info on suffixes here.
Errors
- This command requires you be in a directory that has a Kaiserfile. If you don't have one, you will get the message
Error: No Kaiserfile in current directory. Try --help for help.
- If you try to run this command without an environment name you will get
Error: Needs environment name. Try --help for help.
- If you already initialized the current directory in Kaiser you will get this message:
Error: Already initialized as hats. Try --help for help.
kaiser up
This command will bring up the app in the current directory, but only if it was initialized using kaiser init
.
Usually in user testing we noticed that most people prefer to start up their environment using kaiser up -av
.
Options
-a
--attach
Attach
Attaches to the process after starting up. By default Kaiser will start up the app and run in the background. Using this parameter the process will run in the foreground, which can be useful for debugging or if you are in a GUI where switching terminals is very easy.
If you use this option, and bash exit
or Ctrl+C interrupt out and the process you started ends, it will close the process. Unlike if you ran kaiser up
without this option, and then ran kaiser attach
.
Parameters
This command takes a command line as parameters, which means you can go kaiser up -av bash
. This will start the application in the foreground and run bash
. You can also use it to go kaiser up -av rails c
or kaiser up -av sh -c 'mylongcommand; andmorestuff'
or whatever suits your fancy.
Errors
- If you try running this command in a directory that has not been initialized, you will get the error:
Error: No environment? Please use kaiser init <name>. Try --help for help.
kaiser login <cmd>
If there already exists a running process that was started by kaiser up
, you can simply login from the side using the default user as defined in its Dockerfile this way. Usually you want to provide a parameter, such as kaiser login bash
or something. It will always be started in TTY and interactive.
Errors
- If you try and run this in a dir where the process is not up and running, you will get a message like this:
Error response from daemon: No such container: hats-app
or one like this:
Error response from daemon: container ceff5f43ca1632294512afd1ed88e30d051bd97438204bb34674fea75e001eab is not running
kaiser root <cmd>
This command is essentially the same as kaiser login
except it forces the login to use the root
user. This can sometimes be useful if the container was built with very tight perms on the user, or does not have sudo
installed in it.
kaiser show <thing>
This shows special globals that were set using kaiser set
. Valid parameters right now are
ports
cert-source
http-suffix
Parameters
ports
Ports reserved for app
This tells you what ports are reserved for the app. While most traffic should go to the thing through the environment name, sometimes you want the actual port number if you want to connect to it to check stuff. Example output is:
app: 9015 db: 9016
cert-source
Certificate source
This tells you the URL from which SSL/HTTPS certificates are downloaded from. You can use this to check if you have it set to the right URL.
http-suffix
HTTP Suffix
This tells you what the HTTP suffix is. See suffixes. Usually you use this with conjunction with the cert source above so you can request wildcard certificates from domains you own and then tell nginx to serve those suffixes so you can have an SSL setup on your local.
Errors
- If you do not specify what thing,
kaiser
will try to be helpful and tell you:
Error: Available things to show: ports cert-source http-suffix. Try --help for help.
kaiser shutdown
This command shuts down all the containers started by Kaiser.
kaiser deinit
This command removes the current environment from the kaiser configuration, and essentially undoes the effects of the kaiser init
command.
kaiser db_save
This command saves the current state of the database of the application. By default it saves it in a file in the $HOME/.kaiser
directory. But you can also specify a file for it to write to by going kaiser db_save ./mydb.mysql
.
Notes
The default save file is actually git branch aware. What this means is that kaiser checks what git branch it is in right now and keys the file on that branch name.
This means that if you
- checked out the
main
branch - ran
kaiser db_save
and then - checked out
mybranch
branch and then - ran
kaiser db_save
it will save the state to a different file and not overwrite the db state saved when you were in the main
branch. How it saves this file is actually an implementation detail and we don't make any guarantees about how it really works or if it will not change.
kaiser db_load
This command loads the saved state of the database of an application (if one exists), and destroys the previous state. By default it loads the file for the branch you are on. You can provide a parameter to load a file instead, like kaiser db_load ./mydb.mysql
kaiser db_reset
This command re-runs the command defined in the db_reset_command
in the Kaiserfile.
kaiser db_reset_hard
Sometimes a db state can become somewhat inconsistent or the command defined by db_reset_command
in the Kaiserfile does not handle all cases of db consistency. This command actually deletes the current state and re-initializes the database from scratch, and then runs the command defined by db_reset_command
. This can be used to work around a messed up database state.
kaiser set <key> <value>
Parameters
Valid <key>
parameters are:
http-suffix
- Sets the domain suffix for the reverse proxy to use (defaults to lvh.me)cert-url
- Sets up a URL from which HTTPS certificates can be downloaded.
For example you can go
kaiser set http-suffix local.aweso.me
and nginx will serve everything on that suffix, i.e. hats.local.aweso.me
.
Errors
- If you do not provide a key and value it will fail like this:
Error: Unknown subcommand: ''. Try --help for help.
kaiser attach
If you started kaiser using just kaiser up
without the --attach
option, you can use this command to "takeover" the process and bring it up to the foreground. This is useful if you intend to apply a breakpoint and interrupt the process, which means you want to be able to make it interactive so you can gracefully unbreakpoint it without having to kill it.
You can also Ctrl+C to interrupt out of this without closing the process, unlike if you used the --attach
option, which if you used that would close the process.