HomePage » WebServer » Apache » ApacheSourceInstall


Compiling and installing apache from source.

Apache2.3.12-beta from source

I built apr, apu, and openssl from source. The first two are needed because apache-2.3 requires apr-1.4 which is available with ubuntu11. Without these three, mod_ssl, mod_rewrite, and mod_auth_digest won't work. Openssl is built with the following options:
sh config no-threads -fPIC --prefix=/opt/ssl


Then compile apache
./configure  --enable-rewrite --disable-userdir \
--disable-negotiation --enable-vhost-alias --enable-info \
--enable-heartbeat --enable-heartmonitor --enable-lbmethod-heartbeat \
--enable-lbmethod-bybusyness --enable-lbmethod-bytraffic \
--enable-lbmethod-byrequests --enable-static-ab --enable-ssl \
--enable-proxy-ajp --enable-proxy-balancer --enable-proxy-http \
--enable-proxy-connect  --enable-proxy --enable-deflate \
--enable-so --enable-cache --enable-disk-cache --enable-file-cache \
--enable-mods-shared=most --prefix=/usr/local/apache \
--with-apr=/usr/bin/apr-1-config --with-apr-util=/usr/bin/apu-1-config --with-ssl=/opt/ssl 
# --enable-mpms-shared=event,prefork,worker
# --enable-privileges  Per-virtualhost Unix UserIDs and enhanced security for Solaris
# heartbeat is still under development, perhaps I should skip them during compilation


Here's what I have
# httpd -V
Server version: Apache/2.3.5 (Unix)
Server built:   Feb 24 2010 21:27:04
Server's Module Magic Number: 20091230:2
Server loaded:  APR 1.4.3-dev, APR-UTIL 1.4.0-dev
Compiled using: APR 1.4.3-dev, APR-UTIL 1.4.0-dev
Architecture:   64-bit
Server MPM:     event
  threaded:     yes (fixed thread count)
	forked:     yes (variable process count)



Apache2.2.11 build rpm

Download the apache tar bz2 file
Edit httpd.spec and remove a tag that is not supported
Create a tgz archive
....
rpmbuild -tb httpd-2.2.11.tar.gz

Apache2.2.4 quick compile (RedHat layout)

./configure --prefix=/etc/httpd --sysconfdir=/etc/httpd/conf \
--enable-mods-shared=all --enable-ssl --enable-rewrite --enable-proxy \
--enable-proxy-ajp --enable-cache --enable-disk-cache --enable-mem-cache \
--docdir=/var/www/html --enable-layout=RedHat \
--libexecdir=/usr/lib64/httpd --bindir=/usr/bin --sbindir=/usr/sbin \
--libdir=/usr/lib64 --includedir=/usr/include  --enable-authn-dbm
# Optional
--with-mpm=worker : you need php compiled with thread safety (--enable-experimental-zts)


and you'll need a proper init script
#!/bin/bash
#
# httpd        Startup script for the Apache HTTP Server
#
# chkconfig: - 85 15
# description: Apache is a World Wide Web server.  It is used to serve \
#              HTML files and CGI.
# processname: httpd
# config: /etc/httpd/conf/httpd.conf
# config: /etc/sysconfig/httpd
# pidfile: /var/run/httpd.pid

# Source function library.
. /etc/rc.d/init.d/functions

if [ -f /etc/sysconfig/httpd ]; then
		. /etc/sysconfig/httpd
fi

# Start httpd in the C locale by default.
HTTPD_LANG=${HTTPD_LANG-"C"}

# This will prevent initlog from swallowing up a pass-phrase prompt if
# mod_ssl needs a pass-phrase from the user.
INITLOG_ARGS=""

# Set HTTPD=/usr/sbin/httpd.worker in /etc/sysconfig/httpd to use a server
# with the thread-based "worker" MPM; BE WARNED that some modules may not
# work correctly with a thread-based MPM; notably PHP will refuse to start.

# Path to the apachectl script, server binary, and short-form for messages.
apachectl=/usr/local/apache2/bin/apachectl
httpd=${HTTPD-/usr/local/apache2/bin/httpd}
prog=httpd
pidfile=${PIDFILE-/var/run/httpd.pid}
lockfile=${LOCKFILE-/var/lock/subsys/httpd}
RETVAL=0

# check for 1.3 configuration
check13 () {
		CONFFILE=/usr/local/apache2/conf/httpd.conf
		GONE="(ServerType|BindAddress|Port|AddModule|ClearModuleList|"
		GONE="${GONE}AgentLog|RefererLog|RefererIgnore|FancyIndexing|"
		GONE="${GONE}AccessConfig|ResourceConfig)"
		if LANG=C grep -Eiq "^[[:space:]]*($GONE)" $CONFFILE; then
				echo
				echo 1>&2 " Apache 1.3 configuration directives found"
				echo 1>&2 " please read /usr/share/doc/httpd-2.2.3/migration.html"
				failure "Apache 1.3 config directives test"
				echo
				exit 1
		fi
}

