CentOS 6.8 编译安装MySQL5.5.32 (二 多实例)

前端之家收集整理的这篇文章主要介绍了CentOS 6.8 编译安装MySQL5.5.32 (二 多实例)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

MysqL多实例的配置

通过上文 CentOS 6.8 编译安装MysqL5.5.32 ,我们完成了编译安装,接下配置多实例


5,添加多实例目录

[root@db01application]#mkdir-p/data/{3306,3307}/data
[root@db01application]#tree/data/
/data/
├──3306
│└──data
└──3307
└──data,

6,上传多实例配置文件

[root@db01/]#cd/
[root@db01/]#rz-ydata.zip
[root@db01/]#unzipdata.zip
[root@db01/]#treedata
data
├──3306##3306实例目录
│├──data
│├──my.cnf
│└──MysqL
└──3307
├──data
├──my.cnf
└──MysqL

##多实例 文件对比 配置文件中 只有字符串 3306与3307,与serverID 的不同

7,给MysqL启动脚本增加执行权限

find/data-typef-name"MysqL"|xargschmod+x
chown-RMysqL.MysqL/data

wKiom1kEGjLzMo8JAABdjs04lcw923.png

8,多实例初始化,作用就是加载MysqL自带的库与表##

cd/application/MysqL/scripts
./MysqL_install_db--basedir=/application/MysqL--datadir=/data/3306/data--user=MysqL
./MysqL_install_db--basedir=/application/MysqL/--datadir=/data/3307/data--user=MysqL

##提示:--basedir=/application/MysqL/为MysqL的安装路径,--datadir为数据文件目录。
另,注意MysqL_install_db和MysqL5.1的路径不同,MysqL5.1不在MysqLbin路径下了。

编译过程,注意要有2个OK 才算成功

[root@db02scripts]#./MysqL_install_db--basedir=/application/MysqL--datadir=/data/3306/data--user=MysqL
WARNING:Thehost'db02'couldnotbelookedupwithresolveip.
Thisprobablymeansthatyourlibclibrariesarenot100%compatible
withthisbinaryMysqLversion.TheMysqLdaemon,MysqLd,shouldwork
normallywiththeexceptionthathostnameresolvingwillnotwork.
ThismeansthatyoushoulduseIPaddressesinsteadofhostnames
whenspecifyingMysqLprivileges!
InstallingMysqLsystemtables...
OK#<==两个OK是初始化成功的标志。
Fillinghelptables...
OK#<==两个OK是初始化成功的标志。
TostartMysqLdatboottimeyouhavetocopy
support-files/MysqL.servertotherightplaceforyoursystem
PLEASEREMEMBERTOSETAPASSWORDFORTHEMysqLrootUSER!
Todoso,starttheserver,thenissuethefollowingcommands:
/application/MysqL/bin/MysqLadmin-urootpassword'new-password'
/application/MysqL/bin/MysqLadmin-uroot-hdb02password'new-password'
Alternativelyyoucanrun:
/application/MysqL/bin/MysqL_secure_installation
whichwillalsogiveyoutheoptionofremovingthetest
databasesandanonymoususercreatedbydefault.Thisis
stronglyrecommendedforproductionservers.
Seethemanualformoreinstructions.
YoucanstarttheMysqLdaemonwith:
cd/application/MysqL;/application/MysqL/bin/MysqLd_safe&
YoucantesttheMysqLdaemonwithMysqL-test-run.pl
cd/application/MysqL/MysqL-test;perlMysqL-test-run.pl
Pleasereportanyproblemswiththe/application/MysqL/scripts/MysqLbugscript!
###请注意如下几行英文的说明及报错
Newdefaultconfigfilewascreatedas/application/MysqL//my.cnfand
willbeusedbydefaultbytheserverwhenyoustartit.
Youmayeditthisfiletochangeserversettings
#从上文说明中可以指导MysqL的默认配置文件已经变到了/application/MysqL//my.cnf
WARNING:Defaultconfigfile/etc/my.cnfexistsonthesystem
ThisfilewillbereadbydefaultbytheMysqLserver
Ifyoudonotwanttousethis,eitherremoveit,orusethe
--defaults-fileargumenttoMysqLd_safewhenstartingtheserver
#从上文说明中可以看到数据库启动时会读取/etc/my.cnf,因此有可能会导致无法启动,避免的方法就是使用MysqLd_safe启动服务时采用--defaults-file参数指定配置文件,前文已将/etc/my.cnf改名了,所以,就不需要指定参数了,这里是一个坑,读者要注意。
此步骤必须要初始化成功,否则,后面会出现登录不了数据库等各种问题。
[root@oldboy~]#MysqL
ERROR1045(28000):Accessdeniedforuser'root'@'localhost'(usingpassword:NO)
解决办法:重新初始化数据库即可,此问题一般都是数据库初始化问题,或者数据库文件损坏,以及目录权限问题

9,MysqL 初始化原理

初始化数据库的就是加载MysqL自带的库与表 例如:生成的test及MysqL库表等。

