Tideways Installation

Foreword

If you would like to use Tideways, a very comprehensive PHP profiler, on your website and/or online store, our installation guide will show you how to install and configure the service on your server.


Prerequisites

  • creoline server
  • active Tideways license



Installation on Managed Server

For the installation of Tideways on managed servers, please contact our support so that we can install and configure Tideways.



Installation on unmanaged server

To install Tideways on Debian and Ubuntu servers, you need an active root SSH connection to start the installation.


First of all, the Tideways PHP Service and the Tideways Daemon must be installed. Both packages are installed using the following SSH commands:


echo 'deb [signed-by=/usr/share/keyrings/tideways.gpg] https://packages.tideways.com/apt-packages-main any-version main' | tee /etc/apt/sources.list.d/tideways.list > /dev/null


wget -qO - 'https://packages.tideways.com/key.gpg' | gpg --dearmor | tee /usr/share/keyrings/tideways.gpg > /dev/null


 apt-get update && apt-get install tideways-php tideways-daemon


After installation, Tideways must be configured with your API key and the desired environment (production, stage, etc.). The next steps for Plesk, PHP-FPM and Mod PHP (Apache2) will show you how to configure Tideways successfully.


Configuration under Plesk

To configure Tideways under Plesk, log in to your Plesk Control Panel and navigate to Website → PHP Settings → Additional Instructions



You can find your Tideways API key under Tideways → Project → Setup → php.ini

The structure is as follows:


Apache

SetEnv TIDEWAYS_APIKEY XXXXXXXXXXXXXXXXXXX
SetEnv TIDEWAYS_SAMPLERATE 25


NGINX

location / {
    ...
    fastcgi_param TIDEWAYS_APIKEY XXXXXXXXXXXXXXXXX;
    fastcgi_param TIDEWAYS_SAMPLERATE 25;
        ...
}


Insert this into the additional configuration statement in Plesk so that the result looks like this:



After the installation you can check if Tideways is already collecting data, please wait 60 seconds so that Tideways can collect the data.



Configuration under PHP-FPM

To configure Tideways under PHP-FPM, you need an active SSH connection as root user with which you can log on to the desired server.


Once you are connected, open the zz-creoline.ini with nano or vim and edit the file as specified.


Please note that the instructions in zz-creoline.ini should not be changed, only add the API key from Tideways here.


nano /etc/php/8.2/fpm/conf.d/zz-creoline.ini

\You must add the following lines to zz-creoline.ini:

tideways.api_key=XXXXXXXXXXXXXXXXXXXXXXXX
tideways.sample_rate=25


After configuration, you should reload the PHP-FPM service by executing the following commands:

# Configtest
php-fpm8.2 --test

# Reload
systemctl reload php8.2-fpm.service



Configuration under Mod PHP (Apache2)


If you install Tideways under Apache2, log in as root user via SSH on your server for which you want to analyze the data with Tideways.


First of all you have to store the API key of Tideways, use the zz-creoline.ini, if the file does not yet exist, you can create it with the following command:

nano /etc/php/8.2/fpm/conf.d/zz-creoline.ini


You must add the following lines to zz-creoline.ini:

tideways.api_key=XXXXXXXXXXXXXXXXXXXXXX
tideways.sample_rate=25


After the configuration, you should reload the PHP-FPM service by executing the following commands:

# Configtest
php-fpm8.2 --test

# Reload
systemctl reload php8.2-fpm.service



Set environment

In Tideways you can display several environments, the configuration is done via the supplied tideways-daemon file.



The file can be found under /etc/default/tideways-daemon and can be edited with nano or vim. To edit the file, the following command can be used:


nano /etc/default/tideways-daemon


The file content should look like this, for example:

TIDEWAYS_DAEMON_EXTRA="--env=staging"


If you want to display your staging environment, use --env=staging, if you use Tideways on your production environment, you must enter --env=production here.


The data will be displayed in the specified environment after a restart.