3.15. One Installation, Multiple Instances¶
This is a somewhat specialist feature; if you don’t know whether you need it, you don’t. It is useful to admins who want to run many separate instances of Bugzilla from a single installed codebase.
This is possible by using the PROJECT
environment variable. When accessed,
Bugzilla checks for the existence of this variable, and if present, uses
its value to check for an alternative configuration file named
localconfig.<PROJECT>
in the same location as
the default one (localconfig
). It also checks for
customized templates in a directory named
<PROJECT>
in the same location as the
default one (template/<langcode>
). By default
this is template/en/default
so PROJECT
’s templates
would be located at template/en/PROJECT
.
To set up an alternate installation, just export PROJECT=foo
before
running checksetup.pl for the first time. It will
result in a file called localconfig.foo
instead of
localconfig
. Edit this file as described above, with
reference to a new database, and re-run checksetup.pl
to populate it. That’s all.
Now you have to configure the web server to pass this environment variable when accessed via an alternate URL, such as virtual host for instance. The following is an example of how you could do it in Apache, other Webservers may differ.
<VirtualHost 12.34.56.78:80>
ServerName bugzilla.example.com
SetEnv PROJECT foo
</VirtualHost>
Don’t forget to also export this variable before accessing Bugzilla by other means, such as repeating tasks like those above.
This documentation undoubtedly has bugs; if you find some, please file them here.