0.说明

最近在CentOS6.5上安装mysql,想要知道具体的安装过程,不想要通过yum直接一键安装,折腾一番,但是总遇到些麻烦。于是将mysql文档中的关于如何在Linux上安装mysql的部分仔细的读了一遍,又Google了广大网友的经验贴。总结起来在CentOS或者Red Hat上安装mysql可以有三种方式:

  • 使用rpm -ivh xxx.rpm 或者 yum install xxx (一般推荐使用rpm来安装,需要弄清各个关键目录在哪)
  • 使用编译好的通用二进制版本的mysql来安装(Generic Binaries mysql) (我就是使用方法2来安装的)
  • 使用源码来编译安装。

Linux通用二进制版本mysql是在当我们使用rpm或者yum方法安装失败时,可以使用的方法。因为通用二进制版本对glibc等lib库的版本要求不是很高。所以使用这种方法,可以很好的解决:在低版本的CentOS上安装高版本的mysql。

1.下载

打开网页

http://dev.mysql.com/downloads/mysql/

Select Platform 中选择Linux - Generic,根据自己的系统选择32位或者64位的。

2.创建用户组和用户名(可选)

创建mysql用户组和用户名,相关命令如下:

groupadd mysql
useradd -g -r mysql mysql

3.解压,指定目录

将mysql安装包上传到centos系统的目录/usr/local/,解压软件包。将解压后生成的目录,改名为mysql,/usr/local/mysql就是MySQL数据库的安装目录(basedir)。

cd /usr/local/ #进入安装目录,安装包已经放在这里

tar  -vxfz mysql-5.7.15-linux-glibc2.5-x86_64.tar.gz #解压

mv mysql-5.7.15-linux-glibc2.5-x86_64 mysql #改名为mysql

4.创建mysql数据目录和日志目录

mysql在初始化数据库的时候会用到该数据目录

mkdir /usr/local/data   #数据目录
mkdir /usr/local/logs #日志目录

5.更改目录权限

修改相关目录为mysql专属用户组和用户名

chown -R mysql:mysql /usr/local/mysql

6.创建my.cnf文件

vi /etc/my.cnf

#文件内容:

[client]
port=3306
socket=/tmp/mysql.sock [mysqld]
basedir=/usr/local/mysql
datadir=/usr/local/mysql/data
socket=/tmp/mysql.sock
pid-file=/usr/local/mysql-5.7.16/data/mysql.pid
log_error=/usr/local/mysql-5.7.16/logs/mysql-error.log default-character-set=utf8 #配置字符编码
port=3306
server_id=10
user=mysql sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES

7.初始化mysql

进入数据库目录,以下配置都在/usr/local/mysql下,完成初始化:

#初始化命令1
bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --innodb_undo_tablespaces=3 --explicit_defaults_for_timestamp #初始化命令2
bin/mysql_ssl_rsa_setup --datadir=/usr/local/mysql/data

等待初始化后,如果配置了my.cnf的log_error,那么初始密码在log_error文件中,否则会打印出来。查看日志文件会看到A temporary is generated for root@localhost:u_7UR<%ox- 。MySQL初始化完成后,就可以使用这个密码,在本机通过root用户登录。

8.配置启动文件,启动MySQL服务

Mysql的启动文件mysql.server放在mysql源码包中,如下目录/usr/local/mysql/support-files,复制该文件同时改名为mysql到/etc/init.d/mysql:

#拷贝启动服务命令
cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql #启动mysql服务
/etc/init.d/mysql

9.配置环境变量和开机自启动

配置环境变量:

vim /etc/profile

#在文件最后加上下面两句话
export mysql_home=/usr/local/mysql
export PATH=$PATH:$mysql_home/bin
(也可以不用vi打开文件修改,直接在shell执行命令也可以完成配置:echo "export PATH=/usr/local/mysql/bin:$PATH" >> /etc/profile) #修改文件,使配置立即生效
source /etc/profile

设置开机自启动:

chkconfig --add mysql #添加mysql服务到开机自启动列表
chkconfig mysql on #开机自动启动

10.登录mysql服务

mysql -uroot -p  #这里直接回车

password:  #输入从日志文件里面的初始化密码

登录后,在重设密码之前,什么都不能干,所以要重设秘密:

mysql>alter user root@localhost identified by '你的密码';

这之后就可以正常进行数据库的各种操作了。

注意在5.7中存储密码的字段不再是password了,变成了authentication_string,如果要修改密码,就要执行下面的语句:

update mysql.user set authentication_string=password("root") where user="root";

参考链接:

http://blog.chinaunix.net/uid-25909722-id-4605091.html

http://www.th7.cn/system/lin/201607/172036.shtml

http://dev.mysql.com/downloads/mysql/

http://blog.sina.com.cn/s/blog_4b50392101017wln.html

