linux安装mysql5.7.20并登录

最近在我的阿里云服务器上配置目前最新版的mysql5.7.20,期间出现各种奇葩问题,针对自己的各种问题也是网上各种扒资料,各个击破,最后终于大功告成。

趁热打铁,以下将自己的安装登录过程以及遇到的问题尽力按照流程详细还原!

1.准备工作(由于个人有强迫症并且力求完美,所以文件的存放位置,也尽量按照linux标准,我是linux小小白~)

(说明:此次下载源码存放位置都在:/usr/local/src  解压后的代码存放在:/usr/local下的mysql中,当然需要在/usr/local中使用mkdir mysql 创建mysql文件夹)

mysql5.7.20的下载:

https://dev.mysql.com/downloads/mysql/

linux安装mysql5.7.20并登录_第1张图片

如图选择 linux的通用版本,我的是64位系统(注意:我这个下载的不是源码版本,而是二进制版本,不需要编译,之前想要使用源码版本,由于编译时间久且总是出现我解决不了的问题,故而没有深究直接放弃了),所以我选择64为版本,下载第一个,点击第一个后面的“download”跳转到页面https://dev.mysql.com/downloads/file/?id=473559看到:linux安装mysql5.7.20并登录_第2张图片

这里你可以选择登录也可以选择不登录。点击下面的红框可以直接下载。因为我这里是远程登录阿里云服务器,所以右键->复制链,然后到我的阿里云服务器中使用wget下载,将mysql5.7的二进制源码下载到/usr/local/src中。以下是下载步骤:

(1)进入/usr/local/src文件夹      cd /usr/local/src

(2)下载mysql: wget https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.20-linux-glibc2.12-x86_64.tar.gz

(3)解压下载的问价: 

 tar -zxvf mysql-5.7.20-linux-glibc2.12-x86_64.tar.gz

(4)将加压后的文件内容移动到 /usr/local/mysql中,没有此文件夹就使用mkdir /usr/local/mysql创建

mv mysql-5.7.20-linux-glibc2.12-x86_64/* mysql

(5)创建用户和用户组并赋予权限(这一步我也不是特别明白为什么这么做,还需要多多学习linux,多多去研究,不放过任何知识)

[root@dbserver ~]# groupadd mysql  #创建用户组mysql

[root@dbserver ~]# useradd -r -g mysql mysql //useradd -r参数表示mysql用户是系统用户,不可用于登录系统,创建用户mysql并将其添加到用户组mysql中

[root@dbserver local]# chown -R mysql mysql/

[root@dbserver local]# chgrp -R mysql mysql/


2.开始安装并配置my.cnf

(6)安装和初始化数据库

⚠️初始化数据库:在5.7.6之前初始化的方法是:bin/mysql_install_db

5.7.6之后的版本初始化数据库不再使用mysql_install_db,而是使用: bin/mysqld --initialize

mysql5.7初始化数据库后会默认生成一个初始的登录密码,第一次登录要使用初始密码,初始密码的获取下面会讲到

安装和初始化数据库有两种方式,建议使用a,个人使用的是b

a.初始化数据库后配置

<1>初始化数据库:

[root@dbserver mysql]# bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --lc_messages_dir=/usr/local/mysql/share --lc_messages=en_US

<2>获取初始登录密码:

执行上一步操作后会在命令行输出 root@localhost: gFamcspKm2+u localhost: 后面的这一串便是你首次登陆mysql需要的初始密码

<3>配置my.cnf

接下来进入/usr/local/mysql/support-files/目录下 
查看是否存在my-default.cnf文件,如果存在直接copy到/etc/my.cnf文件中

    [root@dbserver mysql]# cp -a ./support-files/my-default.cnf /etc/my.cnf
  • 1

如果不存在my-default.cnf文件,则在/etc/目录下创建my.cnf,并写入以下内容,例如我的是这样的:

[mysqld]

character_set_server=utf8

init_connect='SET NAMES utf8'

basedir=/usr/local/mysql

datadir=/usr/local/mysql/data

socket=/tmp/mysql.sock

log-error=/var/log/mysqld.log

pid-file=/var/run/mysqld/mysqld.pid

b.配置后初始化数据库

<1>同a中的<3>

<2>同a中的<1>

<3>获取初始登录密码

这个的初始登录密码将不会在执行第二步之后被输出到命令行中,而是会被存放在错误日志中。错误日志路径就是你在my.cnf中配置的 log-error=/var/log/mysqld.log

执行:

cat /var/log/mysqld.log

能够看到一行信息,例如我的是:

2017-11-29T01:55:23.192210Z 1 [Note] A temporary password is generated for root@localhost: Q5Sck93kdK/*

localhost: 后面的一串就是你mysql登录的初始密码。

⚠️如果你的初始密码丢失,可以备份data数据:mv /usr/local/mysql/data data.bak 或者直接删除data数据:rm -rf /usr/local/mysql/data 然后初始化数据库:

[root@dbserver mysql]# bin/mysqld --initialize --user=mysql 重新生成初始密码然后查看并记住。此处还有其他的方法,大家可以尝试一下,参考:http://blog.csdn.net/ljbmxsm/article/details/50612777


3.启动服务

[root@dbserver mysql]# cd bin/

[root@dbserver bin]# ./mysqld_safe --user=mysql &


4.设置开机启动

进入 /usr/local/mysql文件夹

[root@dbserver support-files]# cp mysql.server /etc/init.d/mysql //设置开机启动


5.使用service mysqld命令启动/停止服务

例如我的mysql:启动/停止/暂停:

service mysqld start/stop/restart

执行命令出现OK时说明成功,如果有其他提示,可以在看看出现了什么问题


6.登录mysql

[root@dbserver bin]# ./mysql -u root -p //密码是第2步产生的初始密码


7.设置密码

mysql>  set password=password("new password");
Query OK, 0 rows affected, 1 warning (0.00 sec)
mysql> flush privileges;
 8.退出当前的mysql服务,并重启,再用新的密码登录mysql,成功! 
  


你可能感兴趣的:(技术,mysql)