mysql连接管理及实例初始化配置

1.mysql连接管理

  1)连接工具      mysql

  2)常见的特定连接选项:

    -u:指定用户  -p:指定密码    -h:指定主机      -P:指定端口      -S:指定搜sock     -e:指定SQL

    --protocol=那么:指定连接方式

  3)第三方的连接工具

    sqlyog    navicat

    应用程序连接mysql

    注意: 需要加载对应语言程序的API

2.连接方式

  1)socket连接

mysql -uroot -poldboy123 -S/application/mysql/tmp/mysql.sock

mysql -uroot -poldboy123

  2)TCP/IP

mysql -uroot -poldboy123 -h10.0.0.51 -P3306

 

3.mysql启动流程

4.mysql实例初始化配置

1)预编译:cmake去指定,硬编码到程序当中去

2)在命令行设定启动初始化配置

 

--skip-grant-tables --skip-networking

--datadir=/application/mysql/data

--basedir=/application/mysql

--defaults-file=/etc/my,cnf

--pid-file=/application/mysql/data/db01.pid

--socket=/application/mysql/data/mysql.sock

--user=mysql --port=3306

--log-error=/application/mysql/data/db01.err

3)初始化配置文件(/etc/my.cnf)

配置文件读取顺序:

/etc/my.cnf
/etc/mysql/my.cnf
$MYSQL_HOME/my.cnf(前提是在环境变量中定义了MYSQL_HOME变量)
defaults-extra-file (类似include)
~/my.cnf

 5.mysql多实例配置

1.什么是多实例

  1)多套后台进程+线程+内存结构

  2)多个配置文件
a.多个端口
b.多个socket文件
c.多个日志文件
d.多个server_id

  3)多套数据

2.多实例实战

 #创建数据目录

[root@db01 ~]# mkdir -p /data/330{7..9}

#创建配置文件

[root@db01 ~]# touch /data/330{7..9}/my.cnf

#编辑3307配置文件

[root@db01 ~]# vim /data/3307/my.cnf

[mysqld]

basedir=/application/mysql

datadir=/data/3307/data

socket=/data/3307/mysql.sock

log_error=/data/3307/mysql.log

log-bin=/data/3307/mysql-bin

server_id=7

port=3307

[client]

socket=/data/3307/mysql.sock

#编辑3308配置文件

[root@db01 ~]# vim /data/3308/my.cnf

[mysqld]

basedir=/application/mysql

datadir=/data/3308/data

socket=/data/3308/mysql.sock

log_error=/data/3308/mysql.log

log-bin=/data/3308/mysql-bin

server_id=8

port=3308

[client]

socket=/data/3308/mysql.sock

#编辑3309配置文件

[root@db01 ~]# vim /data/3309/my.cnf

[mysqld]

basedir=/application/mysql

datadir=/data/3309/data

socket=/data/3309/mysql.sock

log_error=/data/3309/mysql.log

log-bin=/data/3309/mysql-bin

server_id=9 port=3309

[client]

socket=/data/3309/mysql.sock

#初始化3307数据

[root@db01 ~]#/application/mysql/scripts/mysql_install_db \

--user=mysql \

--defaults-file=/data/3307/my.cnf \

--basedir=/application/mysql

--datadir=/data/3307/data

#初始化3308数据

[root@db01 ~]#/application/mysql/scripts/mysql_install_db \

--user=mysql \ --defaults-file=/data/3308/my.cnf \

--basedir=/application/mysql

--datadir=/data/3308/data

#初始化3309数据 [root

@db01 ~]#/application/mysql/scripts/mysql_install_db \

--user=mysql \ --defaults-file=/data/3309/my.cnf \

--basedir=/application/mysql

--datadir=/data/3309/data

#修改目录权限

[root@db01]# chown -R mysql.mysql /data/330*

#启动多实例

[root@db01]# mysqld_safe

--defaults-file=/data/3307/my.cnf &

[root@db01]# mysqld_safe --defaults-file=/data/3308/my.cnf &

[root@db01]# mysqld_safe --defaults-file=/data/3309/my.cnf &

#查看server_id

[root@db01]# mysql -S /data/3307/mysql.sock -e "show variables like 'server_id'"

[root@db01]# mysql -S /data/3308/mysql.sock -e "show variables like 'server_id'"

[root@db01]# mysql -S /data/3309/mysql.sock -e "show variables like 'server_id'"

 

posted @ 2018-11-26 21:55  只许澎湃不许爱  阅读(525)  评论(0编辑  收藏  举报