Building Zimbra on Fedora Core 5 and x86 64

 - This is archive documentation, which means it is not supported or valid for recent versions of Zimbra Collaboration.
Developer Article

Article Information

This article applies to the following ZCS versions.

ZCS 4.5 Article ZCS 4.5

This documentation is in the process of being rewritten. The documentation that comes with Zimbra is way out of date for source building.

First off all, note that if you want to add functionality to Zimbra's front end, look at Zimlet's. Zimbra's front end is almost completely javascript.

Grab JVM 1.5

First of all, go grab a real JVM. Fedora ships with gcj rather then a default Java JVM. You can get the JVM from (make sure it's version 1.5. Earlier versions don't support generics, version 6 has some SQL stuff that breaks ZimbraIM).

JVM 1.5 is also called JDK 5 and can be downloaded from Java SE Downloads - Previous Release - JDK 5 page

Check the Source Code out from Subversion

Check the source code out:

    svn co zimbra

Note that you may find references to CRAY versus Main. Those tags only mattered with the old cvs repository.

  you used the i386 version right? Zimbra doesn't provide a libzimbra-native jni library for x86-64 

Building the Web Server for Zimlets.

Zimbra uses a httpd instance for Zimlets and the spell checker. Apache 2.0.54 is used for this. Zimbra documentation has a tendency to be wrong about versions, so check the makefile carefully for whatever version the software is currently expecting.

  • Zimbra Folks... Would it be possible to put up a copy of the ThirdParty stuff uncompiled? You lose a lot of time just digging for the software

Build the web server:

  cd main/ThirdParty/apache-httpd
  sudo make

The final output should look like:

  (cd /opt/zimbra; tar czf \
  /home/Projects/Source/Zimbra/main/ThirdParty/apache-httpd/builds/UNKNOWN/httpd-2.0.54.tgz \
  chmod -R a+w \

Amavisd -- Mail filtering in the Secure Layer

Zimbra segregates itself by using two seperate mail systems. The first email server is Postfix. Postfix receives the emails from the outside world and passes them on to a perl program called Amavis. Amavis integrates Postfix with Spamassasin, ClamAV and DSPAM and provides standard site wide filtering actions and returns the email to postfix.

  • Be very careful if you are screwing with Postfix. Chances are you could probably do it in Amavis.
  • Be cautious about security. Postfix is designed to be fast and secure, but email security problems have only recently be passed by web security problems as hackers entry way of choice.

To Install Amavisd, you need to do the following:

 cd ../amavisd
 tar xzf amavisd-new-2.3.3.tar.gz
 cd amavisd-new-2.3.3
 patch -p0 < ../amavisd.2.3.3.patch

Amavis does not have a Makefile. We can't test the build until we build the whole thing.

Net Snmp

Net Snmp monitors the server in the industry standard snmp format.

  mkdir ../snmp
  get net-snmp-5.1.2.tar.gz # (You have to dig for this. I found it at
  tar xzf net-snmp-5.1.2.tar.gz
  cd net-snmp-5.1.2
  ./configure --prefix=/opt/zimbra/snmp-5.1.2 # ( Some questions where asked here. I went with the defaults, but if anything breaks, this is a good thing to check)
  sudo make install
  cd /opt/zimbra
  sudo tar czf snmp-5.1.2.tar.gz snmp-5.1.2
  echo Do the last two steps manually
  # cd  your zimbra Directory/ThirdParty/snmp
  # sudo /opt/zimbra/snmp-5.1.2.tar.gz .


Aspell enables the spelling service for Zimbra. Unfortuntily the version of aspell is behind the times and has a few problems with the more modern gcc-g++. So we are going to build this package using the compat-gcc instead (GCC 3.2). To do that, change the Makefile in the aspell directory. Go to the line that includes ./configure and change it to be the following:

  ./configure --prefix=/opt/zimbra/aspell-$(ASPELL_VERSION) CXX=g++32; make)

