How To Install Kimai on a Ubuntu 24.04
In this tutorial, we have covered step-by-step guide on how to install Kimai on a Ubuntu 24.04. A self-hosted time-tracking application.
Kimai is popular among freelancers and businesses for its intuitive interface and powerful reporting tools. Each step below includes explanations so you understand not just what to do, but also why you’re doing it.
Prerequisites
- A Ubuntu 24.04 installed dedicated server .
- A root user or normal user with administrative privileges.
- A domain name point A record to server's IP
How To Install Kimai on a Ubuntu 24.04
1. Update and Prepare Your Server
Update Your Package List
Open your terminal or SSH into your Ubuntu server. It’s always a good practice to ensure that your server packages are up to date before installing any new software.
sudo apt update
sudo apt upgrade -y
The -y flag automatically confirms any prompts to install updates.
Install Basic Tools
While many of these might be installed by default, it’s good to be certain.
sudo apt install software-properties-common zip unzip curl -y
- software-properties-common helps manage repository settings.
- zip and unzip allow you to compress and extract archives.
- curl helps you download files and check network endpoints.
2. Install Apache (or Nginx)
Kimai runs on PHP, which needs a web server to handle requests. Apache is straightforward and widely used; you can also use Nginx if you prefer.
Install Apache
sudo apt install apache2 -y
- Installs the Apache web server on your Ubuntu server.
- After installation, Apache will automatically start running.
Check if Apache is Running
sudo systemctl status apache2
If it’s active (running), you’re good to go.
If not, start it manually: sudo systemctl start apache2.
Enable Apache on Boot
sudo systemctl enable apache2
Ensures Apache automatically starts after a server reboot.
(If you prefer using Nginx, you would install it by running sudo apt install nginx -y and configure the virtual host accordingly. For simplicity, this guide focuses on Apache.)
3. Install and Configure PHP
Kimai requires PHP with several extensions. Ubuntu 24.04 typically has a newer version of PHP (for example, PHP 8.x).
Install PHP and Required Extensions
sudo apt install php php-cli php-fpm php-common \
php-gd php-intl php-mbstring php-mysql php-xml \
php-zip php-curl php-ldap -y
- php-cli: Command-line interface for running PHP scripts.
- php-fpm: FastCGI process manager for PHP, helps with performance.
- php-mbstring: Needed for string manipulation in various encodings.
- php-mysql: Allows PHP to communicate with MySQL/MariaDB databases.
- php-intl: Important for internationalization and date formatting.
- php-xml, php-zip, php-curl, php-gd: Various functionalities that Kimai needs to generate PDFs, handle files, and manage HTTP requests.
- php-ldap: Required if you plan to integrate Kimai with an LDAP directory.
Adjust PHP Settings
Open the main PHP configuration file or the relevant pool file (often found at /etc/php/8.3/apache2/php.ini) in your favorite text editor:
sudo nano /etc/php/8.3/apache2/php.ini
Look for these settings and adjust them if necessary (for example, increasing the maximum file upload size or memory limit):
memory_limit = 256M
upload_max_filesize = 50M
post_max_size = 50M
- memory_limit controls how much memory a PHP script can use.
- upload_max_filesize and post_max_size control allowed file upload sizes.
Restart Apache
sudo systemctl restart apache2
Applies any configuration changes immediately.
4. Install MariaDB (or MySQL) and Create a Database
Kimai stores its data (projects, timesheets, user info, etc.) in a database. MariaDB is a popular open-source fork of MySQL.
Install MariaDB
sudo apt install mariadb-server mariadb-client -y
Secure Your MariaDB Server
sudo mysql_secure_installation
You’ll be prompted to set a root password, remove anonymous users, disable remote root login, and more. These steps help secure your database.
Create a Database and User for Kimai
Log into the MariaDB shell:
sudo mysql
Inside the MariaDB shell, run the following queries (adjust values to match your preferences—here we use kimai_db, kimai_user, and StrongPassword as placeholders):
CREATE DATABASE kimai_db CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
CREATE USER 'kimai_user'@'localhost' IDENTIFIED BY 'StrongPassword';
GRANT ALL PRIVILEGES ON kimai_db.* TO 'kimai_user'@'localhost';
Помог ли вам данный ответ?

