Tutoriels/Base de données partagée

From KDE UserBase Wiki
This page is a translated version of the page Tutorials/Shared Database and the translation is 77% complete.

Base de données partagée

Il existe plusieurs applications de bureau pour KDE qui gèrent une sorte de base de données. Les plus populaires sont probablement Amarok le lecteur de musique, digiKam le gestionnaire de photos et Akonadi le cadre d'informations personnelles. Pour simplifier leur installation et limiter leurs besoins, chacun de ces programmes embarque sa propre base de données, utilisant dans la plupart des cas SQLite. Avoir de nombreuses bases de données distinctes crée une surcharge inutile et rend plus difficile la sauvegarde de vos données.

Serveur de base de données

La seule base de données universellement supportée par ces programmes est MySQL, c'est donc celle que nous utilisons bien. Elle est également très simple à configurer, soit en ligne de commande, soit avec des outils graphiques.

Installation

Tout d’abord, nous devons installer le serveur MySQL. Les utilisateurs de Linux voudront probablement installer un package à partir de leur distribution, d'autres pourront l'obtenir depuis leur page d'accueil. Les instructions pour démarrer MySQL au démarrage sont spécifiques à la distribution, mais comme MySQL est un package populaire, elles ne devraient pas être difficiles à trouver. Lors de l'installation, le programme d'installation vous demandera probablement un mot de passe root. Choisissez un mot de passe sécurisé pour cela et souvenez-vous-en, ce compte ne sera pas utilisé par les applications de bureau mais uniquement pour l'administration de la base de données.

Configuration

For the server configuration, this we will assume that your database server is not used over the network, contains no sensitive data, and that you trust your applications. If you plan to use this database for Akonadi data, it's best if you copy the configuration file from the Akonadi code repository, which can be downloaded at here. Make a copy of your existing /etc/mysql/my.cnf, then replace it with the downloaded file.

Warning

Ce fichier désactive « l'accès au réseau » et « l'authentification de l'utilisateur ». Ce dernier signifie que n'importe quelle application de votre ordinateur peut s'y connecter sans mot de passe. Cela facilite la configuration des programmes et convient bien au cas d’utilisation général du bureau.


Création des bases de données

La première chose que nous devons faire une fois MySQL installé et exécuté consiste à ajouter une base de données distincte pour chaque programme. Je leur donne généralement le nom des programmes qui les utilisent. Cela peut être fait avec l'un ou l'autre des outils d'administration GUI, mais comme nous ne devons le faire qu'une seule fois, il est probablement plus rapide d'écrire quelques commandes :

$ mysql -u root -p

À l'invite du mot de passe, saisissez le mot de passe root défini lors de l'installation de MySQL. Nous pouvons maintenant commencer à créer des bases de données. Par exemple, pour créer une base de données nommée « amarok », tapez cette commande :

mysql> create database amarok;

Amarok

Amarok nécessite très peu de configuration, mais il ne permet pas de migrer votre ancienne base de données. Allez dans Paramètres -> Configurer Amarok... et allez dans l'onglet Base de données. Remplissez localhost dans le champ de texte Serveur, 3306 dans Port, et amarok dans Base de données.

digiKam

Note

DigiKam avait un bug qui l'empêchait de fonctionner dans les versions antérieures à 2.0, vous aurez donc besoin d'une version plus récente du programme. Dans la version 2.0, cela ne fonctionne toujours pas parfaitement : un message d'erreur apparaît au démarrage, mais les tableaux sont remplis et les données de l'album sont stockées correctement.

digiKam est un peu spécial car il nécessite deux bases de données : une pour les métadonnées des images et une pour les vignettes. Leurs noms n'ont pas d'importance, j'ai choisi de les appeler digikam et digikam_thumb :

mysql> create database digikam;
mysql> create database digikam_thumb;

Dans digiKam, le processus est très similaire à celui de Amarok. Les paramètres se trouvent dans Paramètres -> Configurer digiKam... -> Base de données.

digiKam est également livré avec un outil de migration de base de données pratique, disponible dans Paramètres -> Migration de base de données. Remplissez vos paramètres de base de données précédents (vous n'avez rien à faire si vous n'avez pas modifié ces options) sur le côté gauche et vos nouveaux paramètres sur le côté droit, puis cliquez sur Migrer.

Akonadi

Créez d’abord une base de données pour Akonadi:

mysql -u root -p
create database akonadi;

Akonadi n'est pas censé être un outil destiné à l'utilisateur, il n'y a donc pas d'interface graphique de configuration pour celui-ci. Cependant, vous pouvez modifier ~/.config/akonadi/akonadiserverrc pour avoir ces contenus :

[%General]
Driver=QMYSQL

[QMYSQL]
Name=akonadi
Host=localhost
StartServer=false
Options=
ServerPath=/usr/bin/mysqld

Enregistrez le fichier, puis déconnectez-vous et reconnectez-vous.