We are going to use Apache mod_php for running PHP scripts so we need to install apache2-mpm-preform MPM. MPM worker does not play nicely with mod_php because PHP is not thread safe. mod_php is the fastest way of running PHP sites so you dont really need to think to much over this option. If you are low on memory resources you could install Lighttpd and run PHP as a FastCGI but then I guess you do not want to install Postfix or use the same machine as a mail server, so skip installing Postfix as well.
apt-get install apache2 apache2-mpm-prefork apache2-utils ssl-cert
mod_rewrite is not enabled by default so we will enable it and restart Apache
a2enmod rewrite invoke-rc.d apache2 restart
Open up your web browser and try to visit http://YOUR-IP-ADDRESS you should see “It works!” displayed in your browser if Apache is working normally.
If you can not access the page, check your firewall rules. Port 80 should be open. If not, rebuild the firewall rules making sure that this time the port 80 is open, copy them to /etc/network/iptables.rules and reboot your server.
Since we only have one IP address we are going to use Apaches name-based virtual hosting for serving multiple domains from a single server.
Configuration files for sites are located in /etc/apache2/sites-available
and symbolic links for active sites are created in /etc/apache2/sites-enabled
.
Now, we are going to create a configuration file for out example.com domain. Create an example.com in /etc/apache2/sites-available
using nano /etc/apache2/sites-available/example.com
and save this in the file:
<VirtualHost *:80> ServerAdmin webmaster@example.com ServerName example.com ServerAlias www.example.com DocumentRoot /home/www/example.com/public_html ErrorLog /home/www/example.com/logs/error.log # Possible values include: debug, info, notice, warn, error, crit, # alert, emerg. LogLevel warn CustomLog /home/www/example.com/logs/access.log combined </VirtualHost>
You can see that the DocumentRoot points to /home/www/…
. This is because I choose to save all my sites in the /home/www
folder in which every domain has its own folder.
Since those folders for our domain still don't exist, we need to create them
mkdir /home/www mkdir /home/www/example.com mkdir /home/www/example.com/logs mkdir /home/www/example.com/public_html
As you can see, we can tell Apache to save log files for each virtual host separately.
Od Debian systems Apache runs as user www-data. So we need to give permissions to Apache to read and write to this folders. We can change the owner and the group of all files with
chown www-data:www-data -R /home/www/
We are ready to enable our new virtual host
a2ensite example.com update-rc.d apache2 restart
If you want to add other sites to your server, just create another file in the /etc/apache2/sites-available
folder and repeat the procedure.
Default configuration of Apache sends server information in the response headers that we do not want to expose to everybody. To disable this open /etc/apache2/conf.d/security with nano and replace
ServerTokens Full ServerSignature On
with
ServerTokens Prod ServerSignature Off
All application on my web server use UTF-8 as a default encoding so I also edit /etc/apache2/conf.d/charset and uncomment the AddDefaultCharset UTF-8
directive which adds the UTF-8 as the default charset to the header for all files Apache sends to clients.
All that is left to do is to restart Apache once again
update-rc.d apache2 restart
Since log files for every domain are located in the /home/www/DOMAIN-NAME/logs we need to make appropriate changes to the logrotate utility which is used for rotating log files.
Create a file /etc/logrotate.d/apache2-virtual
and for each virtual domain you have you have to create a section that looks like this:
/home/www/example.com/logs/*.log { weekly missingok rotate 52 compress delaycompress notifempty create 644 www-data www-data sharedscripts prerotate /usr/lib/cgi-bin/awstats.pl -config=example.com -update endscript postrotate if [ -f "`. /etc/apache2/envvars ; echo ${APACHE_PID_FILE:-/var/run/apache2.pid}`" $ /etc/init.d/apache2 reload > /dev/null fi endscript }
This will rotate log files for the domain, and it will run awstats update script before rotating log files so we do not loose any statistical information. Details about installing awstats are in the next section.
You have to change the location of the log file for every domain you host, and change -config=example.com
to match the awstats identifier.
Note: If you do not want to use awstats, delete
prerotate /usr/lib/cgi-bin/awstats.pl -config=example.com -update endscript
from the file.
apt-get install awstats gzip
Configure awstats
cd /usr/share/doc/awstats/examples/ gunzip awstats.model.conf.gz cp awstats.model.conf /etc/awstats/ mkdir wwwroot mkdir wwwroot/cgi-bin cp awstats.model.conf wwwroot/cgi-bin/ perl awstats_configure.pl
Copying awstats.model.conf
to /etc/awstats/
is needed because this file is referenced from the awstats_configure.pl
script, but somebody forgot to put it there when they were packaging awstats for Debian.
Run the awstats configuration script:
atlantis:/usr/share/doc/awstats/examples# perl awstats_configure.pl ----- AWStats awstats_configure 1.0 (build 1.7) (c) Laurent Destailleur ----- This tool will help you to configure AWStats to analyze statistics for one web server. You can try to use it to let it do all that is possible in AWStats setup, however following the step by step manual setup documentation (docs/index.html) is often a better idea. Above all if: - You are not an administrator user, - You want to analyze downloaded log files without web server, - You want to analyze mail or ftp log files instead of web log files, - You need to analyze load balanced servers log files, - You want to 'understand' all possible ways to use AWStats... Read the AWStats documentation (docs/index.html). -----> Running OS detected: Linux, BSD or Unix Warning: AWStats standard directory on Linux OS is '/usr/local/awstats'. If you want to use standard directory, you should first move all content of AWStats distribution from current directory: /usr/share/doc/awstats/examples to standard directory: /usr/local/awstats And then, run configure.pl from this location. Do you want to continue setup from this NON standard directory [yN] ? y -----> Check for web server install Enter full config file path of your Web server. Example: /etc/httpd/httpd.conf Example: /usr/local/apache2/conf/httpd.conf Example: c:\Program files\apache group\apache\conf\httpd.conf Config file path ('none' to skip web server setup): > /etc/apache2/apache2.conf -----> Check and complete web server config file '/etc/apache2/apache2.conf' -----> Need to create a new config file ? Do you want me to build a new AWStats config/profile file (required if first install) [y/N] ? y -----> Define config file name to create What is the name of your web site or profile analysis ? Example: www.mysite.com Example: demo Your web site, virtual server or profile name: > default -----> Define config file path In which directory do you plan to store your config file(s) ? Default: /etc/awstats Directory path to store config file(s) (Enter for default): > -----> Create config file '/etc/awstats/awstats.default.conf' Config file /etc/awstats/awstats.default.conf created. -----> Add update process inside a scheduler Sorry, configure.pl does not support automatic add to cron yet. You can do it manually by adding the following command to your cron: /usr/share/doc/awstats/examples/wwwroot/cgi-bin/awstats.pl -update -config=default Or if you have several config files and prefer having only one command: /usr/share/doc/awstats/examples/tools/awstats_updateall.pl now Press ENTER to continue... A SIMPLE config file has been created: /etc/awstats/awstats.default.conf You should have a look inside to check and change manually main parameters. You can then manually update your statistics for 'default' with command: > perl awstats.pl -update -config=default You can also read your statistics for 'default' with URL: > http://localhost/awstats/awstats.pl?config=default Press ENTER to finish...
nano /etc/awstats/awstats.default.conf
change LogFile= to
LogFile="/var/log/apache2/access.log"
Run awstats
/usr/lib/cgi-bin/awstats.pl -update -config=default
This will run awstats for the default profile. Default profile takes care of the log files that are used when serving content from the /var/www
. Since, you probably will just use virtual domains you have to create a separate awstats config file for each domain. Just make sure that every domain has a different answer for Your web site, virtual server or profile name:
question.
You will also have to edit config file for each domain (located in /etc/awstats
) and change the location to the config file.
Awstats package has created a cron job that should generate logs for awstats regularly, but it doesn't fit our needs, so we are going to edit it, open /etc/cron.d/awstats
and replace
0,10,20,30,40,50 * * * * www-data [ -x /usr/lib/cgi-bin/awstats.pl -a -f /etc/awstats/awstats.conf -a -r /var/log/apache/access.log ] && /usr/lib/cgi-bin/awstats.pl -config=awstats -update >/dev/null
with an entry for every one of our domains
0,10,20,30,40,50 * * * * www-data /usr/lib/cgi-bin/awstats.pl -config=default -update >/dev/null
The is also alo a script in /usr/share/doc/awstats/examples/awstats_updateall.pl
that you can use to update all domains at once.
To display data awstats created fetch the latest version of Jawstats and unpack it somewhere in you domains public_html folder. Copy config.dist.php
to config.php
and add all the domains you want Jawstats to fetch information from the database awstats creates.
Important: If you store all awstats information for you virtual domains in the same place. One user of the server will be able to edit config.php
and view statistics for other domain. If this is an issue for you, you should change awstats domain configuration files and point DirData
for each domain to a separate folder. You could for example create awstats
inside every /home/www/domain
. Youd would then have 3 folders inside every /home/www/domain
directory
If you need HTTPS access to your virtual hosts you will have to:
/etc/apache2/sites-available/domain
file (you can use the content from default-ssl
as a template for this section)