Table des matières
(转)Amoeba for MySQL 非常好用的mysql集群软件
Maison base de données tutoriel mysql (转)Amoeba for MySQL 非常好用的mysql集群软件_MySQL

(转)Amoeba for MySQL 非常好用的mysql集群软件_MySQL

Jun 01, 2016 pm 01:18 PM
mysql 应用层 数据库 软件

Mysql集群

bitsCN.com

(转)Amoeba for MySQL 非常好用的mysql集群软件

http://yanwt.iteye.com/blog/1460780

Amoeba for MySQL 


Amoeba for MySQL致力于MySQL的分布式数据库前端代理层,它主要在应用层访问MySQL的时候充当query 路由功能,专注 分布式数据库 proxy 开发。座落与Client、DB Server(s)之间。对客户端透明。具有负载均衡、高可用性、Query过滤、读写分离、可路由相关的query到目标数据库、可并发请求多台数据库合并结果。 在Amoeba上面你能够完成多数据源的高可用、负载均衡、数据切片的功能。目前在很多企业的生产线上面使用。 




Amoeba使用指南 

说明文档见:http://docs.hexnova.com/amoeba/ 




安装小结: 




目前可以有三种解决方式实现mysql读写分离 

1 程序修改mysql操作类 

优点:直接和数据库通信,简单快捷的读写分离和随机的方式实现的负载均衡,权限独立分配 

缺点:自己维护更新,增减服务器在代码处理 




2 amoeba 

参考官网:http://amoeba.meidusa.com/ 

优点:直接实现读写分离和负载均衡,不用修改代码,有很灵活的数据解决方案 

缺点:自己分配账户,和后端数据库权限管理独立,权限处理不够灵活 




3 mysql-proxy 

参考 mysql-proxy。 

优点:直接实现读写分离和负载均衡,不用修改代码,master和slave用一样的帐号 

缺点:字符集问题,lua语言编程,还只是alpha版本,时间消耗有点高 




如果你不能安装软件来解决读写分离,那可以尝试阿权的项目解决思路。 

如果你可以安装软件,那amoeba是不错的,mysql-proxy不太建议,目前只有alpha版本,效率还不太理想,amoeba目前在阿里巴巴是内部项目,正在生产环境使用的。 




amoeba的安装使用 

1 安装java环境,需要Java SE 1.5 或以上 

2 配置xml文件 

下载地址: http://www.sf.net/projects/amoeba 

解压就可以使用的,顺便说一下,打包的习惯似乎不是太好,最好解压后是自己的文件夹,如用tar -zxpf amoeba-mysql-binary-2.1.0-RC5.tar.gz -C /usr/local/amoeba-mysql 




运行很简单 bin/amoeba 即可,后台运行 bin/amoeba & 

如果没有配置JAVA_HOME,则会有如下提示: 

[root@aslibra amoeba-mysql]# bin/amoeba 

Error: JAVA_HOME environment variable is not set. 

如果你是比1.5低,比如1.4的,运行会有错误提示: 




[root@aslibra amoeba-mysql]# bin/amoeba 

Exception in thread "main" java.lang.UnsupportedClassVersionError: com/meidusa/amoeba/mysql/server/MysqlProxyServer (Unsupported major.minor version 49.0) 

        at java.lang.ClassLoader.defineClass0(Native Method) 

        at java.lang.ClassLoader.defineClass(ClassLoader.java:539) 

        at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:123) 

..... 




下载jdk1.5以上的版本,压缩版解压后设置好环境变量即可 




可以编辑 /etc/profile以便启动时变量生效,末尾加上 




##############  java  ########### 




JAVA_HOME=/usr/java/jdk 

PATH=$PATH:JAVA_HOME/bin 

export JAVA_HOME PATH 




用bin/amoeba start即可启动amoeba 

如bin/amoeba start > /dev/null & 




配置amoeba: 




conf/amoeba.xml 配置mysql数据库,简单说明一下: 




1 server节点定义amoeba为接受client访问的数据库,可以当作是mysql看待的,用户名和密码是访问时使用的,这个似乎不能定义多个用户名密码,也就是只有一个权限控制,这个对于多应用似乎不大方便。 

