初级第一次在linux下安装mysql-5.7.19版本教程,如果已经会安装了,那么请看下一篇linux下安装多个mysql-5.7.19
环境:centos 6.5
1、下载
2、跳过登陆
3、上传并解压到目录../usr/local/mysql-5.7.19-3307
tar -zxvf mysql-5.7.19-linux-glibc2.12-x86_64.tar.gz -C ../usr/local/mysql5.7.19-3307
4、添加系统mysql组和mysql用户:
执行命令:
groupadd mysqlosf和useradd -r -g mysqlosf mysqlosf
5、授权当前目录给组用户mysqlosf
chown -R mysqlosf:mysqlosf .
执行红框内的两个命令发现都不行 观察报错原因意思是找不到路径 这里的原因是默认选择安装到usr/lcoal/mysql
因为我们一个系统可能安装多个数据库 一主多从 或者多主多从 ,我这里也是因为有了一个mysql那么我在安装的时候就不会使用它默认的路径以及端口3306,选择了自定义路径usr/,那么我们发现新版本的mysql这里就会有问题。
那么我查看了mysqld执行文件,结果很遗憾,那么我看到了在support-files下面有个mysql.server这里面有个红色框内说的特别好,那么我们理解他就是配置文件默认的,然后红色框内是描述:
大意翻译:如果你安装mysql在其他路径 而不是usr/local/mysql,那么你必须做以下的事情 运行这个脚本在mysql安装的目录,创建一个 /etc/my.cnf文件和以下信息
[mysqld]
basedir=<path-to-mysql-installation-directory>
添加上述的内容到任意其他的配置文件 例如 ~/.my.ini
并且copy my_print_defaults 到 /usr/bin 添加这个路径到安装目录的基本路径,如果你想要影响其他变量你应该啊做些改变在etc/my.cnf 或其他配置信息。
如果你改变了基本目录,你必须也改datadir数据目录,这些会是设置的默认配置文件被重写。
但是相同道理我发现个可恶的事情,假如说现在你安装这个安装了那么再来一个mysql呢也是这么安装,到etc/my.cnf吗?可以发现这里其实他想表达的只是如果你需要只是安装一个mysql的话那么安照刚才上面所述的就可以了,但是我们现在要安装多个,那么肯定这样是不可以的,但是配置文件肯定
6、得需要 先在mysql-5.7.19-3307目录下创建my.cnf配置文件如下图:
7、然后开始初始化3307端口上的mysql:
bin/mysqld --defaults-file=/usr/local/mysql-5.7.19-3307/my.cnf --initialize --user=mysqlosf

然后提示信息如图:
2017-07-20T03:34:58.140832Z 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details).
2017-07-20T03:35:00.213126Z 0 [Warning] InnoDB: New log files created, LSN=45790
2017-07-20T03:35:00.482183Z 0 [Warning] InnoDB: Creating foreign key constraint system tables.
2017-07-20T03:35:00.554451Z 0 [Warning] No existing UUID h>'k4(brZj3ro疒j惚r'&*rokkR2 |