Bugzilla:Win32Install: Difference between revisions

about 10% content modified to make it correct and up to date.
(about 10% content modified to make it correct and up to date.)
Line 76: Line 76:


Extract the archive to the directory of your choice. For the remainder of this document I will assume that you have extracted Bugzilla into <b>C:\Bugzilla</b>.
Extract the archive to the directory of your choice. For the remainder of this document I will assume that you have extracted Bugzilla into <b>C:\Bugzilla</b>.
Have a check after you extracted it, as you probably extracted it to location such as <b>C:\Bugzilla\bugzilla-3.3.2</b> which is not what you want.


====Upgrading From TarBall====
====Upgrading From TarBall====
Line 91: Line 93:
====Install====
====Install====


MySQL has a standard Windows installer.  It's ok to select a Typical MySQL install (the default).  For the remainder of this document I will assume you have installed MySQL into <b>C:\mysql</b>.
MySQL has a standard Windows installer.  It's ok to select a Typical MySQL install (the default).  For the remainder of this document I will assume you have installed MySQL into default location <b>C:\Program Files\MySQL\MySQL Server 5.0</b>, with default port number <b>3306</b>, and password <b>sockmonkey</b> which is my favorite.


====Create Bugs Database and User====
====Create Bugs Database and User====
Line 97: Line 99:
Use the <b>mysql</b> command line utility to create the Bugzilla database and a MySQL account for Bugzilla.
Use the <b>mysql</b> command line utility to create the Bugzilla database and a MySQL account for Bugzilla.


Note in the following example 'sockmonkey' is my password for the bugs account:
  C:\Program Files\MySQL\MySQL Server 5.0\bin&gt;<b>mysql --user=root -p mysql</b>
 
  C:\mysql\bin&gt;<b>mysql --user=root -p mysql</b>
   
   
  Enter password: <b>********</b>
  Enter password: <b>sockmonkey</b>
  Welcome to the MySQL monitor.  Commands end with ; or \g.
  Welcome to the MySQL monitor.  Commands end with ; or \g.
  Your MySQL connection id is 15 to server version: 4.0.20a-debug
  Your MySQL connection id is 2
Server version: 5.0.67-community-nt MySQL Community Edition (GPL)
   
   
  Type 'help;' or '\h' for help. Type '\c' to clear the buffer.
  Type 'help;' or '\h' for help. Type '\c' to clear the buffer.
Line 121: Line 122:
  Bye
  Bye
   
   
  C:\mysql\bin&gt;
  C:\Program Files\MySQL\MySQL Server 5.0\bin&gt;


If you are running MySQL 4.1, you may encounter the <b>Client does not support authentication protocol requested by server</b> error message.  To fix this, once the user has been created you will have to reset the password using OLD_PASSWORD:
If you are running MySQL 4.1, you may encounter the <b>Client does not support authentication protocol requested by server</b> error message.  To fix this, once the user has been created you will have to reset the password using OLD_PASSWORD:


  C:\mysql\bin&gt;<b>mysql --user=root -p mysql</b>
  C:\mysql\bin&gt;<b>mysql --user=root -p mysql</b>
  Enter password: <b>********</b>
  Enter password: <b>sockmonkey</b>
   
   
  Welcome to the MySQL monitor.  Commands end with ; or \g.
  Welcome to the MySQL monitor.  Commands end with ; or \g.
Line 176: Line 177:
====Install Modules====
====Install Modules====


Bugzilla requires a number of perl modules to be installed. They are either available in the ActiveState repository, or at <b>http://theoryx5.uwinnipeg.ca/ppms/</b> (Perl 5.8.x) or <b>http://cpan.uwinnipeg.ca/PPMPackages/10xx/</b> (Perl 5.10.x).
Bugzilla requires a number of perl modules to be installed. They are either available in the ActiveState repository, or at <b>http://theoryx5.uwinnipeg.ca/ppms/</b> (Perl 5.8.x) or <b>http://cpan.uwinnipeg.ca/PPMPackages/10xx/</b> (Perl 5.10.x). You should use PPM program install them from Internet into your local computer. Later you will see an example (Example 1) with details.