初始化数据库后,查看数据目录,生成哪些文件

[root@db02scripts]#ls-l/data/3306/data/
total143372
-rw-rw----1MysqLMysqL134217728Apr2903:32ibdata1
-rw-rw----1MysqLMysqL4194304Apr2903:32ib_logfile0
-rw-rw----1MysqLMysqL4194304Apr2903:32ib_logfile1
-rw-rw----1MysqLMysqL4194304Apr2903:32ib_logfile2
drwx------2MysqLroot4096Apr2903:31MysqL##用于存放管理MysqL数据
drwx------2MysqLMysqL4096Apr2903:31performance_schema#内部性能库
drwx------2MysqLroot4096Apr2903:31test##测试库

10,启动MysqL 命令 多实例(3306/3307)

[root@db02scripts]#/data/3306/MysqLstart##启动脚本见百度云连接
StartingMysqL...
[root@db02scripts]#/data/3307/MysqLstart
StartingMysqL...
[root@db02scripts]#ps-ef|grep330
root134261011:32pts/100:00:00/bin/sh/application/MysqL/bin/MysqLd_safe--defaults-file=/data/3306/my.cnf
MysqL1415013426011:32pts/100:00:05/application/MysqL-5.5.32/bin/MysqLd--defaults-file=/data/3306/my.cnf--basedir=/application/MysqL--datadir=/data/3306/data--plugin-dir=/application/MysqL/lib/plugin--user=MysqL--log-error=/data/3306/MysqL_oldboy3306.err--open-files-limit=1024--pid-file=/data/3306/MysqLd.pid--socket=/data/3306/MysqL.sock--port=3306
root178401012:57pts/100:00:00/bin/sh/application/MysqL/bin/MysqLd_safe--defaults-file=/data/3307/my.cnf
MysqL18540178401512:57pts/100:00:01/application/MysqL-5.5.32/bin/MysqLd--defaults-file=/data/3307/my.cnf--basedir=/application/MysqL--datadir=/data/3307/data--plugin-dir=/application/MysqL/lib/plugin--user=MysqL--log-error=/data/3307/MysqL_oldboy3307.err--open-files-limit=1024--pid-file=/data/3307/MysqLd.pid--socket=/data/3307/MysqL.sock--port=3307
root185581286012:57pts/100:00:00grep--color=auto330
##如果启动失败,请检查日志,路径是在每个实例下都有个err文件,例如下面的3306
[root@db02scripts]#vi/data/3306/MysqL_oldboy3306.err

11,连接MysqL数据库( 以socket区分,多实例

[root@db02scripts]#MysqL-uroot-p-S/data/3306/MysqL.sock#-S指定要启动实例的socket-bash:MysqL:commandnotfound#报错是因为没有设定环境变量
解决方法的两种思路:(建议使用第二种)
1)将MysqL路径添加到环境变量
echo"PATH=$PATH:/application/MysqL/bin/">>/etc/profile
source/etc/profilep
2)将MysqL需要执行的文件或脚本,拷贝到第一个已经有环境变量权限的目录下,去执行。
cp/application/MysqL/bin/*/usr/local/sbin/
再次连接,登录3306
[root@db02~]#MysqL-uroot-p-S/data/3306/MysqL.sock
[root@db02~]#MysqL-uroot-p-S/data/3307/MysqL.sock
Enterpassword:WelcometotheMysqLmonitor.Commandsendwith;or\g.YourMysqLconnectionidis2Serverversion:5.5.32-logSourcedistributionCopyright(c)2000,2013,Oracleand/oritsaffiliates.Allrightsreserved.OracleisaregisteredtrademarkofOracleCorporationand/oritsaffiliates.Othernamesmaybetrademarksoftheirrespectiveowners.Type'help;'or'\h'forhelp.Type'\c'toclearthecurrentinputstatement.MysqL>

12,添加开机自启动 (多实例 multi instances

[root@db02~]#echo"#MysqLmultiinstances">>/etc/rc.local#添加注释,及实例启动项
[root@db02~]#echo"/data/3306/MysqLstart">>/etc/rc.local
[root@db02~]#echo"/data/3307/MysqLstart">>/etc/rc.loca

l

13,排错总结

MysqL多实例启动故障排错说明

  1. 如果MysqL多实例有服务没有被启动,排除方法如下:

    如果发现没有显示MysqL对应的实例端口,请稍微等待几秒在检查,MysqL服务的启动稍慢

    如果还是不行,请查看MysqL实例对应的错误日志,路径在my.cnf配置文件中最下面定义:

    例如:3306实例的错误日志为:/data/3306/*.err

  2. 细看所有执行命令返回的屏幕输出,不要忽略关键的输出内容

  3. 辅助查看系统日志/var/log/messages

  4. 如果是MysqL关联了其他服务,同时查看相关服务日志

  5. 仔细阅读,重新查看操作的步骤是否正确,书写命令及字符串是否正确。

  6. 多看日志,多多总结,终究会称为高手的。

猜你在找的CentOS相关文章