linux中安装mysql5.7

[root@localhost mysql]# scripts/mysql_install_db --user=mysql
-bash: scripts/mysql_install_db: 没有那个文件或目录

可能是哪些问题呢,怎么解决?
1.q:首先看你安装的版本是什么?
a:是5.5的还是5.7的版本,如果是5.7的这个初始化命令是不对的。

 mysql5.7之前版本初始化配置表命令:
 script/mysql_install_db --user=mysql --basedir=/app/test/mysql --datadir=/app/test/mysql/data/
 --user  启动mysql的用户
 --basedir  mysql安装目录
 --datadir  mysql数据仓库目录

2.q:安装在哪里?
a:不是在源码编译包目录里面,是在编译安装后的目录。
在这里插入图片描述
在这里插入图片描述

3.安装命令:
mysql5.7 是二进制包安装:

执行报错:
[root@localhost mysql]# /app/mysql/bin/mysql_install_db --user=mysql \
basedir=/app/mysql/mysql \
datadir=/app/mysql/mysql/data

而mysql5.7的mysql_install_db命令是在bin目录下 的并且建议 用 mysqld --initialize命令

执行成功:
/app/mysql/bin/mysqld --initialize --user=mysql --basedir=/app/mysql/mysql --datadir=/app/mysql/mysql/data

在这里插入图片描述
注意最后一行,这也是和之有版本不同的地方,它给了root一个初始密码,后面要登录的时候要用到这个密码。(Kh=9ahu-th(*)

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

[root@localhost mysql]# chown -R root .
[root@localhost mysql]# chown -R mysql mysql/data

③复制配置文件

[root@localhost mysql]# cp support-files/my-default.cnf /etc/my.cnf
cp:是否覆盖"/etc/my.cnf"? y
y

④mysql5.7配置文件需要修改my.cnf关键配置, mysql5.7之前默认配置文件中是有配置项的,不用手动修改

[mysqld]
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES 

# 一般配置选项
basedir = /app/mysql/mysql
datadir = /app/mysql/mysql/data
port = 3306
socket = /var/run/mysqld/mysqld.sock
character-set-server=utf8
#网上的是:
# socket = /Ultrapower/test/mysql/tmp/mysql.sock  

注意,tmp目录不存在,请创建之。否则会出错 创建后要赋予mysql权限执行:

# chown -R mysql:mysql mysql/tmp 

如果mysql.sock指定到/tmp以外的目录,需要在my.cnf中添加[client]并且指定socket位置,
否则登录mysql时会报错:ERROR 2002 (HY000): Can’t connect to local MySQL server through socket ‘/tmp/mysql.sock’ (2)
应该是,默认会找tmp目录下的sock文件

  1. 将mysqld服务加入开机自启动项。

将{mysql}/ support-files/mysql.server 拷贝为/etc/init.d/mysql并设置运行权限,这样就可以使用service mysql命令启动/停止服务,

否则就只能使用{mysql}/bin/mysqld_safe &命令来启动服务

还需要把mysql.server中basedir的相关路径,改为自定义的路径,默认路径是/usr/local/mysql

[root@localhost mysql]# cp support-files/mysql.server /etc/init.d/mysql
[root@localhost mysql]# chmod +x /etc/init.d/mysql  

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

[root@localhost mysql]# chkconfig --add mysql  

查看是否添加成功

[root@localhost mysql]# chkconfig --list mysql  
注:该输出结果只显示 SysV 服务,并不包含
原生 systemd 服务。SysV 配置数据
可能被原生 systemd 配置覆盖。 
      要列出 systemd 服务,请执行 'systemctl list-unit-files'。
      查看在具体 target 启用的服务请执行
      'systemctl list-dependencies [target]'。
mysql          	0:关	1:关	2:开	3:开	4:开	5:开	6:关

5.mysql服务的开启和关闭

/etc/init.d/mysql start   或者   serivce mysql start  或者  /app/mysql/bin/mysqld_safe&  
#/etc/init.d/mysql stop    或者   service mysql stop   或者  bin/mysqladmin -uroot -p  

注:在bin/mysqld_safe&这个启动脚本里已默认设置–user=mysql;在脚本末尾加&表示设置此进程为后台进程,区别就是在控制台输入bg,即可将当前进 程转入后台, 当前shell 可进行其他操作。
bin/mysqladmin -uroot -p (注意此时的root是指mysql的root用户)

需要把mysqll加入到环境变量中,或者为mysql建立软链接
否则运行mysql命令会出现 -bash: mysql:command not found
不加环境变量,就要使用bin/mysql -uroot -p 或者bin/mysqladmin -uroot -p 命令来登录mysql服务

建立软链接:

ln -s /app/mysql/mysql/bin/mysql  /usr/local/bin
ln -s /app/mysql/mysql/bin/mysqladmin  /usr/local/bin
ln -s /app/mysql/mysql/bin/mysqld_safe  /usr/local/bin

6.加入环境变量
修改/etc/profile文件使其永久性生效,并对所有系统用户生效,在文件末尾加上如下两行代码
PATH=$PATH:/app/mysql/mysql:/app/mysql/mysql/bin
export PATH
最后:执行 命令source /etc/profile或 执行点命令 ./profile使其修改生效,执行完可通过echo $PATH命令查看是否添加成功。

[root@localhost etc]# echo 'PATH=$PATH:/app/mysql/mysql:/app/mysql/mysql/bin'>>/etc/profile
[root@localhost etc]# source ./profile
[root@localhost etc]# cat ./profile

7.登录mysql服务
执行:mysql -uroot -p生成的密码

此时报错
找不到 mysql 命令

连上后,在做任何操作前,mysql要求要改掉root的密码后才能进行操作。
ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing this statement.
需要执行:alter user ‘root’@‘localhost’ identified by ‘xxxxxxx’;

猜你喜欢

转载自blog.csdn.net/pojpoj/article/details/85039518