Newer version of Aspell also have this problem. Revised install:

  cd ../aspell
  EDITOR=`if [ ! "x$EDITOR" = "x" ]; then echo $EDITOR; else if [ -f /usr/bin/editor ]; then echo /usr/bin/editor; else echo $(which vi); fi; fi`
  $EDITOR Makefile # Edit the make file and change the configure line to (tab)    ./configure --prefix=/opt/zimbra/aspell-$(ASPELL_VERSION) CXX=g++32; make)

--BEGIN-- To build with GCC g++ > 3.2 edit the following file:

  -    bool NroffFilter::process_char (FilterChar::Chr c);
  +    bool process_char (FilterChar::Chr c);

then repack it and continue

  tar czf aspell-0.60.3.tar.gz aspell-0.60.3

--END-- 2006-11-23, Nicolas Mendoza <>


ClamAV provides the basic virus protection for Zimbra.

Since the instructions on this section are wrong, I redid this section with the newest clamav.

Edit the Make file in the clamav folder to point at the new version

    CLAMAV_VERSION ?= 0.88.2
    sudo make

The very last part of it fails because of the extra .2

    sudo tar czf /home/Projects/Source/Zimbra/main/ThirdParty/clamav/builds/UNKNOWN/clamav-0.88.2.tgz clamav-0.88/
  • You can keep this last part from failing if you make one further change to the makefile. Under the build target, change the configure line from this: --C. Bailey 5/14/06
       ./configure --prefix=/opt/zimbra/clamav-0.88

to this:

       ./configure --prefix=/opt/zimbra/clamav-$(CLAMAV_VERSION)


Tomcat is the primary web server for the Java backends

  mkdir ../jakarta-tomcat
  cd ../jakarta-tomcat


   cd ../mysql
   mkdir FC5
   ln -s FC5 UNKNOWN
   cd FC5

Here comes the interesting part. The howto says to grab a client libs zip, that does't exist. So we need to built it ourselves:

   tar xvfz mysql-4.1.16.tar.gz
   cd mysql-4.1.16
   cd libmysql
   cd .libs/
   tar cvfz mysql-standard-4.1.16-clientlibs.tgz

Then copy that intothe mysql/unknown directory. From Mysql

  mkdir -p /opt/zimbra
  (cd /opt/zimbra; \
  tar xzf /home/Projects/Source/Zimbra/main/ThirdParty/mysql/UNKNOWN/mysql-standard-4.1.16-pc-linux-gnu-i686-glibc23.tar.gz)
  (cd /opt/zimbra/mysql-standard-4.1.16-pc-linux-gnu-i686-glibc23/lib; \
  tar xzf /home/Projects/Source/Zimbra/main/ThirdParty/mysql/UNKNOWN/mysql-standard-4.1.16-clientlibs.tgz)

LDAP and the rest of the executables:

  cd ../openldap
  wget (Wrong version in documentation)
  cd ../php
  cd ../PostFix/Postfix-2.2.5
  cd ../../sleepycat
  cd ../openldap
  tar xzf openldap-2.2.28.tgz
  # cp openldap-2.2.28/build/BerkeleyDB42.patch ../sleepycat # Since we are using a later version of openldap, this file no longer appears to exist. 
  cd ../sleepycat
  tar xzf db-4.2.52.tar.gz
  cd db-4.2.52
  patch -p0 < ../patch.
  patch -p0 < ../patch.
  patch -p0 < ../patch.
  patch -p0 < ../patch.
  # patch -p0 < ../BerkeleyDB42.patch #  Couldn't find this file. ** no longer necessary as of
  cd ..
  mv db-4.2.52 db-
  tar czf db- db-
Verified Against: unknown Date Created: 5/9/2006
Article ID: Date Modified: 03/24/2015

Try Zimbra

Try Zimbra Collaboration with a 60-day free trial.
Get it now »

Want to get involved?

You can contribute in the Community, Wiki, Code, or development of Zimlets.
Find out more. »

Looking for a Video?

Visit our YouTube channel to get the latest webinars, technology news, product overviews, and so much more.
Go to the YouTube channel »

Jump to: navigation, search