2 dbServerList里面可以定义很多实际的mysql数据库,增加dbServer节点即可,这里的用户名密码是作为amoeba操作数据库使用的,要有足够权限。dbServer可以是虚拟的,比如要做负载均衡时可用定义多个数据库归属到此虚拟数据库。2.1RC版的dbServer已移到dbServers.xml文件中配置。 

3 queryRouter节点定义读写的分配情况,也就是读写该发往那个dbServer。 




vi amoeba.xml 修改主配置文件 

4.1)把默认端口8066改成3306 

3066 

4.2)把默认连接用户名和密码改成自己的 

sky 

123456 

4.3)把默认的客户端线程数,请求数及服务端回应数改成200,300,300 

200 




                        

                       300 

                        

                       300 

4.4)把默认注释掉的读写分离选项,把注释去掉并readpool修改成server2 

 

                       server1 

                       server2 

提示:readPool或writePool可以是dbServers中的multiPool名称,用multiPool来设置负载均衡。 




(本文出自php_sir的新浪博客,用户名php_sir,首页链接:http://blog.sina.com.cn/phpsir,未经本人(php_sir)同意禁止转载) 




5. vi dbServers.xml 增加SEVER2模块,里面的连接用户名密码及地址都表示两台MYSQL的物理机器,192.168.1.11和192.168.1.13 另SERVER1是写,SERVER是读 




 

 




 

     

   




     




      ${defaultManager} 




      64 




      128 




       




      3306 




       




      test 




       




      root 




       




      123456 




   
 




     




      500 




      500 




      10 




      600000 




      600000 




      true 




      true 




   
 




 
 




   




     




       




      192.168.2.11 




   
 




 
 

   




     




       




      192.168.2.13 




   
 




 
 




 




     




       




      1 




       




      server1 




   
 




 
 




 




6:修改log4j.xml 取消日志文件生成,如做pdf时(太大了,磁盘很容易满) 

 

改成 

 

注意:我在2.1-rc5版本下第6条的设置JAVA运行时报警,无法通过。 





7:性能优化,打开bin/amoeba 




DEFAULT_OPTS="-server -Xms256m -Xmx256m -Xss128k" 

改成 

DEFAULT_OPTS="-server -Xms2048m -Xmx2048m -Xmn1000m -Xss2048k" 




8:启动amoeba 

nohup /usr/local/amoeba/bin/amoeba start 2>&1 >/dev/null &

bitsCN.com
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Repo: Comment relancer ses coéquipiers
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment optimiser les performances des requêtes MySQL en PHP ? Comment optimiser les performances des requêtes MySQL en PHP ? Jun 03, 2024 pm 08:11 PM

Les performances des requêtes MySQL peuvent être optimisées en créant des index qui réduisent le temps de recherche d'une complexité linéaire à une complexité logarithmique. Utilisez PreparedStatements pour empêcher l’injection SQL et améliorer les performances des requêtes. Limitez les résultats des requêtes et réduisez la quantité de données traitées par le serveur. Optimisez les requêtes de jointure, notamment en utilisant des types de jointure appropriés, en créant des index et en envisageant l'utilisation de sous-requêtes. Analyser les requêtes pour identifier les goulots d'étranglement ; utiliser la mise en cache pour réduire la charge de la base de données ; optimiser le code PHP afin de minimiser les frais généraux.

Comment utiliser la sauvegarde et la restauration MySQL en PHP ? Comment utiliser la sauvegarde et la restauration MySQL en PHP ? Jun 03, 2024 pm 12:19 PM

La sauvegarde et la restauration d'une base de données MySQL en PHP peuvent être réalisées en suivant ces étapes : Sauvegarder la base de données : Utilisez la commande mysqldump pour vider la base de données dans un fichier SQL. Restaurer la base de données : utilisez la commande mysql pour restaurer la base de données à partir de fichiers SQL.

Comment corriger les erreurs mysql_native_password non chargé sur MySQL 8.4 Comment corriger les erreurs mysql_native_password non chargé sur MySQL 8.4 Dec 09, 2024 am 11:42 AM

L'un des changements majeurs introduits dans MySQL 8.4 (la dernière version LTS en 2024) est que le plugin « MySQL Native Password » n'est plus activé par défaut. De plus, MySQL 9.0 supprime complètement ce plugin. Ce changement affecte PHP et d'autres applications

Tous les logiciels seront ouverts avec WPS et la méthode d'ouverture par défaut de l'exe sera restaurée. Tous les logiciels seront ouverts avec WPS et la méthode d'ouverture par défaut de l'exe sera restaurée. Jun 19, 2024 am 01:48 AM

Tous les logiciels sur l'ordinateur de mon ami ont été ouverts à l'aide de WPS et ne peuvent pas fonctionner normalement. Tous les fichiers exécutables ne peuvent pas être ouverts, y compris le gestionnaire de tâches, le registre, le panneau de configuration, les paramètres, etc. Une fois ouverts, tous les caractères tronqués de WPS apparaissent. Cette situation ne peut pas être résolue à distance. Le logiciel distant est également un exe, ce qui semble insoluble. Voyons comment 20 fonctionne pour restaurer l'ordinateur de l'ami à la normale. En effet, la méthode d'ouverture de l'exe a été modifiée en WPS et il vous suffit de restaurer la méthode d'ouverture par défaut. Er0 exporte les informations du registre exe sur un ordinateur normal et les place sur le site Web. Étant donné que le navigateur peut être ouvert, veuillez me guider pour ouvrir notre site Web, copier les informations du registre, créer un nouveau document texte sur le bureau et l'enregistrer sous [Nom du fichier : 1.reg ; Type d'enregistrement : Tous les fichiers (*.

Comment créer une table MySQL en utilisant PHP ? Comment créer une table MySQL en utilisant PHP ? Jun 04, 2024 pm 01:57 PM

La création d'une table MySQL à l'aide de PHP nécessite les étapes suivantes : Connectez-vous à la base de données. Créez la base de données si elle n'existe pas. Sélectionnez une base de données. Créer un tableau. Exécutez la requête. Fermez la connexion.

Tutoriel détaillé sur l'établissement d'une connexion à une base de données à l'aide de MySQLi en PHP Tutoriel détaillé sur l'établissement d'une connexion à une base de données à l'aide de MySQLi en PHP Jun 04, 2024 pm 01:42 PM

Comment utiliser MySQLi pour établir une connexion à une base de données en PHP : Inclure l'extension MySQLi (require_once) Créer une fonction de connexion (functionconnect_to_db) Appeler la fonction de connexion ($conn=connect_to_db()) Exécuter une requête ($result=$conn->query()) Fermer connexion ( $conn->close())

iOS 18 ajoute une nouvelle fonction d'album 'Récupéré' pour récupérer les photos perdues ou endommagées iOS 18 ajoute une nouvelle fonction d'album 'Récupéré' pour récupérer les photos perdues ou endommagées Jul 18, 2024 am 05:48 AM

Les dernières versions d'Apple des systèmes iOS18, iPadOS18 et macOS Sequoia ont ajouté une fonctionnalité importante à l'application Photos, conçue pour aider les utilisateurs à récupérer facilement des photos et des vidéos perdues ou endommagées pour diverses raisons. La nouvelle fonctionnalité introduit un album appelé "Récupéré" dans la section Outils de l'application Photos qui apparaîtra automatiquement lorsqu'un utilisateur a des photos ou des vidéos sur son appareil qui ne font pas partie de sa photothèque. L'émergence de l'album « Récupéré » offre une solution aux photos et vidéos perdues en raison d'une corruption de la base de données, d'une application d'appareil photo qui n'enregistre pas correctement dans la photothèque ou d'une application tierce gérant la photothèque. Les utilisateurs n'ont besoin que de quelques étapes simples

Comment Go WebSocket s'intègre-t-il aux bases de données ? Comment Go WebSocket s'intègre-t-il aux bases de données ? Jun 05, 2024 pm 03:18 PM

Comment intégrer GoWebSocket à une base de données : Configurer une connexion à la base de données : Utilisez le package database/sql pour vous connecter à la base de données. Stocker les messages WebSocket dans la base de données : utilisez l'instruction INSERT pour insérer le message dans la base de données. Récupérer les messages WebSocket de la base de données : utilisez l'instruction SELECT pour récupérer les messages de la base de données.

See all articles