# The semantics of these two functions differ from the way apachectl does
# things -- attempting to start while running is a failure, and shutdown
# when not running is also a failure.  So we just do it the way init scripts
# are expected to behave here.
start() {
		echo -n $"Starting $prog: "
		check13 || exit 1
		LANG=$HTTPD_LANG daemon $httpd $OPTIONS
		RETVAL=$?
		echo
		[ $RETVAL = 0 ] && touch ${lockfile}
		return $RETVAL
}

# When stopping httpd a delay of >10 second is required before SIGKILLing the
# httpd parent; this gives enough time for the httpd parent to SIGKILL any
# errant children.
stop() {
		echo -n $"Stopping $prog: "
		killproc -d 10 $httpd
		RETVAL=$?
		echo
		[ $RETVAL = 0 ] && rm -f ${lockfile} ${pidfile}
}
reload() {
	echo -n $"Reloading $prog: "
	if ! LANG=$HTTPD_LANG $httpd $OPTIONS -t >&/dev/null; then
		RETVAL=$?
		echo $"not reloading due to configuration syntax error"
		failure $"not reloading $httpd due to configuration syntax error"
	else
		killproc $httpd -HUP
		RETVAL=$?
	fi
	echo
}

# See how we were called.
case "$1" in
  start)
		start
		;;
  stop)
		stop
		;;
  status)
		status $httpd
		RETVAL=$?
		;;
  restart)
		stop
		start
		;;
  condrestart)
		if [ -f ${pidfile} ] ; then
				stop
				start
		fi
		;;
  reload)
		reload
		;;
  graceful|help|configtest|fullstatus)
		$apachectl $@
		RETVAL=$?
		;;
  *)
		echo $"Usage: $prog {start|stop|restart|condrestart|reload|status|fullstatus|graceful|help|configtest}"
		exit 1
esac

exit $RETVAL


Apache 2.0 compile

./configure --prefix=/opt/apache2 --enable-mods-shared=all \
--enable-ssl --enable-rewrite --enable-proxy --enable-deflate \
--enable-cache --enable-disk-cache --enable-file-cache --enable-mem-cache \
--enable-suexec


Useful configure options
--enable-layout=xxx : check config.layout for detail
http://httpd.apache.org/docs/2.2/programs/configure.html

Apache 1.3.x compile

You will be needing the following packages:

apache_1.3.14.tar.gz http://www.apache.org
openssl-0.9.6.tar.gz http://www.openssl.org
mod_ssl-2.7.1-1.3.14.tar.gz http://www.modssl.org
mm-1.1.3.tar.gz http://www.engelschall.com/sw/mm

Installing the prerequisites
openssl
sh config -fPIC
make -j2 
make install


mm
./configure --disable-shared
make
make install


Apache and mod_ssl
Apache
./configure  --enable-module=so --enable-module=proxy
make -j2 
make install


mod_ssl
./configure \
--with-apache=../$apache_ver \
--with-ssl=../$ssl_ver \
--with-mm=../$mm_ver \
--prefix=/usr/local/apache \
--enable-shared=ssl \
--enable-module=proxy 

or
./configure \
--with-apache=../apache_1.3.x \
--expert --with-ssl=/usr


Back to Apache
make -j2
make certificate
make install

or
env CFLAGS="-Wall -DHARD_SERVER_LIMIT=1024" ./configure \
--prefix=/usr/local/apache \
--enable-module=so \
--enable-shared=max \
--enable-module=ssl 


Install from FreeBSD ports
cd /usr/ports/www/apache22/
make config install distclean
echo 'apache2_enable="YES"' >> /etc/rc.conf
echo 'apache2ssl_enable="YES"' >> /etc/rc.conf
echo 'accf_http_ready="YES"' >> /etc/rc.conf && kldload accf_http



What about stupid solaris?
What does this tell you? Everything that comes with solaris by default don't fking work.

env PATH=/usr/bin:/usr/ccs/bin:/opt/SUNWspro/bin \
CC=cc CFLAGS=-fast CPPFLAGS="-D_LARGEFILE_SOURCE -D_FILE_OFFSET_BITS=64" \
./configure --prefix=/usr/local/apache2 --enable-mods-shared=all \
--enable-ssl --enable-rewrite --enable-proxy --enable-proxy-ajp \
--enable-cache --enable-disk-cache --enable-mem-cache \
--with-mpm=worker 


There are no comments on this page. [Add comment]

Valid XHTML 1.0 Transitional :: Valid CSS :: Powered by WikkaWiki