MYSQLLINUX安装MYSQL

Posted lucas1024

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MYSQLLINUX安装MYSQL相关的知识,希望对你有一定的参考价值。

安装环境:系统是 Red Hat Enterprise Linux Server release 6.6

安装软件:mysql-5.6.33-linux-glibc2.5-x86_64.tar.gz

1、下载

    下载地址:http://dev.mysql.com/downloads/mysql/5.6.html#downloads

    下载版本:我这里选择的5.6.33,通用版,linux下64位

    也可以直接复制64位的下载地址,通过命令下载:wget http://dev.mysql.com/get/Downloads/MySQL-5.6/mysql-5.6.33-linux-glibc2.5-x86_64.tar.gz

2、解压

1

2

3

4

#解压

tar -zxvf mysql-5.6.33-linux-glibc2.5-x86_64.tar.gz

#复制解压后的mysql目录

cp -r mysql-5.6.33-linux-glibc2.5-x86_64/* /usr/local/mysql

 

#或者 解压后 更改为mysql目录名称 再复制或移动到/usr/local/

mv mysql-5.6.33-linux-glibc2.5-x86_64 mysql

cp  -r mysql /usr/local

3、添加用户组和用户

1

2

3

4

#添加用户组

groupadd mysql

#添加用户mysql 到用户组mysql

useradd -r -g mysql mysql

 

# * useradd -r参数表示mysql用户是系统用户,不可用于登录系统。

 

# * useradd -g参数表示把mysql用户添加到mysql用户组中。

4、安装

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

cd /usr/local/mysql/

mkdir ./data/mysql              (注意;数据库仓库存放位置指定需自定义,有的话可以忽略)

chown -R mysql:mysql ./      

# 执行mysql_install_db脚本,对mysql中的data目录进行初始化并创建一些系统表格。

./scripts/mysql_install_db --user=mysql --datadir=/usr/local/mysql/data/mysql

#############此为5.7版本前后安装说明信息,这里用5.6所以不需考虑 开始 ###

mysql5.7执行mysql_install_db脚本,对mysql中的data目录进行初始化并创建一些系统表格。

 

 bin/mysql_install_db --user=mysql

 

 报错:

 

 2016-07-15 14:50:14 [WARNING] mysql_install_db is deprecated. Please consider switching to mysqld --initialize

 2016-07-15 14:50:14 [ERROR]   The data directory needs to be specified.

 

 需要指定data目录,注意mysql服务进程mysqld运行时会访问data目录,所以必须由启动mysqld进程的用户(就是我们之前设置的mysql用户)执行这个脚本,  或者用root  执行,但是加上参数--user=mysql。

 

 上文还有警告信息,说mysql_install_db 命令已经是弃用的,建议切换到mysqld --initialize命令

 

 注:

 

 mysql5.7和之前版本不同,很多资料上都是这个命令:../scripts/mysql_install_db --user=mysql,而mysql5.7的mysql_install_db命令是在bin目录下  的并且建议  用 mysqld --initialize命令

 

 mysql5.7之前版本初始化配置表命令:

 

 script/mysql_install_db --user=mysql --basedir=/Ultrapower/test/mysql --datadir=/Ultrapower/test/mysql/data/

 

 # --user  启动mysql的用户

 

 # --basedir  mysql安装目录

 

 # --datadir  mysql数据仓库目录

#############此为5.7版本前后安装说明信息,这里用5.6所以不需考虑结束 ###

 

# 将mysql/目录下除了data/目录的所有文件,改回root用户所有,mysql用户只需作为mysql/data/目录下所有文件的所有者。

chown -R root . 

chown -R mysql data 

 

# 复制配置文件 (如果/etc/my.cnf已存在则不需操作)

cp support-files/my-default.cnf /etc/my.cnf

检查配置(正常如下截图,basedir和datadir配置正确,socket不要指定在/tmp/路径,否则需要配置tmp权限,log-error自定义,pid-file如下)

 

# 将/support-files/mysql.server 拷贝并重命名为/etc/init.d/mysql并设置运行权限,这样就可以使用service mysql命令启动/停止服务,否则就只能使用{mysql}/bin/mysqld_safe &命令来启动服务

cp support-files/mysql.server /etc/init.d/mysql

# 设置运行权限

chmod +x /etc/init.d/mysql

 

#检查修改启动脚本

vi /etc/init.d/mysql

 

#修改项:

basedir=/usr/local/mysql/

datadir=/usr/local/mysql/data/mysql

 

 

#把mysql注册为开机启动的服务

chkconfig --add mysql

chkconfig --list mysql 

 

#加入环境变量,编辑 /etc/profile,这样可以在任何地方用mysql命令了

export PATH=$PATH:/usr/local/mysql/bin

source /etc/profile

 

 

#启动服务或如下图命令

service mysqld start

 

 

#测试连接

./mysql/bin/mysql -uroot

 

#启动mysql

service mysqld start

#关闭mysql

service mysqld stop

#查看运行状态

service mysqld status

5、错误

  5.1 sqlyog远程连接时,报1130错误,是由于没有给远程连接的用户权限问题(推荐2)

    解决1:更改 ‘mysql’数据库‘user’表‘host’项,从‘localhost’改成‘%’。

use mysql;

select ‘host‘ from user where user=‘root‘;

update user set host = ‘%‘ where user =‘root‘;

flush privileges;

    解决2:直接授权

GRANT ALL PRIVILEGES ON *.* TO ‘root‘@‘%‘ IDENTIFIED BY PASSWORD ‘*81F5E21E35407D884A6CD4A731AEBFB6AF209E1B‘ WITH GRANT OPTION;

  5.2 初始化时的一些提示

    ./scripts/mysql_install_db ……
    说明: 初始化完成末尾会有一些配置文件提示或产生root用户初始密码,请阅读。

5.3 客户端远程连接mysql错误2003 cant connect to mysql 10060/10061解决方法

    
    方法:1. 确保mysql服务已经启动:service mysql status

                       2. 在装有sqlyog的端尝试在命令行中ping目标ip,确保能ping通

                       3. 在需要连接的服务器端查看mysql用户名和权限,确保sqlyog输入的用户名和密码正确

                       4. 在需要连接的服务器端登陆mysql后查看用户权限:show grants;

                       5. 记得关闭防火墙

                       6. 打开/etc/my.cnf 文件,bind-address = ******** 一句前边加上 # ,注释掉

7. 重启mysql服务

 

6、其他

  6.1 配置环境变量

    vi   /etc/profile

              增加如下:

    MYSQL =/usr/local/mysql/bin

       export MYSQL

7、报错(可参考)

mysql安装过程遇到的错误:

 

启动Mysql

 

bin/mysqld_safe --user=mysql & 

 

[[email protected] mysql]# bin/mysqld_safe &

[1] 13863

[[email protected] mysql]# bin/mysqld_safe: line 541: /Ultrapowewr/test/mysql/data/mysqld_safe.pid: 没有那个文件或目录

awk: (FILENAME=- FNR=1) warning: error writing standard output (断开的管道)

2016-07-15T07:57:05.782967Z mysqld_safe Logging to ‘/Ultrapowewr/test/mysql/data/rhel5-32.err‘.

touch: 无法触碰 “/Ultrapowewr/test/mysql/data/rhel5-32.err”: 没有那个文件或目录

chmod: 无法访问 “/Ultrapowewr/test/mysql/data/rhel5-32.err”: 没有那个文件或目录

touch: 无法触碰 “/Ultrapowewr/test/mysql/data/rhel5-32.err”: 没有那个文件或目录

chown: 无法访问 “/Ultrapowewr/test/mysql/data/rhel5-32.err”: 没有那个文件或目录

2016-07-15T07:57:05.877234Z mysqld_safe Starting mysqld daemon with databases from /Ultrapowewr/test/mysql/data

bin/mysqld_safe: line 135: /Ultrapowewr/test/mysql/data/rhel5-32.err: 没有那个文件或目录

bin/mysqld_safe: line 169: /Ultrapowewr/test/mysql/data/rhel5-32.err: 没有那个文件或目录

touch: 无法触碰 “/Ultrapowewr/test/mysql/data/rhel5-32.err”: 没有那个文件或目录

chown: 无法访问 “/Ultrapowewr/test/mysql/data/rhel5-32.err”: 没有那个文件或目录

chmod: 无法访问 “/Ultrapowewr/test/mysql/data/rhel5-32.err”: 没有那个文件或目录

2016-07-15T07:57:05.923131Z mysqld_safe mysqld from pid file /Ultrapowewr/test/mysql/data/rhel5-32.pid ended

bin/mysqld_safe: line 135: /Ultrapowewr/test/mysql/data/rhel5-32.err: 没有那个文件或目录

 

 

[[email protected] mysql]# service mysql restart

MySQL server PID file could not be found!                  [失败]

/etc/init.d/mysql: line 276: cd: /Ultrapowewr/test/mysql: 没有那个文件或目录

Starting MySQLCouldn‘t find MySQL server (/Ultrapowewr/test[失败]/bin/mysqld_safe)

 

这错误是因为,在/etc/my.cnf中配置basedir路径出错导致的

*************************************************************************************************************************************************

 

执行 mysql -uroot -p

 

出错:ERROR 2002 (HY000): Can‘t connect to local MySQL server through socket ‘/tmp/mysql.sock‘ (111)

 

 

查看 less data/rhel5-32.err

 

发现日志输出:

 

2016-07-15T08:13:31.786920Z 0 [Note] /Ultrapower/test/mysql/bin/mysqld: ready for connections.

Version: ‘5.7.13‘  socket: ‘/temp/mysql.sock‘  port: 3306  MySQL Community Server (GPL)

 

 

查看/etc/my.cnf中,socket配置:

 

# These are commonly set, remove the # and set as required.

basedir = /Ultrapower/test/mysql

datadir = /Ultrapower/test/mysql/data

port = 3306

# server_id = .....

socket = /tmp/mysql.sock

 

 

socket文件目录为/temp/mysql.sock和错误提示不一样,

 

#由上可知my.cnf中定义的为/tmp目录下,而错误提示为/temp/mysql.sock/目录下

#也就是说mysqld已经声称了正确的sock文件,但客户端连接还是从初始目录去找sock文件

 

应该是因为,没有temp目录,mysql不会自动创建,找不到所致

 

*************************************************************************************************************************************************

 

错误:The server quit without updating PID file [失败]local/mysql/data/rhel5-32.pi

 

启动mysql服务时报如上错误,查看mysql日志发现

 

[plain] view plain copy

 

    2016-07-26T02:07:28.134232Z 0 [Note] InnoDB: Highest supported file format is Barracuda. 

    2016-07-26T02:07:28.172866Z 0 [Note] InnoDB: Creating shared tablespace for temporary tables 

    2016-07-26T02:07:28.172990Z 0 [Note] InnoDB: Setting file ‘./ibtmp1‘ size to 12 MB. Physically writing the file full; Please wait ... 

    2016-07-26T02:07:28.244892Z 0 [Note] InnoDB: File ‘./ibtmp1‘ size is now 12 MB. 

    2016-07-26T02:07:28.252257Z 0 [Note] InnoDB: 96 redo rollback segment(s) found. 96 redo rollback segment(s) are active. 

    2016-07-26T02:07:28.252344Z 0 [Note] InnoDB: 32 non-redo rollback segment(s) are active. 

    2016-07-26T02:07:28.253779Z 0 [Note] InnoDB: Waiting for purge to start 

    2016-07-26T02:07:28.305124Z 0 [Note] InnoDB: 5.7.13 started; log sequence number 2523957 

    2016-07-26T02:07:28.306232Z 0 [Note] InnoDB: Loading buffer pool(s) from /usr/local/mysql/data/ib_buffer_pool 

    2016-07-26T02:07:28.307231Z 0 [Note] Plugin ‘FEDERATED‘ is disabled. 

    2016-07-26T02:07:28.315654Z 0 [Warning] Failed to set up SSL because of the following SSL library error: SSL context is not usable without certificate and private key 

    2016-07-26T02:07:28.315736Z 0 [Note] Server hostname (bind-address): ‘*‘; port: 3306 

    2016-07-26T02:07:28.315825Z 0 [Note] IPv6 is available. 

    2016-07-26T02:07:28.315860Z 0 [Note]   - ‘::‘ resolves to ‘::‘; 

    2016-07-26T02:07:28.316013Z 0 [Note] Server socket created on IP: ‘::‘. 

    2016-07-26T02:07:28.316099Z 0 [ERROR] Could not create unix socket lock file /usr/local/mysql/tmp/mysql.sock.lock. 

    2016-07-26T02:07:28.316115Z 0 [ERROR] Unable to setup unix socket lock file. 

    2016-07-26T02:07:28.316128Z 0 [ERROR] Aborting 

 

 

不能创建mysql.sock.lock文件,可能是tmp目录权限不足或者目录不存在的问题

 

执行 chown -R mysql:mysql tmp,然后启动mysql服务,启动成功

 

*************************************************************************************************************************************************

 

登录mysql,mysql -uroot -pi7YCy.:jv6yr

 

如出现ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: NO),是因为不允许密码为空

 

如出现ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES),可能密码错误,

终极办法停止mysql服务,删除data目录,重新初始化表数据,受权data目录给Mysql用户,用重新生成的临时密码登录。

 

重置密码解决MySQL for Linux错误 ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)

 

一般这个错误是由密码错误引起,解决的办法自然就是重置密码。

 

假设我们使用的是root账户。

 

1.重置密码的第一步就是跳过MySQL的密码认证过程,方法如下:

 

#vim /etc/my.cnf(注:windows下修改的是my.ini)

 

在文档内搜索mysqld定位到[mysqld]文本段:

/mysqld(在vim编辑状态下直接输入该命令可搜索文本内容)

 

在[mysqld]后面任意一行添加“skip-grant-tables”用来跳过密码验证的过程,如下图所示:

 

保存文档并退出:

 

#:wq

2.接下来我们需要重启MySQL:

 

/etc/init.d/mysql restart(有些用户可能需要使用/etc/init.d/mysqld restart或者 service mysql restart)

 

3.重启之后输入./bin/mysql即可进入mysql。

cd /usr/local/mysql

./bin/mysql

4.接下来就是用sql来修改root的密码

mysql> use mysql;

mysql> update user set password=password("你的新密码") where user="root";

mysql> flush privileges;

mysql> quit

 

到这里root账户就已经重置成新的密码了。

 

5.编辑my.cnf,去掉刚才添加的内容,然后重启MySQL。大功告成!

service mysql restart

 网上有很多关于这个问题的解决说明,很多刚接触的朋友可能比较迷惑的是在自己的平台上找不到my.cnf或者my.ini文件,如果你是Linux,使用如下方式可以搜索到:whereis my

 

至于windows平台,去安装目录下找一下my.ini吧。



以上是关于MYSQLLINUX安装MYSQL的主要内容,如果未能解决你的问题,请参考以下文章

MysqlLinux环境安装Mysql

大牛深入讲解!mysqllinux安装教程

MySQLLinux下MySQL 5.55.6和5.7的RPM二进制和源码安装

MySQLLinux MySQL学习记录

mysqllinux, mac mysql数据库root 密码忘记修改

MySQLLinux创建MySQL的角色信息