Selon Wikipédia : Lua est un langage de script libre dont l'interpréteur est conçu dans un but de compacité (95 à 185 Ko pour la version 5.0.2, selon le compilateur utilisé et le système cible). Lua est conçu de manière à pouvoir être embarqué au sein d'une autre application, ce qui permet d'étendre celle-ci.
Avec MySQL Proxy, vous serez capable de :
- Filtrer les requêtes avant de les transmettre au serveur ;
- Réécrire certaines requêtes (en corrigant la syntaxe par exemple) ;
- Intercepter le resultset afin d'y supprimer, modifier ou ajouter des enregistrements ;
- Interdire le retour de certains résultats vers le client.
- Rediriger les écritures sur le maître et les lectures sur l'esclave, dans le cas de réplication ;
- Exécuter des commandes Shell.
Aller plus loin
- MySQL Proxy (599 clics)
- Download (112 clics)
- Getting Started with MySQL Proxy (318 clics)
- Language Lua (50 clics)
# Retour d'expérience en production
Posté par Greg (site web personnel) . Évalué à 10.
effectivement ce produit est très interressant sur le principe, on évite par exemple de faire de la répartition de charge au niveau applicatif...
Je l'ai configuré et installé, tout semblait parfait, sous l'effet de l'excitation je l'ai meme mis en prod quelques heures.
Environnement: des serveurs PHP qui interroge un pool de 5 serveurs MySQL de manière aléatoire, statistiquement c'est équitable :)
J'ai donc changé le pool de 5 par 1 seul: MySQL Proxy, qui lui load balance les requetes sur les 5 serveurs (read-only)
Impressionnant, mysql proxy ne consomme rien en CPU avec 1500 req/sec , le serveur n'atteint meme pas 1 de charge, et ... ça marche !
Sauf que ... je ne sais pas pourquoi, mais les 5 serveurs se prennent moins de requetes, la partie du site concerné est plus lente à la navigation, on dirait que mysql proxy n'accepte qu'un nombre restreint de connections simultanés et/ou par secondes, le serveur étant pourtant légerement tuné pour largement encaisser plus de 100000 cnx / seconde.
J'ai posé la question sur le forum mysql proxy, et n'ai pas obtenu de réponse....
Et je n'ai pas le temps de creser, pour l'instant.
Dommage :-(
[^] # Re: Retour d'expérience en production
Posté par Joris Dedieu (site web personnel) . Évalué à 5.
[^] # Re: Retour d'expérience en production
Posté par Greg (site web personnel) . Évalué à 5.
Pourquoi ?
[^] # Re: Retour d'expérience en production
Posté par Joris Dedieu (site web personnel) . Évalué à 3.
[^] # Re: Retour d'expérience en production
Posté par Greg (site web personnel) . Évalué à 7.
Tu peux répliquer toute la DB, juste quelques DB, ou encore seulement des tables.
Plus tu répliques de données, moins tes slaves seronts efficaces pour répondre aux requetes de lectures, et plus ils risquent de prendre du délais de réplic (d'après mon expérience c'est exponentiel :( le slave qui prend du délais devient tres vite innaccessible)
Mais attention aux parametres de config "replicate-ignore-table" qui permettent de ne pas répliquer toutes les tables, MAIS si une requête d'écriture impliquant des tables ignorées apparait, la réplic est cassée.
Exemple typique, tu réplic les tables A, B, C et tu ignores D. Une requete de ce genre va planter la réplic:
UPDATE B SET champ=1 WHERE D > 0;
Pour revenir à mysql proxy, il va etre possible dans les versions futures de changer dynamiquement la liste des slaves. Donc avec un programme tiers, on peut récupérer les délais de réplic de tous les slaves, et appliquer un algorithme pour ajouter/supprimer des slaves de mysql proxy ....
[^] # Re: Retour d'expérience en production
Posté par Jean-Yves Beaujean (site web personnel) . Évalué à 4.
[^] # Re: Retour d'expérience en production
Posté par Greg (site web personnel) . Évalué à 3.
Il faudrait que je puisse tester hors production mais comment ?
[^] # Re: Retour d'expérience en production
Posté par Jean-Yves Beaujean (site web personnel) . Évalué à 1.
[^] # Re: Retour d'expérience en production
Posté par arthurr (site web personnel) . Évalué à 5.
[^] # Re: Retour d'expérience en production
Posté par Greg (site web personnel) . Évalué à 2.
# Il existe ausi DBIx::MyServer en Perl
Posté par R4f . Évalué à 4.
Pour ceux que l'utilisation d'un nouveau langage (lua) rebute, vous pouvez également utiliser DBIx::MyServer, un module en Perl.
Un très bon article à ce sujet : http://dev.mysql.com/tech-resources/articles/dbixmyserver.ht(...)
Ce qu'on peut en faire ?
- implémenter un système de journal (log) maison en local ou à distance
- générer des tests à la demande
- implémenter des macros pour les expressions SQL les plus courantes
- lancer des commandes shell et du mail par votre serveur de bases de données
- utiliser d'autres SGBD au sein de MySQL
- ...
# Et pourquoi pas mettre des requêtes... en memcache ?
Posté par Maxime Ritter (site web personnel) . Évalué à 2.
C'est assez bizarre l'utilisation de LUA, mais mon rêve le plus fou pourrait bien se réaliser là : mettre les grosses requêtes SQL en memcache sans toucher au code PHP/Perl/ruby pour cacher mes requêtes !
En effet, on s'est déjà amusé à écrire une lib pour utiliser memcache trouvé là :
http://trac.lighttpd.net/trac/attachment/ticket/1139/Memcach(...) (la dépêche ne le dis pas, mais LUA est aussi pas mal utilisé dans lightty).
Il n'y a donc plus qu'à faire la suite, ça ne saurait être bien difficile pour qui a un peu de temps à perdre... Un volontaire pour tester ?
[^] # Re: Et pourquoi pas mettre des requêtes... en memcache ?
Posté par chl (site web personnel) . Évalué à 7.
Ce que la dépêche ne dit pas non plus, ni toi d'ailleurs :), c'est que lighttpd et mysqlproxy sont du même auteur : Jan Kneschke
[^] # Re: Et pourquoi pas mettre des requêtes... en memcache ?
Posté par Greg (site web personnel) . Évalué à 2.
[^] # Re: Et pourquoi pas mettre des requêtes... en memcache ?
Posté par Maxime Ritter (site web personnel) . Évalué à 3.
http://www.danga.com/memcached/
Suivre le flux des commentaires
Note : les commentaires appartiennent à celles et ceux qui les ont postés. Nous n’en sommes pas responsables.