centos7安装mysql
本文主要介绍如何在contos7下安装mysql,以及安装成功后需要做的一些后续操作
centos7安装mysql(yum)
安装环境
- centos7
- MySQL 5.6.24
依赖安装
mysql依赖libaio,所以先要安装libaio
1 | yum search libaio #检索相关信息 |
成功安装,提示如下:
1 | [root@bogon /]# yum install libaio |
检查mysql是否已安装
yum list installed | grep mysql
如果已经安装,就先全部卸载,命令如下:yum -y remove mysql-libs.x86_64
若有多个依赖文件则依次卸载。当结果显示为 Complete!即卸载完毕。
安装
添加mysql yum respository
添加 MySQL Yum Repository 到你的系统 repository 列表中,执行wget http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm
yum localinstall mysql-community-release-el7-5.noarch.rpm
显示
1 | [root@bogon software]# yum localinstall mysql-community-release-el7-5.noarch.rpm |
提示“完成!”,则说明 源添加成功。
验证是否添加成功
yum repolist enabled | grep "mysql.*-community.*"
可以看到下面内容:
1 | [root@bogon software]# yum repolist enabled | grep "mysql.*-community.*" |
选择要启用的mysql版本
查看mysql版本,执行yum repolist all | grep mysql
可以看到 5.5, 5.7 版本是默认禁用的,因为现在最新的稳定版是 5.6
1 | [root@bogon software]# yum repolist all | grep mysql |
可以通过类似下面的语句来启动某些版本
1 | yum-config-manager --disable mysql56-community |
或者通过修改 /etc/yum.repos.d/mysql-community.repo 文件
1 | # Enable to use MySQL 5.6 |
其中 enabled=0 是指禁用,enabled=1 指启用。
注意: 任何时候,只能启用一个版本。
执行yum repolist enabled | grep mysql
查看当前的启动的 MySQL 版本
1 | [root@bogon software]# yum repolist enabled | grep mysql |
通过Yum安装mysql
执行命令yum install mysql-community-server
Yum 会自动处理 MySQL 与其他组件的依赖关系:
1 | [root@bogon software]# yum install mysql-community-server |
中途遇到提示,按照提示安装
执行rpm -qi mysql-community-server.x86_64 0:5.6.24-3.el7
执行whereis mysql
可以看到mysql的安装目录是/usr/bin
1 | [root@localhost ~]# whereis mysql |
启动和关闭 MySQL Server
启动 MySQL Server
systemctl start mysqld
查看 MySQL Server 状态
systemctl status mysqld
关闭 MySQL Server
systemctl stop mysqld
测试是否安装成功
mysql
可以进入mysql命令行界面
防火墙设置
远程访问 MySQL, 需开放默认端口号 3306.
方式1:iptables(CentOS 7.x版本之前用法,不推荐)
打开 iptables 的配置文件:vi /etc/sysconfig/iptables
如果该 iptables 配置文件 不存在,先执行 yum install iptables-services 安装
添加
1 | -A RH-Firewall-1-INPUT -m state –state NEW -m tcp -p tcp –dport 3306 -j ACCEPT |
执行iptables重启生效service iptables restart
方式2:firewall-cmd(推荐)
执行
1 | firewall-cmd --permanent --zone=public --add-port=3306/tcp |
这样就开放了相应的端口。
执行firewall-cmd --reload
使最新的防火墙设置规则生效。
mysql安全设置
服务器启动后,可以执行mysql_secure_installation;
根据提示进行选择。
至此,整个 MySQL 安装完成。
远程访问设置
创建一个普通用户 sa ,密码是 some_passCREATE USER 'sa'@'%' IDENTIFIED BY 'some_pass';
给这个用户授予 SELECT,INSERT,UPDATE,DELETE 的远程访问的权限,这个账号一般用于提供给实施的系统访问GRANT SELECT,INSERT,UPDATE,DELETE ON *.* TO 'sa'@'%';
创建一个管理员用户 admin 账号 ,密码是 some_passCREATE USER 'admin'@'%' IDENTIFIED BY 'some_pass';
给这个用户授予所有的远程访问的权限。这个用户主要用于管理整个数据库、备份、还原等操作。GRANT ALL ON *.* TO 'admin'@'%';
使授权立刻生效flush privileges;
更改数据存放目录
创建数据存放目录
home 目录下建立 data 目录mkdir /home/data
把 MySQL 服务进程停掉
如果 MySQL 是启动的,要先关闭mysqladmin -u root -p shutdown
移动数据到数据存放目录
/var/lib/mysql 整个目录移到 /home/data,执行mv /var/lib/mysql /home/data
这样就把 MySQL 的数据文件移动到了 /home/data/mysql 下
修改 /etc/my.cnf 文件,
1 | [mysqld] |
修改权限chown -R mysql:mysql /home/data/mysql
重启后,如果不能启动 MySQL 服务,执行vi /etc/sysconfig/selinux
调整SELINUX=permissive
保存设置,执行 reboot 重启生效
开机自起
查看 MySQL 服务是否开机启动
1 | [root@localhost ~]# systemctl is-enabled mysql.service;echo $? |
如果是 enabled 则说明是开机自动,如果不是,执行chkconfig --levels 235 mysqld on
chkconfig --levels 235 mysqld off
关闭开机启动
设置字符集
一般的,为了支持中文,我们应该讲字符集设为 UTF-8, 执行SHOW VARIABLES LIKE 'character%';
查看当前 MySQL 字符集
1 | mysql> SHOW VARIABLES LIKE 'character%'; |
可以看到默认服务器的字符器是 latin1 ,对中文不友好。
修改 /etc/my.cnf 文件,添加字符集的设置
1 | [mysqld] |
重启 MySQL ,可以看到字符集已经修改了
其他常用配置配置
调整 MySQL 运行参数,修改 /etc/my.cnf 文件,常用配置如下:
1 | [mysqld] |
其他可选参数:
back_log = 384
指定MySQL可能的连接数量。 当MySQL主线程在很短时间内接收到非常多的连接请求,该参数生效,主线程花费很短时间检查连接并且启动一个新线程。 back_log参数的值指出在MySQL暂时停止响应新请求之前的短时间内多少个请求可以被存在堆栈中。 如果系统在一个短时间内有很多连接,则需要增大该参数的值,该参数值指定到来的TCP/IP连接的侦听队列的大小。 试图设定back_log高于你的操作系统的限制将是无效的。默认值为50。对于Linux系统推荐设置为小于512的整数。
max_connections = n
MySQL服务器同时处理的数据库连接的最大数量(默认设置是100)。超过限制后会报 Too many connections 错误
key_buffer_size = n
用来存放索引区块的RMA值(默认设置是8M),增加它可得到更好处理的索引(对所有读和多重写)
record_buffer:
这里写代码片 每个进行一个顺序扫描的线程为其扫描的每张表分配这个大小的一个缓冲区。 如果你做很多顺序扫描,你可能想要增加该值。默认数值是131072(128K)
wait_timeout:
服务器在关闭它之前在一个连接上等待行动的秒数。
interactive_timeout:
服务器在关闭它前在一个交互连接上等待行动的秒数。 一个交互的客户被定义为对 mysql_real_connect()使用 CLIENT_INTERACTIVE 选项的客户。 默认数值是28800,可以把它改为3600。
skip-name-resolve
禁止MySQL对外部连接进行DNS解析,使用这一选项可以消除MySQL进行DNS解析的时间。 但需要注意,如果开启该选项,则所有远程主机连接授权都要使用IP地址方式,否则MySQL将无法正常处理连接请求!
log-slow-queries = slow.log
记录慢查询,然后对慢查询一一优化
skip-innodb
skip-bdb
关闭不需要的表类型,如果你需要,就不要加上这个
备份、还原
方法1:命令行
备份mysqldump --socket=/home/data/mysql/mysql.sock --single-transaction=TRUE -u root -p emsc > emsc.sql
还原mysql --socket=/home/data/mysql/mysql.sock -u root -p emsc < emsc.sql
mysql的sql_mode配置
vi /etc/my.cnf文件
1 | [mysqld] |
修改sql_mode为最后一行的配置,然后重启mysql