Centos6.5的MySQL5.7.15二进制源码单机版安装的更多相关文章

  1. linux安装MySQL5.7.13(二进制|源码)

    二进制和源码版本安装MySQL5.7.13,并简单介绍不同之处. 一.通用二进制部分 1.下载MySQL通用二进制软件包.[root@node1 ~]# wget http://120.52.72.2 ...

  2. MySQL5.7 二进制源码包安装

    一般平时安装MySQL都是源码包安装的,但是由于它的编译需要很长的时间,所以建议安装二进制免编译包.可以到MySQL官方网站去下载,也可以到comsenz官方网站下载,还有各大镜像站下载. 下载安装包 ...

  3. 烂泥:mysql5.5数据库cmake源码编译安装

    本文由秀依林枫提供友情赞助,首发于烂泥行天下. 以前也写过一篇有关mysql5.0源码编译的文章,该文章为<烂泥:mysql5.0数据库源码编译安装>.但是MySQL自5.5版本以后,就开 ...

  4. Mysql5.7.34 数据库源码编译安装

    Mysql 数据库源码编译安装 MySQL是一个关系型数据库管理系统,关系型数据库是将数据保存在不同的表中,而非将所有数据放在一个大仓库内,这样就加快了速度并提高了灵活性.由于其体积小.速度快.总体拥 ...

  5. centos6.5环境源码编译安装mysql5.6.34

    centos6.5环境源码编译安装mysql5.6.34 源码下载地址http://dev.mysql.com/downloads/mysql/5.6.html#downloads 选择Generic ...

  6. mysql5.7.10 源码编译安装记录 (centos6.4)【转】

    一.准备工作 1.1 卸载系统自带mysql 查看系统是否自带MySQL, 如果有就卸载了, 卸载方式有两种yum, rpm, 这里通过yum卸载 rpm -qa | grep mysql //查看系 ...

  7. 源码编译安装MySQL-5.6/mysql-5.6.39------踩了无数坑,重装了十几次服务器才会的,不容易啊!

    1.切换到src目录 cd /usr/local/src/ 2. 下载mysql免编译二进制包 免编译的mysql二进制包5.6源码包: wget http://mirrors.163.com/mys ...

  8. 2-14 MySQL初步认识,及CentOS6.8环境,源码方式安装MySQL

    什么是数据库: 存放数据的仓库RDBMS-->(Relational Database Management System) 关系型数据库管理系统DBMS--->(Database Man ...

  9. Centos6 系统下源码方式安装Mysql 记录

    在运维工作中经常部署各种运维环境,涉及mysql数据库的安装也是时常需要的.mysql数据库安装可以选择yum在线安装,但是这种安装的mysql一般是系统自带的,版本方面可能跟需求不太匹配. #### ...

随机推荐

  1. vue 中使用 async/await 将 axios 异步请求同步化处理

    1. axios 常规用法: export default { name: 'Historys', data() { return { totalData: 0, tableData: [] } }, ...

  2. 闭包----你所不知道的JavaScript系列(4)

    一.闭包是什么? · 闭包就是可以使得函数外部的对象能够获取函数内部的信息. · 闭包是一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分. · 闭包就 ...

  3. WordPress更新时提示无法连接到FTP服务器的解决方案

    这几天在搭建主站的时候,更新wordpress时无法连接到FTP原因服务器 解决方法如下: 在WordPress目录下找到wp-config.php文件并编辑,在最后一行加上: define('FS_ ...

  4. 分布式监控系统Zabbix-3.0.3-新版微信报警(企业微信取代企业号)

    一般来说,Zabbix可以通过多种方式把告警信息发送到指定人,常用的有邮件,短信报警方式,但是现在越来越多的企业开始使用zabbix结合微信作为主要的告警方式,这样可以及时有效的把告警信息推送到接收人 ...

  5. PAT甲级题解-1066. Root of AVL Tree (25)-AVL树模板题

    博主欢迎转载,但请给出本文链接,我尊重你,你尊重我,谢谢~http://www.cnblogs.com/chenxiwenruo/p/6803291.html特别不喜欢那些随便转载别人的原创文章又不给 ...

  6. 基于SSH框架开发的《高校大学生选课系统》的质量属性的实现

    基于SSH框架开发的<高校大学生选课系统>的质量属性的实现 对于可用性采取的是错误预防战术,即阻止错误演变为故障:在本系统主要体现在以下两个方面:(1)对于学生登录模块,由于初次登陆,学生 ...

  7. 基于UML的需求分析和系统设计

    小序: 从学生时代就接触到UML,几年的工作中也没少使用,各种图形的概念.图形的元素和属性,以及图形的画法都不能说不熟悉.但是怎样在实际中有效地使用UML使之发挥应有的作用,怎样捕捉用户心中的需求并转 ...

  8. Leetcode——58.最后一个单词的长度

    给定一个仅包含大小写字母和空格 ' ' 的字符串,返回其最后一个单词的长度. 如果不存在最后一个单词,请返回 0 . 说明:一个单词是指由字母组成,但不包含任何空格的字符串. 示例: 输入: &quo ...

  9. navicat有数据额结构同步

    这个功能可能检查两个库的表结构异同,进行表结构构同步,可以生成同步语句. 比如在测试环境表中新增了字段,可以通过这个工具进行表结构同步.

  10. ASP.NET Forms验证

    /// <summary> /// 执行用户登录操作 /// </summary> /// <param name="config">授权配置信 ...