data:image/s3,"s3://crabby-images/8664f/8664f3c716d9e170f2e087bba01cb68ed96b69e8" alt="Final product image"
Piwik may be the most polished open source analytics tool you've never heard of. Not only has it had more than two million downloads, it has a rich set of features and excellent documentation. This tutorial will describe how to install and use it to track web traffic to your own sites.
If you prefer to pay to have someone else run it for you, they offer several cloud-based options. Piwik offers a 30 day free trial with $65 monthly pricing afterwards. There's also a community of paid consultants you can hire to assist you.
Benefits to Hosting Your Own Analytics
I've been a long-time user of freemium, cloud-service analytics provider Statcounter. I like being able to see specific user activity and IP address traffic. While Google Analytics doesn't provide this information, Statcounter lacks many of the features that Google Analytics provides for free.
Enter Piwik, a mature, well-documented, full-featured open source analytics product written in PHP; it even offers free mobile applications for iOS and Android.
data:image/s3,"s3://crabby-images/0055d/0055db478edb58ae7de17395befed2a12eea9106" alt="Piwik Offers a Mobile App"
The team has upcoming plans to offer a tool to migrate Google Analytics data to Piwik in 2015.
Installing Piwik on Your Own Server
Piwik runs on any modern LAMP-based server configuration. If you'd like, you can begin with my generic Ubuntu LAMP installation here.
Then, follow my installation instructions below and/or watch the installation video:
First, let's download the open source Piwik code and create a web directory for your dashboard:
mkdir /var/www/piwik cd /var/www/piwik sudo wget http://builds.piwik.org/piwik.zip sudo unzip piwik.zip sudo rm piwik.zip sudo rm How\ to\ install\ Piwik.html
Change the ownership and permissions appropriate to your web server:
chown -R www-data:www-data /var/www/piwik sudo mkdir /var/www/piwik/tmp sudo mkdir /var/www/piwik/tmp/assets/ sudo mkdir /var/www/piwik/tmp/cache/ sudo mkdir /var/www/piwik/tmp/logs/ sudo mkdir /var/www/piwik/tmp/tcpdf/ sudo mkdir /var/www/piwik/tmp/templates_c/ sudo chmod -R 0755 /var/www/piwik/tmp sudo chmod -R 0755 /var/www/piwik/tmp/assets/ sudo chmod -R 0755 /var/www/piwik/tmp/cache/ sudo chmod -R 0755 /var/www/piwik/tmp/logs/ sudo chmod -R 0755 /var/www/piwik/tmp/tcpdf/ sudo chmod -R 0755 /var/www/piwik/tmp/templates_c/
Create an Apache site configuration file and paste the Virtual Host definition below into it. Then, enable the site.
cd /etc/apache2/sites-available/ sudo nano stats.conf sudo a2ensite stats.conf
Paste in and customize the virtual host definition for your Piwik site as shown below:
<VirtualHost *:80> ServerName piwik.yourdomain.com DocumentRoot /var/www/piwik DirectoryIndex index.php <Directory /var/www/piwik/> AllowOverride All Order Deny,Allow Allow from all </Directory> </VirtualHost>
Setting Up Piwik
You can follow the Piwik five minute installation guide if you'd like more details. The installation wizard you should see on your site is quite simple:
data:image/s3,"s3://crabby-images/f4f2d/f4f2d884c03ba9672a8e19ea7bcb6e55f0964220" alt="Piwik Installation Wizard Welcome"
It performs a system check, which should pass if you followed my LAMP configuration guide:
data:image/s3,"s3://crabby-images/ec6dc/ec6dce679be092d55f60825071958dbae2614f57" alt="Piwik Installation Wizard System Check"
Enter in the database permissions that you created from the configuration guide—when you created your MySQL database:
data:image/s3,"s3://crabby-images/5cf3d/5cf3d74bdebfe31caa3a0f3563ae6db3524e7efc" alt="Piwik Installation Wizard MySQL Database Setup"
You should see this:
data:image/s3,"s3://crabby-images/309a9/309a9ec8b7eedb13f33428980314c16adf25f980" alt="Piwik Installation Wizard Database Created"
Specify your administrator or superuser login credentials:
data:image/s3,"s3://crabby-images/ad9fe/ad9fe030ed194bc95e8dcdf3c73238945c594994" alt="Piwik Installation Wizard Superuser"
Now, you can add your first website to track:
data:image/s3,"s3://crabby-images/f438b/f438b1cd14dc130182728715cff9ff4ceb9291dc" alt="Piwik Installation Wizard Add Your Site"
Keep in mind that the site isn't actively tracking yet. We'll do that below.
If you log out, you'll be greeted with the Piwik sign-in. Enter your administrative credentials chosen above:
data:image/s3,"s3://crabby-images/df021/df021f4eab69c6bffe9fb7ad3e77c8f6a4d583ed" alt="Piwik Sign In"
Enabling Tracking From Your Sites
There are a couple of ways to enable tracking on your website.
Embedding JavaScript
Just like with Google Analytics, you can paste the Piwik JavaScript into your website code:
data:image/s3,"s3://crabby-images/ec6c0/ec6c0f5085a99d0fdcde1f82417b3b2d0cffb743" alt="Piwik Tracking Code in Javascript"
WordPress Plugin
Or, you can install the WP-Piwik plugin:
data:image/s3,"s3://crabby-images/63e4b/63e4b49f9dc0d3b7cff894b91d1ba60062b57028" alt="WP-Piwik Plugin for WordPress"
Next, visit your Piwik API settings and copy your authentication token—just the parameter value (mine is blacked out below).
data:image/s3,"s3://crabby-images/652cb/652cbfd4cb52b8d994a96613a978b9b2182de7b4" alt="Piwik API Key"
Visit the WordPress WP-Piwik Settings page and provide your Piwik URL, the domain you set up to host Piwik, and the auth token.
data:image/s3,"s3://crabby-images/bdaf3/bdaf3cf6a3a7a9fc50c2a01b595850551350d97c" alt="WP-Piwik Plugin for WordPress Settings"
Don't forget to visit the Tracking tab under settings to turn on the tracking code on your WordPress site:
data:image/s3,"s3://crabby-images/fbaec/fbaec4edeeb83630b2c5844025a7063af73eade1" alt="WP-Piwik Plugin for WordPress Tracking"
The Piwik Dashboard
You should be able to see data coming in immediately from the real-time dashboard panel:
data:image/s3,"s3://crabby-images/5445b/5445b98ecfe59a643567dcc6dd34d3f42cdfdcb5" alt="Piwik Real Time Visitor Panel"
Once Piwik's been collecting data for a few days, you should see something like this in the Piwik Dashboard when you log in:
data:image/s3,"s3://crabby-images/10300/10300988f66bb3e3e675264f1cf0b5e1d5537528" alt="Piwik Dashboard"
All the sites you've added can be viewed at a glance:
data:image/s3,"s3://crabby-images/9cc53/9cc53f397de96246bdee9ff83ff5ac70bf964b4f" alt="Piwik All Sites"
Here's what a summary of traffic by page title looks like:
data:image/s3,"s3://crabby-images/d4528/d45284d6c756d8929ff33e58800ce71859fdb9a6" alt="Piwik Visitor Traffic by Page Title"
Here's a visitor log for all traffic:
data:image/s3,"s3://crabby-images/8eae6/8eae620092c2bf5bf68cef184d6ddad68f180261" alt="Piwik Visitor Log"
And Piwik has a variety of other features such as device, operating system and browser statistics:
data:image/s3,"s3://crabby-images/6b742/6b742179966937b72274139ae36a57428482100a" alt="Piwik Devices and Operating Systems"
The Piwik administration settings are well designed and very thorough. It's unusually good for an open source project:
data:image/s3,"s3://crabby-images/dd007/dd00792546b72182cd91f50b140939ab95e40643" alt="Piwik Settings"
Piwik Mobile Applications
There are also free Piwik mobile apps available at the AppStore and Google Play, so you can keep up with your site traffic on the go more easily:
data:image/s3,"s3://crabby-images/4166f/4166f99cd46f3c3ac5fa64300269712c6ce6a551" alt="Piwik iOS and Android Mobile Apps"
Special Considerations
Piwik has a wide variety of capabilities. Here are a few things you may wish to update in your own system.
Anonymizing IP Addresses
You can change how much of IP addresses Piwik collects—this affects the relative privacy of your users:
Excluding Your Visits
You can set a cookie on your browser to prevent Piwik from adding traffic of your own editing and browsing from being counted:
data:image/s3,"s3://crabby-images/dfb87/dfb87e801c414cc00978805bbe70c2adc70b15f8" alt="Piwik Exclude Your Visits"
Rolling Up Database Logs
You can also set up Piwik to automatically roll up its logs and reports, to prevent the database from growing too large over time:
data:image/s3,"s3://crabby-images/a946c/a946c6b828f6b102b0ffbddb27e8c521f593053f" alt="Piwik Rollup Logs"
Where to Go From Here
Hopefully you've found Piwik useful and interesting. The team has a variety of ways for you to learn more and engage with its community:
I've been impressed with the clean design and relatively robust feature set provided by this free, open source project.
If you have any questions or suggestions, please post them in the comments. If you'd like to keep up on my future Tuts+ tutorials and other series, please visit my instructor page or follow @reifman.
Comments