Linux下安装mysql的教程详解

 更新时间:2018年11月26日 11:00:04   作者:GnodiYnehS  
这篇文章主要介绍了Linux下安装mysql的教程详解,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下

1. 关闭mysql服务

# service mysqld stop

2. 检查是否有rpm包,如果没有用rpm安装过mysql,不应该有残留,如果有,需要删掉

检查语法: rpm -qa|grep -i mysql

删除语法: rpm -e <包的名字>

如果遇到依赖,无法删除,使用 rpm -e --nodeps <包的名字> 不检查依赖,直接删除rpm包。

3. 通过find命令检查是否有安装mysql文件,有需要删除

检查语法: find / -name mysql

删除语法: rm -rf 目录文件(或文件)

******(2)创建mysql分组和用户******

1. 暴力删除mysql用户

删除语法: userdel -r -f mysql(如果没有,会提示你mysql不存在,不用在意)

2. 添加分组

添加语法: groupadd mysql

 3. 添加mysql用户

添加语法: useradd -g mysql mysql

******(3)解压tar包******

1. cd到mysql-5.7.12-linux-glibc2.5-x86_64.tar.gz目录

2. 解压tar包

解压语法:tar zxvf mysql-5.7.12-linux-glibc2.5-x86_64.tar.gz

解压后多出一个mysql-5.7.12-linux-glibc2.5-x86_64的文件,

将这个文件复制到自己喜欢的目录,重命名为mysql,复制的时候请耐心等待,

复制完后,cd到mysql目录,新建一个data的文件夹。

复制语法: cp -r mysql-5.7.12-linux-glibc2.5-x86_64  /usr/local/mysql

新建文件语法: mkdir data

 chmod 770 data

在/usr/local/mysql里新建一个data文件夹,并修改权限为770(drwxrwx---.):

[wangh@HavGO mysql]$ sudo mkdir data
 [wangh@HavGO mysql]$ sudo chmod 770 data 

将/usr/local/mysql的用户设为mysql,用户组设为mysql:

[wangh@HavGO ~]$ cd /usr/local/
 [wangh@HavGO local]$ sudo chown -R mysql:mysql mysql 

   进入/usr/local/mysql文件夹并执行该命令:

[wangh@HavGO mysql]$ sudo bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data

该命令的意思是初始化 并制定user、mysql目录和data目录(第三步创建的data)

 执行完成后得到一个mysql初始密码,我们需要先保存起来,后期第一次登录mysql时使用

2018-06-30T07:40:21.663544Z 1 [Note] A temporary password is generated for root@localhost: 0hl..Ult.usK

A temporary password is generated for root@localhost: 0hl..Ult.usK
                                                                                                             0hl..Ult.usK

   上述完毕后,执行该命令:

[wangh@HavGO mysql]$ sudo bin/mysql_ssl_rsa_setup --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data

该命令设置SSL安全连接mysql(RSA加密),指定mysql目录和data目录

   在/var/log/里新建一个mysql日志文件夹用于存放mysql运行日志:

[wangh@HavGO mysql]$ cd /var/log
 [wangh@HavGO log]$ sudo mkdir mysql

   在/usr/local/mysql文件夹中执行以下命令:

[wangh@HavGO mysql]$ sudo bin/mysqld_safe --user=mysql --basedir=/usr/local/mysql/ --datadir=/usr/local/mysql/data &

再次按一次Enter键让此命令后台运行

mysqld_safe脚本功能自行百度 

   将mysql加入/etc/init.d启动引导:

[wangh@HavGO mysql]$ sudo cp support-files/mysql.server /etc/init.d/mysql

   配置/etc/my.cnf(my.cnf是mysql的配置文件)

[wangh@HavGO mysql]$ vim /etc/my.cnf

修改配置,如下图:

[mysqld]
 # 设置mysql的安装目录
basedir=/usr/local/mysql
 # 设置mysql数据库的数据的存放目录
datadir=/usr/local/mysql/data
 # 服务端使用的字符集默认为8比特编码的latin1字符集
character-set-server=utf8
 socket=/tmp/mysql.sock
 #socket=/var/lib/mysql/mysql.sock
 user=mysql
 [mysql-safe]
 log-error=/var/log/mysql/mysqld.log
 pid-file=/var/run/mysqld/mysqld.pid

其他设置可配可不配

# 设置mysql客户端默认字符集
default-character-set=utf8
 socket=/var/lib/mysql/mysql.sock
 [mysqld]
 skip-name-resolve
 #设置3306端口
port = 3306
 # 允许最大连接数
max_connections=200
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
 lower_case_table_names=1
 max_allowed_packet=16M
#忘记密码时可取消注释,无密码登陆
#skip-grant-tables

   配置环境变量

