1.前言
MySQL有三种安装方式:RPM安装、二进制包安装、源码包安装。这3种种方式各有特色,主要特点参考下表。实际应用中,可以根据你所用的主机环境进行优化,选择最佳的配置值,安装定制更灵活。访问MySQL网站http://dev.mysql.com/downloads/下载最新稳定发行版的对应MySQL版本,本文对MySQL 5.6.26的二进制版本进行安装演示。
RPM
二进制
源码
优点
安装简单,适合初学者
安装简单,可以安装到任何路径下,灵活性好,一台服务器可以安装多个MySQL。
在实际安装的操作系统进行可根据需要定制编译,最灵活;性能最好,一台服务器可以安装多个MySQL。
缺点
1.需要单独下载客户端和服务器端;
2.安装路径不灵活,默认路径不能修改,一套服务器只能安装一个MySQL。
已经经过编译,性能不如源码编译的好,不能灵活定制编译参数。
安装过程较复杂,编译时间长
文件布局
/usr/bin 客户端程序和脚本
/usr/sbin MySQL服务器
/var/lib/mysql日志文件和数据库
/usr/share/doc/packages 文档
/usr/include/mysql 包含文件
/usr/lib/mysql 库文件
/usr/share/mysql 错误消息和字符集文件
/usr/share/sql-bench 基准程序
Bin 客户端程序和mysqlid服务器
Data 日志文件和数据库
Doc 文档和changelog
Include 包含文件
Lib 库文件
Scripts mysql_install_db脚本,用来安装系统数据库
Share/mysql 错误消息文件
Sql-bench 基准程序
Bin 客户端程序和脚本
Include/mysql 包含文件
Info info格式的文档
Lib/mysql 库文件
Libexec mysql服务器
Share/mysql 错误消息文件
Sql-bench 基准程序和crash-me测试
Var 数据库和日志文件
2.安装前准备
本文测试环境:CentOS release 6.4(Linux version 2.6.32-358.el6.x86_64)
1)设置MySQL用户和组
创建MySQL用户组和用户,不建立的话,以MySQL二进制包安装后,MySQL启动时会因为Linux文件权限导致问题多多
新增MySQL用户组:
- [root@nn ~]# groupadd mysql
新增MySQL用户:
- [root@nn ~]# useradd -r -g mysql mysql
2)新建MySQL数据库数据文件目录
- [root@nn ~]# mkdir -p /data/mysqldb
- [root@nn ~]# chown -R mysql:mysql /data/mysqldb
- [root@nn ~]# cd /usr/local
3.安装MySQL
1)下载MySQL二进制安装包
下载地址:http://dev.mysql.com/downloads/mysql/在Select Platform:中选择Linux - Generic,然后下载最下面的:mysql-5.6.26-linux-glibc2.5-x86_64..tar.gz(有64位的和32位的,根据需要选择)
2)解压二进制包
- [root@nn local]# tar -xzvf mysql-5.6.26.tar.gz
- [root@nn local]# mv mysql-5.6.26 mysql
- [root@nn local]# cd mysql/
- [root@nn mysql]# chown -R mysql .
- [root@nn mysql]# chgrp -R mysql .
其实MySQL已经安装完了,但还需要初始化,初始化mysql表、test表、infomation表等。datadir可以是其他的,但也需要chown修改下创建者,否则可能会出现权限问题。
4.配置MySQL
- [root@nn mysql]# scripts/mysql_install_db.sh --user=mysql --basedir=/usr/local/mysql --datadir=/data/mysqldb
- [root@nn mysql]# chown -R root .
- [root@nn mysql]# chown -R mysql data
- [root@nn mysql]# chgrp -R mysql .
1)为mysql提供sysv服务脚本
- [root@nn mysql]# cp support-files/mysql.server /etc/init.d/mysqld
2)修改配置文件
- [root@nn mysql]# cp my.cnf /etc/my.cnf
- [root@nn mysql]# vi /etc/my.cnf
3)添加MySQL到服务列表
- [root@nn mysql]# chkconfig --add mysqld
- [root@nn mysql]# chkconfig mysqld on
4) 启动服务,用MySQL用户来启动服务
- [root@nn mysql]# bin/mysqld_safe --user=mysql
5)登录数据库
- [root@nn mysql]# bin/mysql -u root
6) 设置root初始密码
- [root@nn mysql]# bin/mysqladmin -u root password "123456"
7)其他操作
- mysql> select user,host,password from mysql.user; --查询MySQL用户,密码等
- mysql> update mysql.user set password = PASSWORD(‘000000‘) where user = ‘root‘ --修改root密码
- mysql> drop user ‘‘@localhost; --删除空用户
- mysql> FLUSH PRIVILEGES;