[rt-users] FUNCTIONING: RT on RHEL 4 with FastCGI and MySQL Install Procedure

William Harrison harrison at itrd.gov
Fri Mar 18 16:36:53 EST 2005



Well, thanks to hard work and effort from others, this procedure has been verified to work across at least three installations of RHEL 4. If you think it would be of value, I'm happy to add it to the wiki.

Installation procedure follows... 


-William



Installing RT on RHEL 4 with FastCGI and MySQL:

Start with a standard install of RHEL, then upgrade / up2date / whatever to get latest versions of installed packages. Then make sure you have the following packages as well:
  httpd-devel
  mysql
  mysqlclient10
  mysql-server
  mysql-devel
  gcc

Install FastCGI...
  wget http://www.fastcgi.com/dist/mod_fastcgi-2.4.2.tar.gz
  gunzip mod_fastcgi-2.4.2.tar.gz
  tar -xvf mod_fastcgi-2.4.2.tar
  cd mod_fastcgi-2.4.2
  cp Makefile.AP2 Makefile
  edit Makefile:
    ###Modify for location of apache 2 installation:
    top_dir      = /etc/httpd
  make
  make install
  edit /etc/httpd/conf/httpd.conf
    ###Add line to load FastCGI module:
    LoadModule fastcgi_module modules/mod_fastcgi.so
  ### FastCGI wants to have a place to put its logs, and permission to do so:
    mkdir /etc/httpd/logs/fastcgi
    mkdir /etc/httpd/logs/fastcgi/dynamic
    chown apache:apache /etc/httpd/logs/fastcgi
    chown apache:apache /etc/httpd/logs/fastcgi/dynamic
  service httpd start
  ### Check Apache logs to make sure fastcgi started
    less /var/log/httpd/error_log
    ### Should see no lines with [error] referencing FastCGI
    ### Should see one line indicating a [notice] and the pid of FastCGI
      ### [Mon Mar 14 9:16:57 2005] [notice] FastCGI: process manager initialized (pid 3478)


Turn on MySQL server, Apache server, set MySQL root password...
  chkconfig httpd on
  chkconfig mysqld on
  service mysqld start
  mysqladmin -u root password newpass


Set up CPAN initially...
  perl -MCPAN -e shell


RT Pre-Install...
  ### RT requires its own group, so let's add it now lest we forget:
    groupadd rt
  ### RT gets initiated by apache, so add apache to the rt group:
    edit /etc/group
    ### Change the line:
    ### rt:x:501:
    ### to read:
    ### rt:x:501:apache
  ### Disable selinux (or make sure it is disabled):
     edit /etc/selinux/config
     ### Change the line:
     ### SELINUX=enforcing
     ### or
     ### SELINUX=permissive
     ### to read:
     ### SELINUX=disabled
  ### Change permissions on /etc/httpd/logs from within
     cd /etc/htttpd/logs
     chmod 755 .


Install RT...
  wget http://download.bestpractical.com/pub/rt/release/rt-3.4.1.tar.gz
  gunzip rt.tar.gz
  tar -xvf rt.tar
  cd rt-3.4.1/
  ### Set up the makefile for us with the proper settings:
    ./configure --with-web-user=apache --with-web-group=apache --with-mysql --with-fastcgi
  ### Show us what's missing and what's not:
    perl sbin/rt-test-dependencies --with-mysql --with-fastcgi --verbose
  ### Try to install what's missing for us through CPAN:
    perl sbin/rt-test-dependencies --with-mysql --with-fastcgi --install
  ### Test again and only show us the MISSING items this time:
    perl sbin/rt-test-dependencies --with-mysql --with-fastcgi --verbose | grep MISSING
  ### MIME::Entity won't install without MIME::Base64, so install that first:
    perl -MCPAN -e 'install MIME::Base64'
  ### Now install MIME::Entity:
    perl -MCPAN -e 'install MIME::Entity'
  ### Try to install anything else missing for us:
    perl sbin/rt-test-dependencies --with-mysql --with-fastcgi --install
  ### Test again and make sure nothing is MISSING:
    perl sbin/rt-test-dependencies --with-mysql --with-fastcgi --verbose | grep MISSING
  ### Assuming everything is present and it's a go, install and intialize database...
    make install
    make initialize-database
  ### Make a copy of the dist config file to edit:
    cp /opt/rt3/etc/RT_Config.pm /opt/rt3/etc/RT_SiteConfig.pm
  ### Edit your RT config file for your purposes:
    edit /opt/rt3/etc/RT_SiteConfig.pm
    ### Change the line:
    ### Set($WebBaseURL , "http://RT::WebBaseURL.not.configured:80");
    ### to read:
    ### Set($WebBaseURL , "http://your.ip.address:80");
    ### Change the line:
    ### Set($WebPath , "");
    ### to read:
    ### Set($WebPath , "/rt");
  ### Edit your Apache config file as well:
    edit /etc/httpd/conf/httpd.conf
    ###  NameVirtualHost *:80
    ###  <VirtualHost *:80>
    ###    ServerAdmin root
    ###    DocumentRoot /var/www/html/
    ###    # Adding the following for RT (the ticket tracker)
    ###    AddHandler fastcgi-script fcgi
    ###    <Directory "/opt/rt3/share/html">
    ###      Options FollowSymLinks ExecCGI
    ###      AllowOverride None
    ###    </Directory>
    ###    # Pass through requests to display images
    ###    Alias /NoAuth/images/ /opt/rt3/share/html/NoAuth/images/
    ###  </VirtualHost>
    ###  FastCgiServer /opt/rt3/bin/mason_handler.fcgi -idle-timeout 120
    ###  ScriptAlias /rt /opt/rt3/bin/mason_handler.fcgi


  ###Restart Apache:
    service httpd stop
    service httpd start





More information about the rt-users mailing list