MySQL节点部署说明
1.MySQL的编译安装
考虑到MySQL多版本和多分支的特点,综合性能、可用性、成本等因素,我们建议使用Percona公司开发的MySQL,该版本主要使用了XtraDB存储引擎(对于这个存储引擎的特性,以后再专门介绍),完全兼容Innodb,在Innodb_Plugin基础之上进行了增强,支持标准事务的ACID(原子性、一致性、隔离性、持久性)、支持MVCC(Multi-Version Concurrency Control,提供并发控制)、具备更佳的性能、开源可以免费使用,同时Percona公司还提供了开源的物理备份工具(xtrabackup),可以顺利地对使用XtraDB存储引擎的数据库进行快速的物理备份。关于这个分支的详细信息可以查看博客: http://www.mysqlperformanceblog.com/ 。
考虑到版本的成熟性和稳定度,我们建议下载MySQL-5.1版本的源代码,下载的地址列表见: http://www.percona.com/downloads/Percona-Server-5.1/ ,可以考虑选用5.1.47-11.2 (源代码大小 23.7 MB),这个版本网易线上也在大规模的使用,从使用的效果来看,还是非常稳定的。
在安装之前需要检查编译MySQL所需的一些库是否已经安装。在一般的Linux 系统中,可能需要用如下命令安装这些依赖库:
autoconf automake1.9 libtool m4 libncurses5-dev bison ncurses-devel gcc g++
从Percona网站上下载MySQL源代码,保存在本地
http://www.percona.com/downloads/Percona-Server-5.1/Percona-Server-5.1.47-11.2/source/Percona-Server.tar.gz ,或者可以从我这儿来取,对MySQL打了部分的Patch
将压缩文件解压到$dir目录下
进入到$dir下,添加configure 文件为可执行权限
$ cd $dir
$ chmod +x configure
开始编译安装,分下面三步执行
$./configure --prefix=/usr/local/mysql --with-extra-charsets=all --enable-local-infile --enable-thread-safe-client --enable-assembler --with-client-ldflags=-all-static --with-mysqld-ldflags=-all-static --with-plugins=innodb_plugin,partition --with-big-tables --with-readline
$ make
$ make install //由于是安装在/usr目录下,这步需要切换到root用户下执行
MySQL 源码编译参数说明
参数 涵义
--prefix 指定MySQL安装路径,最好是安装到指定的目录
--with-extra-charsets 指定安装扩展字符集
--enable-local-infile 指定允许本地导入文件
--enable-thread-safe-client 指定线程安全模式
--enable-assembler 指定支持汇编,可提升性能
--with-client-ldflags 静态编译,提升性能13%
--with-mysqld-ldflags 静态编译,提升性能13%
--with-plugins=innodb_plugin,partition 指定安装xtradb存储引擎,分区插件,如果想要利用分区功能,必须指定partition插件
--with-big-tables 指定支持超大表
编译完毕后,需要在相应的目录下创建MySQL启动时所需要的配置文件
编译过程中的常见异常:
checking for termcap functions library... configure: error: No curses/termcap library found
ncurses-devel 没有安装
../depcomp: line 571: exec: g++: not found
g++ 没有安装
Warning: Bison executable not found in PATH
bision没有安装
2.MySQL的配置启动
MySQL安装完毕后,需要做相应的配置后,再启动MySQL。
禁用swap
su root
echo 0 > /proc/sys/vm/swappiness
这样修改的话,只是临时有效,如果机器重启,这个值会重新恢复为100 ;为了达到永
久生效,可以修改/etc/sysctl.conf文件,在/etc/sysctl.conf上添加vm.swappiness=0 。这
里需要解释下原因。
Linux有很多很好的内存、IO调度机制,但是并不会适用于所有场景。对于DBA来说,
Linux比较让人头疼的一个地方是,它不会因为MySQL很重要就避免将分配给MySQL的
地址空间映射到swap上。对于频繁进行读写操作的系统而言,数据看似在内存而实际上在
磁盘是非常糟糕的,响应时间的增长很可能直接拖垮整个系统。作为DBA,怎样尽量避免
MySQL使用swap?比如说为什么会产生swap。假设我们的物理内存是16G,swap是4G。
如果MySQL本身已经占用了12G物理内存,而同时其他程序或者系统模块又需要6G内存,
这时候操作系统就可能把MySQL所拥有的一部分地址空间映射到swap上去)。
/etc/sysctl.conf上中的参数vm.swappiness决定了Linux是倾向于使用swap,还是倾向
于释放文件系统cache和buffer(这个大小是多少,可以在root用户下利用FREE命令查看
之)。
在内存紧张的情况下,数值越低越倾向于释放文件系统cache。当然,这个参数只能减少
使用swap的概率,并不能避免Linux使用swap。想想有内存可以使用,干嘛还要使用SWAP
呢?swappiness=0的时候表示最大限度使用物理内存,然后才是 swap空间,swappiness=
100的时候表示积极的使用swap分区,并且把内存上的数据及时的搬运到swap空间里面。
创建MySQL帐号
useradd mysql
passwd mysql
创建MySQL数据目录,这里MySQL的数据目录和配置文件最好放在统一的文件
目录下,数据目录最好采用软链接的形式,这里要注意原始数据目录的权限,如:
[mysql@localhost mysql]$ ls -lh /home/mysql/mysql/
total 4.0K
-rw-r--r-- 1 mysql mysql 2.1K Jul 5 14:54 my1.cnf
lrwxrwxrwx 1 mysql mysql 16 Jul 4 10:50 mysql -> /opt/mysql-test/
[mysql@localhost mysql]$ ls -lh /opt/|grep mysql-test
drwxr-xr-x 4 mysql mysql 4.0K Jul 5 14:54 mysql-test
生成MySQL配置文件
根据MySQL配置文件模板生成MySQL配置文件my.cnf,放在/home/mysql/mysql这个目录下,my.cnf根据模板进行以下修改:
替换#port_holder#为你自己打算使用的端口,这里假设为4321
替换#path_holder#为数据存放的目录,假定为 /home/mysql/mysql/mysql
替换#ip_holder#为当前主机的内网IP
替换#user_holder#为启动MySQL的用户,一般为mysql
模板配置文件如下:
[client]
port = #port_holder#
socket = #path_holder#/mysqld.sock
[mysqld_safe]
user = #user_holder#
nice = 0
ledir =/usr/local/mysql/libexec
[mysqld]
server-id = 3
bind-address = #ip_holder# //注意:如果是配置VIP的话,这个参数不要设置
port = #port_holder#
pid-file = #path_holder#/mysqld.pid
socket = #path_holder#/mysqld.sock
basedir = /usr/local/mysql
datadir = #path_holder#
innodb_data_home_dir = #path_holder#
innodb_log_group_home_dir = #path_holder#
tmpdir = #path_holder#
log-error = #path_holder#/mysqld.log
slow_query_log =1
slow_query_log_file = #path_holder#/mysql-slow.log
log_bin = #path_holder#/mysql-bin.log
log_slave_updates //中继操作使用也记录日志到binary-log
skip-slave-start //MySQL启动的时候,不启动复制
auto_increment_increment =2 //如果是M-M结构,该参数为M的个数
auto_increment_offset =2 //如果是M-M结构,该参数为该实例的编号
user = #user_holder#
language = /usr/local/mysql/share/mysql/english
table_cache = 512
long_query_time = 4
max_connections = 800
query_cache_type = 0
default-character-set = utf8
default-storage-engine = innodb
skip-external-locking
expire_logs_days = 7
max_binlog_size = 100M
innodb_buffer_pool_size = 200M //根据机器的实际情况设置,一般为内存的75%
innodb_data_file_path = ibdata1:512M:autoextend
innodb_autoextend_increment = 128
innodb_log_files_in_group = 2
innodb_log_file_size = 512M
innodb_lock_wait_timeout = 5
innodb_flush_method = O_DIRECT
innodb_flush_log_at_trx_commit = 2
innodb_file_per_table = 1
innodb_file_format =Barracuda
innodb_file_format_check =Barracuda
innodb_adaptive_checkpoint =estimate
innodb_expand_import = 1
innodb_read_io_threads = 1
innodb_stats_method = nulls_unequal
innodb_thread_concurrency = 12
innodb_write_io_threads = 1
innodb_io_capacity =800
[mysqldump]
quick
quote-names
max_allowed_packet = 16M
default-character-set = utf8
[mysql]
default-character-set = utf8
具体的各个参数的含义,在后续的优化文档中介绍说明。
初始化MySQL数据库
cd /home/mysql/mysql
mysql_install_db --defaults-file=my.cnf
启动MySQL
mysqld_safe --defaults-file=/home/mysql/mysql/my.cnf &
查看文件列表
[mysql@localhost mysql]$ ls -lh /home/mysql/mysql/mysql/
total 1.6G
-rw-rw---- 1 mysql mysql 512M Jul 5 14:54 ibdata1
-rw-rw---- 1 mysql mysql 512M Jul 5 14:54 ib_logfile0
-rw-rw---- 1 mysql mysql 512M Jul 4 10:51 ib_logfile1
-rw-rw---- 1 mysql mysql 63 Jul 5 14:54 master.info
drwx------ 2 mysql mysql 4.0K Jul 4 10:48 mysql
-rw-rw---- 1 mysql mysql 125 Jul 5 14:54 mysql-bin.000001
-rw-rw---- 1 mysql mysql 106 Jul 5 14:54 mysql-bin.000002
-rw-rw---- 1 mysql mysql 82 Jul 5 14:54 mysql-bin.index
-rw-rw---- 1 mysql mysql 19K Jul 5 14:54 mysqld.log
-rw-rw---- 1 mysql mysql 12K Jul 4 18:27 mysqld.log-old
-rw-rw---- 1 mysql mysql 5 Jul 5 14:54 mysqld.pid
-rw-rw---- 1 mysql mysql 156 Jul 5 14:54 mysqld-relay-bin.000003
-rw-rw---- 1 mysql mysql 251 Jul 5 14:54 mysqld-relay-bin.000004
-rw-rw---- 1 mysql mysql 52 Jul 5 14:54 mysqld-relay-bin.index
srwxrwxrwx 1 mysql mysql 0 Jul 5 14:54 mysqld.sock
-rw-rw---- 1 mysql mysql 2.8K Jul 5 14:54 mysql-slow.log
-rw-rw---- 1 mysql mysql 51 Jul 5 14:54 relay-log.info
drwx------ 2 mysql mysql 4.0K Jul 4 10:48 test
MySQL默认为生成一个名为root的超级用户,且没有密码,安全性不好,因此先设置MySQL本机超级用户密码:
mysql --defaults-file=/home/mysql/mysql/my.cnf -u root
mysql> set password = password('xxxxxx');
至此MySQL的启动已经完毕,遇到异常的情况下要多多查看错误日志文件mysqld.log,上面记录了MySQL在运行过程中的详细信息,类似于Oracle中的alter日志文件。千万不要执行rm -rf /home/mysql/mysql 操作,对于线上环境的话,尽量让最少的人使用root帐号和mysql帐号,尽量在自己的帐号下进行操作(把自己的帐号添加到mysql这个用户组下即可完成大部分的操作)。