If you use a proxy server or a firewall you may have trouble running PPM.  This is covered in the [http://aspn.activestate.com/ASPN/docs/ActivePerl/faq/ActivePerl-faq2.html#ppm_and_proxies ActivePerl FAQ].
If you use a proxy server or a firewall you may have trouble running PPM.  This is covered in the [http://aspn.activestate.com/ASPN/docs/ActivePerl/faq/ActivePerl-faq2.html#ppm_and_proxies ActivePerl FAQ].


The <b>Net::LDAP</b> module is only required if you want to [http://www.bugzilla.org/docs/tip/html/extraconfig.html#bzldap use Active Directory for authentication].
If it still doesn't work, or you just don't like this way, you have another choice here. Instead of run PPM directly, you may download installation packages manually into your local computer firstly, and then run PPM to install them. These kind of installation packages are available in <b>http://cpan.uwinnipeg.ca/PPMPackages/10xx/zips/</b> (Perl 5.10.x). Later you will see an example (Example 2) with details for this kind of ppm local installation.
 
While, up to now, you still do not know which perl modules should be installed. To know this, use command below:
 
C:\Bugzilla&gt;<b>perl checksetup.pl --check-modules</b>
 
Then the script will tell you which modules are needed, under this line:
 
Checking perl modules...
And which module is needed according to the database you use (MySQL), under this line:
 
Checking available perl DBD modules...
As well as which modules are optional, under this line:
 
The following Perl modules are optional:
 
The script will also tell you which modules are ok:
 
Checking for          PathTools (v0.84)  ok: found v3.2501
 
And which modules are too old:
 
Checking for              CGI.pm (v3.33)    found v3.29
As well as which modules were not installed yet:
 
Checking for            TimeDate (v2.21)    not found
 
You should install all the missing ones, and re-install all the out-of-date ones.
 
But that's not enough. As perl modules have dependencies among each other, when you install a perl module, the ppm program may tell you that some dependent modules are missing. Then you have to install these dependent modules firstly.
 
=====Example 1: 'Standard' PPM installation=====
 
Here we provide an exmaple of 'standard' installation method. The ppm program will get modules from internet and install them into your local computer.
 
Note 1: This example is a bit out-of-date. In recent ActiveState Perl version (v5.10.x), when you type
 
C:\&gt;<b>ppm</b>
 
The GUI will pop up instead of command line environment showed in this example. While, it's still possible to run under command line. Try
 
C:\&gt;<b>ppm install TimeDate </b>
 
instead of
 
C:\&gt;<b>ppm</b>
ppm&gt; <b>install TimeDate</b>
 
Note 2: The module list below may not correct for you. Pls use script <b>checksetup.pl</b> to have a check. See below.
 
Note 3: The <b>Net::LDAP</b> module is only required if you want to [http://www.bugzilla.org/docs/tip/html/extraconfig.html#bzldap use Active Directory for authentication].
 
OK. Here is the example:


  C:\&gt;<b>ppm</b>
  C:\&gt;<b>ppm</b>
Line 192: Line 248:
  Type 'help' to get started.
  Type 'help' to get started.
   
   
  ppm&gt; <b>rep add Bugzilla http://...uwinnipeg.ca/...</b>
  ppm&gt; <b>rep add Bugzilla http://theoryx5.uwinnipeg.ca/ppms/</b>
   
   
  Repositories:
  Repositories:
Line 298: Line 354:
  Successfully installed Net-LDAP-Express version 0.11 in ActivePerl 5.8.7.813.
  Successfully installed Net-LDAP-Express version 0.11 in ActivePerl 5.8.7.813.
  ppm&gt;
  ppm&gt;
And then, have a check:
C:\Bugzilla&gt;<b>perl checksetup.pl --check-modules</b>
=====Example 2: PPM local installation=====
As mentioned above, instead of run PPM directly, you may download installation packages into your local computer, and then run PPM to install them.
Note: Again, the module list below may not correct for you. Pls use script <b>checksetup.pl</b> to have a check. See belew.
Step 1: Download installation packages from <b>http://cpan.uwinnipeg.ca/PPMPackages/10xx/zips/</b> (for Perl 5.10.x). Below is the sorted list:
AppConfig.zip
CGI.pm.zip
DBD-mysql.zip
Email-Address.zip
Email-MessageID.zip
Email-MIME.zip
Email-MIME-ContentType.zip
Email-MIME-Encodings.zip
EMail-MIME-Modifier.zip
Email-Send.zip
Email-Simple.zip
MIME-Types.zip
Return-Value.zip
Template-Toolkit.zip
TimeDate.zip
Let's say you downloaded them into folder <b>C:\perl_modules</b>.
Step 2: Unpack the zip packages. Each zip file will be unpacked into 3 files: xxx.tar.gz, xxx.ppd, and a readme file. The readme file is not so valuable that you could throw it away.
Let's say you extracted all tar.gz files and ppd files into folder <b>C:\perl_modules</b>.
Step 3: Run ppm commands listed below. Keep in this order, or you will probably meet dependency problem:
C:\perl_modules&gt;<b>ppm install CGI.pm.ppd</b>
C:\perl_modules&gt;<b>ppm install TimeDate.ppd</b>
C:\perl_modules&gt;<b>ppm install AppConfig.ppd</b>
C:\perl_modules&gt;<b>ppm install Template-Toolkit.ppd</b>
C:\perl_modules&gt;<b>ppm install Return-Value.ppd</b>
C:\perl_modules&gt;<b>ppm install Email-Address.ppd</b>
C:\perl_modules&gt;<b>ppm install Email-Simple.ppd</b>
C:\perl_modules&gt;<b>ppm install Email-Send.ppd</b>
C:\perl_modules&gt;<b>ppm install Email-MIME-ContentType.ppd</b>
C:\perl_modules&gt;<b>ppm install Email-MIME-Encodings.ppd</b>
C:\perl_modules&gt;<b>ppm install MIME-Types.ppd</b>
C:\perl_modules&gt;<b>ppm install Email-MIME.ppd</b>
C:\perl_modules&gt;<b>ppm install Email-MessageID.ppd</b>
C:\perl_modules&gt;<b>ppm install EMail-MIME-Modifier.ppd</b>
C:\perl_modules&gt;<b>ppm install DBD-mysql.ppd</b>
Step 4: Run <b>checksetup.pl</b> to have a check.
C:\Bugzilla&gt;<b>perl checksetup.pl --check-modules</b>


===Apache===
===Apache===
Line 305: Line 419:
====Download Apache 2.x====
====Download Apache 2.x====


Download the Apache HTTP Server version 2.x or high from: http://httpd.apache.org/download.cgi (5.8 Meg).
Download the Apache HTTP Server version 2.x or high from: http://httpd.apache.org/download.cgi (5.8 Meg). Let's say you downloaded version 2.2.


====Install====
====Install====


Yet another standard Windows Installer.  Just follow the prompts, making sure you Install for All Users. Be aware the Apache will always install itself into an <b>Apache2</b> directory under what ever path you specify.  The default install path will be displayed as <b>C:\Program Files\Apache Group</b> which will result in Apache being installed to <b>C:\Program Files\Apache Group\Apache2</b>.  This gets me every time.
Yet another standard Windows Installer.  Just follow the prompts, making sure you Install for All Users. For the remainder of this document I will assume you installed Apache into the default location, <b>C:\Program Files\Apache Software Foundation\Apache2.2</b>.
 
For the remainder of this document I will assume you installed Apache into the default location, <b>C:\Program Files\Apache Group\Apache2</b>.


If you are already running IIS, you must configure apache to run on a port other than 80, however you aren't asked the port to listen on at install time.  Choose <b>All Users</b> (which says port 80), and we'll change the port later.
If you are already running IIS, you must configure apache to run on a port other than 80, however you aren't asked the port to listen on at install time.  Choose <b>All Users</b> (which says port 80), and we'll change the port later.
Line 322: Line 434:


*C:\Bugzilla\data
*C:\Bugzilla\data
*C:\Program Files\Apache Group\Apache2\logs
*C:\Program Files\Apache Software Foundation\Apache2.2\logs
*C:\Temp
*C:\Temp


Line 329: Line 441:
====Configure Port and DocumentRoot====
====Configure Port and DocumentRoot====


Edit <b>C:\Program Files\Apache Group\Apache2\conf\httpd.conf</b> with your [http://www.vim.org/ favourite text editor].
Edit <b>C:\Program Files\Apache Software Foundation\Apache2.2\conf\httpd.conf</b> with your [http://www.vim.org/ favourite text editor]. It's a good idea to backup it before edit.


To change the port that Apache runs on (listens on, or binds to), edit the <b>Listen</b> option.
To change the port that Apache runs on (listens on, or binds to), edit the <b>Listen</b> option.
Line 411: Line 523:
  #
  #
  # The Options directive is both complicated and important.  Please see
  # The Options directive is both complicated and important.  Please see
  # http://httpd.apache.org/docs-2.0/mod/core.html#options
  # http://httpd.apache.org/docs/2.2/mod/core.html#options
  # for more information.
  # for more information.
  #
  #
Line 450: Line 562:
In order for <b>ScriptInterpreterSource Registry-Strict</b> to work, you also need to add an entry to the Registry so Apache will use Perl to execute .cgi files.
In order for <b>ScriptInterpreterSource Registry-Strict</b> to work, you also need to add an entry to the Registry so Apache will use Perl to execute .cgi files.


Create a key <b>HKEY_CLASSES_ROOT\.cgi\Shell\ExecCGI\Command</b> with the default value of the full path of perl.exe with a -T parameter.  For example <b>C:\Perl\bin\perl.exe -T</b>
In command line environment, type <b>regedit</b> to open Microsoft Registory Editor GUI. In Microsoft Registory Editor, create a key <b>HKEY_CLASSES_ROOT\.cgi\Shell\ExecCGI\Command</b> with the default value of the full path of perl.exe with a -T parameter.  For example <b>C:\Perl\bin\perl.exe -T</b>


[[Image:Bugzilla-Regedit.png|100px|Regedit]]
[[Image:Bugzilla-Regedit.png|300px|Regedit]]


====Disable Logging====
====Disable Logging====
Line 469: Line 581:
====Restart Apache====
====Restart Apache====


Finally, restart Apache to get it pick up the changes.
Finally, restart Apache to get it pick up the changes. Here take


  C:\&gt;<b>net stop apache2</b>
  C:\&gt;<b>net stop apache2.2</b>
  The Apache2 service is stopping..
  The Apache2.2 service is stopping..
  The Apache2 service was stopped successfully.
  The Apache2.2 service was stopped successfully.
   
   
  C:\&gt;<b>net start apache2</b>
  C:\&gt;<b>net start apache2.2</b>
  The Apache2 service is starting.
  The Apache2.2 service is starting.
  The Apache2 service was started successfully.
  The Apache2.2 service was started successfully.
   
   
  C:\&gt;
  C:\&gt;
Line 490: Line 602:


===Configure Bugzilla===
===Configure Bugzilla===
====checksetup.pl====
Run <b>checksetup.pl</b>.  This will check your Perl modules and create <b>localconfig</b>.
C:\&gt;<b>cd bugzilla</b>
C:\bugzilla&gt;<b>perl checksetup.pl</b>
Checking perl modules ...
Checking for      AppConfig (v1.52)  ok: found v1.55
Checking for            CGI (v2.93)  ok: found v3.10
Checking for    Data::Dumper (any)    ok: found v2.121_04
Checking for    Date::Format (v2.21)  ok: found v2.22
Checking for            DBI (v1.38)  ok: found v1.48
Checking for      File::Spec (v0.84)  ok: found v3.05
Checking for      File::Temp (any)    ok: found v0.16
Checking for        Template (v2.08)  ok: found v2.13
Checking for      Text::Wrap (v2001.0131) ok: found v2001.09293
Checking for    Mail::Mailer (v1.65)  ok: found v1.67
Checking for        Storable (any)    ok: found v2.13
The following Perl modules are optional:
Checking for              GD (v1.20)  ok: found v2.16
Checking for    Chart::Base (v1.0)    ok: found v2.3
Checking for    XML::Parser (any)    ok: found v2.34
Checking for      GD::Graph (any)    ok: found v1.43
Checking for GD::Text::Align (any)    ok: found v1.18
Checking for    PatchReader (v0.9.4)  ok: found v0.9.5
Most ActivePerl modules are available at Apache's ppm repository.
A list of mirrors is available at
    http://www.apache.org/dyn/closer.cgi/perl/win32-bin/ppms/
You can add the repository with the following command:
    ppm rep add apache http://www.apache.org/dist/perl/win32-bin/ppms/
Checking user setup ...
This version of Bugzilla contains some variables that you may want
to change and adapt to your local settings. Please edit the file
'./localconfig' and rerun checksetup.pl
The following variables are new to localconfig since you last ran
checksetup.pl:  index_html cvsbin interdiffbin diffpath create_htaccess
webservergroup db_driver db_host db_pass db_sock db_check
C:\bugzilla&gt;


====Edit localconfig====
====Edit localconfig====
Line 562: Line 627:
====checksetup.pl====
====checksetup.pl====


Run <b>checksetup.pl</b> again.  This time it will build your database tables and initialise Bugzilla.
Run <b>checksetup.pl</b> again.  This time it will build your database tables and initialise Bugzilla. You will be asked several questions during this script run. You should answer them seriously, typing in true information. For the question "your SMTP server's hostname", you may contact your IT colleagues for hint if you are working for your company now. Generally a company always has at least one internal SMTP server.  


  C:\bugzilla&gt;perl checksetup.pl
  C:\bugzilla&gt;perl checksetup.pl
Line 671: Line 736:
You should now be able to log into to Bugzilla using the account <b>checksetup.pl</b> just created.  Point your web browser to >http://localhost/, choose <b>Log in to an existing account</b>, and login.
You should now be able to log into to Bugzilla using the account <b>checksetup.pl</b> just created.  Point your web browser to >http://localhost/, choose <b>Log in to an existing account</b>, and login.


In the page footer, choose <b>Parameters</b>.
In the page showed up, click link <b>Parameters</b>. In the new page of parameters setting, put in your email address as the <b>maintainer</b>.
 
Put in your email address as the <b>maintainer</b>.


  maintainer:
  maintainer:
  <b>byron@example.com</b>
  <b>byron@example.com</b>


Put in the URL to Bugzilla in the <b>urlbase</b> field.  This URL will be used in emails, so don't use localhost.
And put in the URL to Bugzilla in the <b>urlbase</b> field.  This URL will be used in emails, so don't use localhost.


  urlbase:
  urlbase:
  <b>http://bugzilla.example.com/</b>
  <b>http://bugzilla.example.com/</b>
Download and install WebDot from http://www.graphviz.org/Download_windows.php.  Put the complete path to dot.exe in <b>webdotbase</b>.
webdotbase:
<b>C:/Program Files/ATT/Graphviz/bin/dot.exe</b>


===Scheduled Tasks===
===Scheduled Tasks===
2

edits