MySQL Master/Slave Server ¼ÜÉè
»·¾³£ºÁ½Ì¨·þÎñÆ÷IP:192.168.30.57\192.168.30.58
1¡¢ÏÂÔØmysql-5.0.86-linux-i686-glibc23.tar.gz µ½http://dev.mysql.com/downloads/mysql/5.0.html#linuxÏÂÔØ
2¡¢½âѹ tar -zxvf
mysql-5.0.86-linux-i686-glibc23.tar.gz
3¡¢´´½¨Á´½Ó ln -s
mysql-5.0.86-linux-i686-glibc23
mysql
4¡¢½øÈëmysql
Ŀ¼Ï cd mysql
5£ºÐ½¨ mysql Óû§×é
groupadd mysql
6£ºÐ½¨ mysqlÓû§²¢ÊôÓÚmysqlÓû§×é
useradd -g mysql mysql
7£ºÖ´Ðа²×°½Å±¾£º
scripts/mysql_install_db --user=mysql
8£º¸Ä±äÊô×é (×¢ÒâСÊýµã)
chown -R root . (×¢ÒâСÊýµã)
9£º¸Ä±äÊý¾ÝÊô×é
chown -R mysql data
10£ºÊäÈëÃüÁî chgrp -R mysql . (×¢ÒâСÊýµã)
11¡¢¿½±´ÅäÖÃÎļþ cp supports-files/my-lagre.cnf /etc/my.cnf
12¡¢Æô¶¯mysql
bin/mysqld_safe -user=root &
13¡¢µÇ¼ bin/mysql
-uroot -p
Ò»¡¢Master Server ·½Ãæ
A.É趨 Server-id
Ê×ÏÈÒªÉ趨 server-id¡£»ù±¾ÉÏûÓÐÊ²Ã´ÌØ±ðµÄÏÞÖÆ£¬Ö»Òª Master ºÍ Slave µÄ server-id ²»Ò»Ñù¼´¿É£¬µ«ÆäÖµ±ØÐèΪ
1 ÖÁ 2^32-1 Ö®¼ä¡£
[mysqld]
server-id=1
B.¿ªÆô Binary Log
ÐÞ¸Ä MySQL Server µÄϵͳÉ趨µµ£¬ÔÚ [mysqld] Ï·½¼ÓÉÏ log-bin=mysql-bin£¬ÀýÈ磺
ÒýÓÃ:
[mysqld]
log-bin=mysql-bin
MySQL µÄ Binary Log »á½«ËùÓжÔì¶×ÊÁÏ¿âµÄÐ޸IJÙ×÷È«²¿¼Ç¼ÆðÀ´£¬¶ø Slave Óë Master
Ö®¼ä½øÐÐ×ÊÁÏͬ²½µÄ·½Ê½ºÜ¼òµ¥£¬¾ÍÊÇ Slave »á°Ñ Master Server µÄ Binary Log ÄùýÀ´Ö´ÐУ¬Ò²¾ÍÊÇ˵ Slave
Server »á "ÖØ×ö" ÔÚ Master Server ÉÏ·¢ÉúµÄ¸÷ÖÖÐ޸IJÙ×÷¡£Òò´Ë Master Server Îð±ØÒª¿ªÆô Binary
Log ¹¦ÄÜ£¬·ñÔò Master/Slave ¼Ü¹¹ÎÞ·¨ÔË×÷¡£
C.É趨 Replication Slave ȨÏÞ
ÎÒÃDZØÐëÒªÔÚ Master Server ÉÏ×öÉ趨£¬Èà Slave ¾ßÓпÉÒÔ´Ó Master Server ÉÏ Copy ×ÊÁϵÄȨÏÞ(ÕýʽµÄ˵·¨Îª Replication Slave Priviledges)£¬ËùÐèʹÓõÄÖ¸ÁîÈçÏ£º
ÒýÓÃ:
GRANT REPLICATION SLAVE ON *.* TO 'slave1'@'192.168.30.58'
IDENTIFIED BY '123456';
Òâ˼Ϊ£º
ÔÊÐí 192.168.30.58 Õâ¸ö IP ʹÓà slave1 Õʺţ¬À´½øÐÐ×ÊÁÏͬ²½(Replication)¡£
slave1 Õâ¸öÕʺŵÄÃÜÂëΪ 123456¡£
´ËʱÄú¿ÉÒÔ´Ó Slave Server(192.168.30.58) ʹÓà mysql client program ½øÐÐÑéÖ¤£¬¿´ÊÇ·ñÓÐÕý
Ïà¹ØÎĵµ£º
а²×°ºóµÄmysqlÊý¾Ý¿â£¬ÆäĬÈϵÄ×î´óÁ¬½ÓÊýΪ100¡£
·½·¨Ò»£º
ÔÚmysql°²×°Â·¾¶Ï£¬ÕÒµ½my.ini»òÕßmy.cnfÎļþ£¬´ò¿ªËüÕÒµ½max_connections,ÉèÖóÉ1000; È»ºóÖØÆômysql·þÎñ¡£
·½·¨¶þ£º
ÔÚmysqlÔËÐл·¾³Ï£¬½øÈëmysqlÃüÁîÏ£º
mysql> set global max_connections=1000;
È»ºó¹Ø±ÕmysqlÖØÆôËü£»
ÔÚ./bin·¾¶Ï£¬Ê¹Óà # ......
1¡¢È·¶¨Êý¾Ý¿âĬÈϱàÂ룬±ÈÈç±àÂëΪutf8,½«¶ÁÈë;¾¶±àÂëͬÑùÉèΪutf8£¬ÃüÁîΪ£ºset names utf8;
2¡¢source d:/20080613.sql µ¼ÈëÊý¾Ý¡£ÑéÖ¤Êý¾Ý¿âÖеÄÊý¾ÝÊÇ·ñ´æÔÚÂÒÂë¡£
3¡¢Èç¹ûÈÔÈ»´æÔÚÂÒÂëÎÊÌ⣬Õâʱºò¾ÍÒª¿¼ÂǸı䵼ÈëÎļþµÄ±à ......
1.ʲôÊÇUDF? UDF(user-defined function)ÊÇmysqlΪÓû§ÌṩµÄ×Ô¶¨Ò庯ÊýµÄÀ©Õ¹½Ó¿Ú¡£Ëü±¾ÖÊÉϺÍmysqlÌṩµÄmax¡¢minºÍcountµÈº¯ÊýÀàËÆ¡£ 2.UDF¿ÉÒÔ×öʲô? UDFÊÇ×Ô¶¨Ò庯Êý£¬ËùÒÔËüÄÜ×öʲôÍêȫȡ¾öÓÚÄãµÄʵÏÖ¡£UDF¿ÉÒÔÔÚÆÕͨµÄsql¡¢triggerÒÔ¼°store procedure±»µ÷ÓᣠÈç¹û×Ô¶¨ÒåÒ»¸ötcp_send(ip,port,msg)µ ......
mysqlÀï×î³£ÓõÄÈÕÖ¾ÓÐ4ÖÖ,·Ö±ðÊÇ:´íÎóÈÕÖ¾,¶þ½øÖÆÈÕÖ¾,²éѯÈÕÖ¾ÒÔ¼°Âú²éѯÈÕÖ¾. 1.´íÎóÈÕÖ¾»á¼Ç¼µ±mysqlÆô¶¯ºÍ¹Ø±ÕÒÔ¼°ÔËÐÐÖеĴíÎóÐÅÏ¢,¿ÉÒÔʹÓà --log-error[=file_name]À´Ö¸¶¨´íÎóÈÕÖ¾´æ·ÅÎļþ.µ±mysql serverÒì³£µÄʱºòÓ¦¸ÃÊ×ÏȲ鿴¸ÃÈÕÖ¾.ÆäʵÀïÃæÒ²Ã»Ê²Ã´,ÎÒÓ¢ÓïËļ¶Ã»¹ý,ÅäÉϴʰÔĿǰΪֹ»¹Ã»ÓÐÅöµ½½â¾ö²»Á˵ÄÎÊ ......
MySQLÅäÖÃÎļþ
MySQL·¢²¼µÄ×îвúƷʵ¼ÊÉϳ¬³öÁËLinuxËùЯ´øµÄ°æ±¾¡£µ«ÊÇ£¬Îȶ¨ÐԺͿª·ÅÔ´´úÂë¿ÉÊǺÜÖØÒªµÄÒòËØ£¬Òò´ËÔÚ²Ù×÷ϵͳÉÏʹÓýÏÔçMySQL°æ±¾ÊÇÓеÀÀíµÄ¡£
ÓÐÐí¶à¿ÉÒÔ²ÉÓõÄÅäÖÃÎļþ£¬ËüÃǶ¼±»°üº¬ÔÚmysql-server PRM³ÌÐòÖС£»¹ÓÐÒ»¸öĬÈϵÄÅäÖÃÎļþ±»°üº¬ÔÚmysql PRM³ÌÐò°üÖС£
ÅäÖÃMySQL·þÎñÆ÷ÊÇÒ»¸ö·á¸»¶ø¸´ÔÓ ......