[wangh@HavGO mysql]$ vim /etc/profile

添加以下内容:

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

添加完成,保存退出后,让环境变量立即生效:

[wangh@HavGO mysql]$ source /etc/profile 

   现在mysql已经安装完毕,启动mysql服务:

[wangh@HavGO etc]$ sudo service mysql start

显示启动成功。

 如果在第2步骤中,mysql文件夹不是以“mysql命名”,mysqld_safe会报错,显示“mysqld_safe The file /usr/local/mysql/bin/mysqld 

 does not exist or is not executable.”

因为mysqld_safe脚本默认mysql路径为/usr/local/mysql,此时有两种解决办法,将mysqld_safe中的所有/usr/local/mysql目录改为自己实际的安装目录

 或者将自己实际安装目录创建链接至/usr/local/mysql

 mkdir /var/lib/mysql
 mysql_install_db --user=mysql --ldata=/var/lib/mysql/

   mysql服务启动后,键入命令进入mysql,密码为之前获取的初始密码;

[wangh@HavGO etc]$ mysql -u root -p

输入初始密码,回车

 设置新密码为:jkl12345784  

  再次用新密码登陆,就可以使用mysql了。

    登录后立即修改root密码:

mysql> alter user 'root'@'localhost' identified by 'admin';
 Query OK, 0 rows affected (0.00 sec)

其中your_password是你设置的新密码。新密码应是强密码,要求密码包含大小写字母、数字及标点符号,长度应该在6位以上。

grant all privileges on *.* to 'root'@'%'identified by 'admin' with grant option;
 flush privileges
 ps aux |grep httpd

总结

以上所述是小编给大家介绍的Linux下安装mysql的教程详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

相关文章

  • MySQL数据库修复方法(MyISAM/InnoDB)

    MySQL数据库修复方法(MyISAM/InnoDB)

    这篇文章主要为大家整理了7条修复MySQL数据库的方法,当简单的重启对数据库不起作用,或者有表崩溃时,需要的朋友可以参考下
    2014-06-06
  • PowerDesigner连接MySQL数据库的详细步骤

    PowerDesigner连接MySQL数据库的详细步骤

    这篇文章主要介绍PowerDesigner连接MySQL数据库的详细步骤,文章通过图文介绍的非常详细,对大家学习PowerDesigner连接MySQL数据库有一定的帮助,需要的朋友可以参考下
    2023-09-09
  • mysql LOAD语句批量录入数据

    mysql LOAD语句批量录入数据

    本章的前面讨论如何使用SQL向一个表中插入数据。但是,如果你需要向一个表中添加许多条记录,使用SQL语句输入数据是很不方便的。
    2010-03-03
  • mysql 循环批量插入的实例代码详解

    mysql 循环批量插入的实例代码详解

    本文通过实例代码文字相结合的形式给大家介绍了mysql 循环批量插入功能,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-05-05
  • Mysql之如何根据.frm和.idb文件恢复表结构

    Mysql之如何根据.frm和.idb文件恢复表结构

    这篇文章主要介绍了Mysql之如何根据.frm和.idb文件恢复表结构问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-03-03
  • 使用prometheus统计MySQL自增主键的剩余可用百分比

    使用prometheus统计MySQL自增主键的剩余可用百分比

    这篇文章主要介绍了使用prometheus统计MySQL自增主键的剩余可用百分比,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-04-04
  • SQLyog错误号码2058最新解决办法

    SQLyog错误号码2058最新解决办法

    这篇文章主要给大家介绍了关于SQLyog错误号码2058的最新解决办法,使用sqlyog连接数据库过程中可能会出现2058错误,出现的原因是因为MYSQL8.0对密码的加密方式进行了改变,需要的朋友可以参考下
    2023-08-08
  • mysql聚集索引、辅助索引、覆盖索引、联合索引的使用

    mysql聚集索引、辅助索引、覆盖索引、联合索引的使用

    本文主要介绍了mysql聚集索引、辅助索引、覆盖索引、联合索引的使用,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-02-02
  • 两大步骤教您开启MySQL 数据库远程登陆帐号的方法

    两大步骤教您开启MySQL 数据库远程登陆帐号的方法

    在工作实践和学习中,如何开启 MySQL 数据库的远程登陆帐号算是一个难点的问题,以下内容便是在工作和实践中总结出来的两大步骤,能帮助DBA们顺利的完成开启 MySQL 数据库的远程登陆帐号。
    2011-03-03
  • 傻瓜式用Eclipse连接MySQL数据库

    傻瓜式用Eclipse连接MySQL数据库

    本来不想写这么简单人文章,在百度上搜索我这个标题,完全符合标题的一大堆。但我按照那些文章捣鼓了很久,就是不行。
    2015-09-09

最新评论