在原有3306端口mysqld服务的情况再搭建第二个3308端口的mysql实例(五)
:02 ib_logfile1
drwx------ 2 mysql mysql 4096 Sep 12 02:56 mysql
-rw-rw---- 1 mysql mysql 67100 Sep 12 02:56 mysql-bin.000001
-rw-rw---- 1 mysql mysql 1211196 Sep 12 02:56 mysql-bin.000002
-rw-rw---- 1 mysql mysql 143 Sep 12 03:02 mysql-bin.000003
-rw-rw---- 1 mysql mysql 81 Sep 12 02:58 mysql-bin.log.index
drwx------ 2 mysql mysql 4096 Sep 12 02:56 performance_schema
drwx------ 2 mysql mysql 4096 Sep 12 02:56 test
奇怪配置文件里面的error.err并没有出现,而是产生了一个472322.com.err的文件,那么十有八九就是/etc/my56m1.cnf没有起作用,否则,不可能没有error.err的而是默认的472322.com.err 日志
我在第8步的时候执行init db的时候,命令中指定了 scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql56m1 --datadir=/data56m1 --defaults-file=/etc/my56m1.cnf 配置文件是/etc/my56m1.cnf啊
再去看第8步执行的日志信息:
看到如下信息:
New default config file was created as /usr/local/mysql56m1/my.cnf and
will be used by default by the server when you start it.
You may edit this file to change server settings
好像是说没有找到默认的basedir根目录下的my.cnf所以就自动创建了一个根目录的my.cnf。难道mysqld服务启动的时候没有识别--defaults-file参数?
11.2 check /etc/init.d/mysqld56m1
打开/etc/init.d/mysqld56m1启动文件看看
extra_args=""
if test -r "$basedir/my.cnf"
then
extra_args="-e $basedir/my.cnf"
else
if test -r "$datadir/my.cnf"
then
extra_args="-e $datadir/my.cnf"
fi
fi
...
# Get arguments from the my.cnf file,
# the only group, which is read from now on is [mysqld]
if test -x ./bin/my_print_defaults
then
print_defaults="./bin/my_print_defaults"
elif test -x $bindir/my_print_defaults
then
print_defaults="$bindir/my_print_defaults"
elif test -x $bindir/mysql_print_defaults
then
print_defaults="$bindir/mysql_print_defaults"
else
# Try to find basedir in /etc/my.cnf
conf=/etc/my.cnf
print_defaults=
if test -r $conf
then
subpat='^[^=]*basedir[^=]*=\(.*\)$'
dirs=`sed -e "/$subpat/!d" -e 's//\1/' $conf`
for d in $dirs
do
d=`echo $d | sed -e 's/[ ]//g'`
if test -x "$d/bin/my_print_defaults"
then
print_defaults="$d/bin/my_print_defaults"
break
fi
if test -x "$d/bin/mysql_print_defaults"
then
print_defaults="$d/bin/mysql_print_defaults"
break
fi
done
fi
# Hope it's in the PATH ... but I doubt it
test -z "$print_defaults" && print_defaults="my_print_defaults"
fi
...
看到都指向了my.cnf,先去找/etc/my.cnf,如果找不到,再找$basedir/my.cnf,为什么我init db的时候defaults-file设置无效呢?
12 copy config file to basedir directory
我尝试做了操作,把/etc/my56m1.cnf copy到$basedir/my.cnf
[root@472322 data56m1]# cp /etc/my56m1.cnf /usr/local/mysql56m1/my.cnf
[root@472322 data56m1]#
[root@472322 data56m1]# service mysqld56m1 start
Starting MySQL. SUCCESS!
Ok成功了。
13 check the error log
[root@472322 data56m1]# ll
total 1160480
-rw-r----- 1 mysql root 5037 Sep 12 03:07 472322.com.err
-rw-rw---- 1 mysql mysql 6 Sep 12 03:21 472322.com.pid
-rw-rw---- 1 mysql mysql 56 Sep 12 02:58 auto.cnf
-rw-rw---- 1 mysql mysql 12417 Sep 12 03:21 error.err
-rw-rw---- 1 mysql mysql 1073741824 Sep 12 03:22 ibdata01
-rw-rw---- 1 mysql mysql 12582912 Sep 12 03:07 ibdata1
-rw-rw---- 1 mysql mysql 50331648 Sep 12 03:22 ib_logfile0
-rw-rw---- 1 mysql mysql 50331648 Sep 12 03:02 ib_logfile1
drwx------ 2 mysql mysql 4096 Sep 12 02:56 mysql
srwxrwxrwx 1 mysql mysql 0 Sep 12 03:21 mysql3308.sock
-rw-rw---- 1 mysql mysql 67100 Sep 12 02:56 mysql-bin