Mysql : Différence entre versions

De SME Server Wiki
(rendre accessible depuis l'internet)
(rendre accessible depuis l'internet)
Ligne 81 : Ligne 81 :
 
  config setprop mysqld TCPPort 3306 acces public status enabled LocalNetworkingOnly no
 
  config setprop mysqld TCPPort 3306 acces public status enabled LocalNetworkingOnly no
 
  expand-template /etc/my.cnf
 
  expand-template /etc/my.cnf
  /etc/rc7.d/mysqld restart
+
  /etc/rc.d/init.d/mysqld restart
 
  signal-event remoteaccess-updates
 
  signal-event remoteaccess-updates
  
 
== Replication de mysql ==
 
== Replication de mysql ==
 
[Mysql_replication]
 
[Mysql_replication]

Version du 8 septembre 2006 à 23:52

Tout d'abord Mysql est en version 4 sous SME 7.0.

Vous pouvez l'amdinistrer facilement par le web avec phpmyadmin, un rpm est disponible, vous pouvez le trouver sur http://www.contribs.org

Utilisation de mysql

Attention ne pas utiliser le compte root pour vos applications web, à la place créez en un spécifique. Pour créer un utilisateur en ligne de commande suivez le how to de GrandPa ( http://smeserver.fr/astuces.php?astuce=mysql_users_create ). Pour creer un utilisateur avec phpmyadmin d'abord créez la base vide qu'il devra gerer, ensuite allez dans privileges puis ajouter un utilisateur, donner lui un nom, serveur: localhost, choisissez le mot de passe. Puis créez l'utilisateur sans rein cocher de plus. A la page suivante vous pourez choisir la base que vous avez créé, puis donner tous les droits voulu sur cette base, validez et le toru est joué votre base et son utilisateur sont prés à être utilisé dans n'importe quel application web.


Interface graphique

Voici un petit how to pour Installer_phpMyAdmin. Phpmyadmin vous permettra de gerer avec une interface web votre base mysql pour les taches les plus courantes.


Sauvegarde de mysql

voici un petit script que j'apprecie pour la sauvegarde des mes bases dans des fichiers séparés:


#!/bin/sh
# variable de date
DATE=$(date +%Y-%m-%d)
# liste des bases mysql
FILE=(`mysqlshow|sed -e "/^+--/d"|sed -e "/Database/d"|cat|tr '\n' ' '|sed -e "s/|//g"|sed -e "s/ //"`)
#nb de bases
nb_element=${#FILE[*]}
####################
#   sauvegarde
####################
mkdir -p /home/e-smith/db/mysql/daily/${DATE}/
index=1
while [ "$index" -lt "$nb_element" ]
do #dump de toutes les bases
#echo ${FILE[$index]}
/usr/bin/mysqldump -aec ${FILE[$index]} > /home/e-smith/db/mysql/daily/${DATE}/dumpdaily${DATE}-${FILE[$index]}.sql
let "index = $index + 1"
done
####################
#purge 60 jours
#####################
nice find /home/e-smith/db/mysql/daily -type d -mtime +"60" |xargs rm -fr
# d directory  f files
# mtime en jours

--WikiSysop 3 juillet 2006 à 15:13 (CEST)


J'ai modifié le mot de passe root...

Il ne faut surtotu pas modifier le mot de passe root general qui est stocké dans un fichier pour l'utilisation du ldap. Celui ci fait plus de 70 caracteres. c'est ce meme mot d epasse qui est utilisé derriere votre dos pour acceder à mysql en ligne de commande par exemple. Ne modifier donc pas le mot de passe stocké dans la table user de la base mysql. ne modifiez pas cette table non plus.

Si vous avez fait une telle betise voila le remede pour sme 7:

cd /service/mysqld
runsvctrl d .
cat set.password | /usr/libexec/mysqld --bootstrap  --user=mysql --skip-grant-tables
runsvctrl u .

Si c'est insuffisant voila pour reparer totalement mysql : attention cette methode ecrase toutes les bases existantes:

cd /service/mysqld
runsvctrl d .
/etc/e-smith/events/actions/mysql-delete-db-files
signal-event post-upgrade
signal-event reboot

rendre accessible depuis le reseau local

config setprop mysqld LocalNetworkingOnly no
expand-template /etc/my.cnf
/etc/rc7.d/mysqld restart

rendre accessible depuis l'internet

attention cette manipulation est utile uniquement si vous desirez contacter directement votre base depuis l'internet: ELLE N'EST PAS A REALISER POUR VOIR SON CONTENU GRACE A UNE PAGE WEB HEBERGEE SUR VOTRE SME.

Réaliser cette manoeuvre provoque une exposition dangeureuse de votre base mysql

config setprop mysqld TCPPort 3306 acces public status enabled LocalNetworkingOnly no
expand-template /etc/my.cnf
/etc/rc.d/init.d/mysqld restart
signal-event remoteaccess-updates

Replication de mysql

[Mysql_replication]