一、前言

  由于我使用的是阿里云的服务器,后面会加入配置阿里云的部分,非阿里云的linux系统可以省略后面的步骤,根据自己系统的情况进行配置~

  PS:我安装的是mysql5.7.24的版本,其他版本的MySQL不一定适用此文,仅供参考

二、安装前准备

卸载已经安装的MySQL

#1、检查是否安装过mysql
rpm -qa | grep mysql

#2、若已经安装则运行下面的命令
rpm -e --nodeps 安装的文件

#3、再次检查是否安装过mysql,直至出现下图情况
rpm -qa | grep mysql

删除所有Mysql对应的文件夹

#1、查询mysql相关的文件目录
find / -name mysql

#2、删除相应的目录和文件,多个空格间隔可以一起删除
rm -rf 目录1 目录2 #3、再次检查mysql相关的文件目录是否已经全部删除,直至出现下图情况
find / -name mysql

重新创建MySQL相关的用户和组

#1、先检查mysql用户组和用户是否存在
cat /etc/group | grep 组名 #检查组
cat /etc/passwd |grep 用户名 #检查用户信息

#2、没有时,创建新的MySQL组和用户
groupadd 组名 #创建组
useradd -r -g 组名 用户名 #创建用户【-r指的是创建系统用户,-g指的是给mysql用户分配到mysql组里】

下载安装包

#1、新建一个mysql目录
cd /usr/local #进入目录
mkdir mysql #新建mysql目录
cd mysql #进入新建的mysql目录 #2、用下载工具命令wget来下载安装包
wget https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.24-linux-glibc2.12-x86_64.tar.gz

三、正式安装

解压

#1、解压
tar xzvf mysql-5.7.24-linux-glibc2.12-x86_64.tar.gz

#2、存放好安装包
mv mysql-5.7.24-linux-glibc2.12-x86_64 mysql #把解压出来的文件夹改名
mkdir plugins #新建一个目录存放安装包
mv mysql-5.7.24-linux-glibc2.12-x86_64.tar.gz plugins/ #移动安装包到新的目录

创建数据库路径

#3、创建用于存储数据库数据的目录
mkdir /usr/local/mysql/mysql/data

更改mysql目录权限

#4、更改目录的属主和属组【-R表示目录及子目录和文件】
chown -R mysql:mysql /usr/local/mysql #5、更改目录的用户权限
chmod -R 755 /usr/local/mysql

编译并安装

#6、进入mysql的bin目录
cd /usr/local/mysql/mysql/bin #7、编译
./mysqld --initialize --user=mysql --datadir=/usr/local/mysql/mysql/data --basedir=/usr/local/mysql/mysql

安装成功后出现下图,红框部分为临时密码:

PS:若编译失败时,尝试以下命令后再编译:

#安装linux的异步I/O接口
yum install libaio-devel.x86_64

#安装numactl工具
yum -y install numactl

四、配置MySQL

更改配置文件

#1、查看my.cnf文件权限【默认为644】
ls -l /etc/my.cnf #2、开放配置文件my.cnf权限
chmod 777 /etc/my.cnf #3、编辑mysql的配置文件my.cnf
vim /etc/my.cnf #4、在my.cnf中输入下面的配置并保存
[mysqld]
basedir=/usr/local/mysql/mysql
datadir=/usr/local/mysql/mysql/data
port = 3306
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
symbolic-links=0
max_connections=400
innodb_file_per_table=1 #5、恢复my.cnf文件权限【默认为644】
chmod 644 /etc/my.cnf

启动MySQL

#启动Mysql服务
/usr/local/mysql/mysql/support-files/mysql.server start

出现下图即安装并启动成功:

五、更便捷地使用MySQL

软连接

  软连接类似于windows的快捷方式:

#创建启动类软连接
ln -s /usr/local/mysql/mysql/support-files/mysql.server /etc/init.d/mysql #创建目录软连接
ln -s /usr/local/mysql/mysql/bin/mysql /usr/bin/mysql #重启MySQL服务
service mysql restart

修改密码

#登录mysql【输入密码为上面步骤的初始密码】
mysql -u root -p #修改密码
set password for root@localhost = password('新密码');

开放远程连接

#打开mysql数据库
use mysql; #开放远程机器链接【相当于改user这个系统表】
update user set user.Host='%' where user.User='root'; #刷新系统权限相关表
flush privileges;

原理解析:实际上是打开了mysql这个数据库,然后修改了user这个表的一条记录:

命令执行结果:

设置开机自动启动

#将服务文件拷贝到init.d下,并重命名为mysqld
cp /usr/local/mysql/mysql/support-files/mysql.server /etc/init.d/mysqld #赋予可执行权限
chmod +x /etc/init.d/mysqld #添加服务
chkconfig --add mysqld #显示服务列表
chkconfig --list

六、开放阿里云安全组【非阿里云搭建的同学选看】

   在服务器控制台找到如下路径:

  • 网络与安全--安全组--配置规则--添加安全组规则

  配置完成后保存,并重启实例,就可以使用数据库可视化工具来测试链接了~

参考资料:

linux学习(十)linux安装MySQL的更多相关文章

  1. Linux centos7环境下安装MySQL的步骤详解

    Linux centos7环境下安装MySQL的步骤详解 安装MySQL mysql 有两个跟windows不同的地方 1).my.ini 保存到/etc/my.ini 2).用户权限,单独用户执行 ...

  2. centOS Linux下用yum安装mysql

    centOS Linux下用yum安装mysql      第一篇:安装和配置MySQL   第一步:安装MySQL   [root@192 local]# yum -y install mysql- ...

  3. linux下使用yum安装mysql、tomcat、httpd

    一.linux下使用yum安装mysql   1.安装 查看有没有安装过:           yum list installed mysql*           rpm -qa | grep m ...

  4. [mysql] linux下使用yum安装mysql

    From: http://www.2cto.com/database/201207/141878.html linux下使用yum安装mysql   1.安装 查看有没有安装过:           ...

  5. Linux学习笔记-Linux系统简介

    Linux学习笔记-Linux系统简介 UNIX与Linux发展史 UNIX是父亲,Linux是儿子. UNIX发行版本 操作系统 公司 硬件平台 AIX IBM PowerPC HP-UX HP P ...

  6. Linux学习之三-Linux系统的一些重要配置文件

    Linux学习之三-Linux系统的一些重要配置文件 1.网卡配置文件 /etc/sysconfig/network-scripts/ifcfg-eth0 说明: DEVICE=eth0        ...

  7. Linux学习之CentOS6下Mysql数据库的安装与配置

    转自:http://www.cnblogs.com/xiaoluo501395377/archive/2013/04/07/3003278.html 如果要在Linux上做j2ee开发,首先得搭建好j ...

  8. Linux学习笔记2_mysql安装

    查看文件内容的命令有很多:cat, tac, more, less, head, tail, nl. cat由第一行开始显示档案内容:tac从最后一行开始显示,可以看出tac是cat的倒着写:more ...

  9. linux系统ubuntu18.04安装mysql(5.7)

    本文是参考mysql官网整理而成,顺便把一些遇到的问题记载下来. ①将MySQLAPT存储库添加到系统的软件存储库列表中  ---->下载APT存储库(下载链接)  ---->安装APT存 ...

  10. 在CentOS Linux 7.5上安装MySQL

    本文来自与https://www.linuxidc.com/Linux/2018-05/152574.htm 随着CentOS 7 MySQL的发布,世界上最流行的开源关系数据库管理系统在CentOS ...

随机推荐

  1. AD18 PCB中添加中文字符串显示乱码问题解决

    该问题是由于字符串的自体类型设置问题,AD默认是[stroke],我们点击[TrueType]即可正常显示.PS:AD18搞啥呢,默认显示输入内容不行吗,找半天!!!

  2. 社区布道师揭秘消息中间件技术内幕,撰写MQ架构设计与实现原理

    RocketMQ是什么 RocketMQ是由阿里捐赠给Apache的一款分布式.队列模型的开源消息中间件,经历了淘宝双十一的洗礼. RocketMQ的特性 RocketMQ基本概念 Client端 P ...

  3. zabbix如何监控Nvidia显卡的各项指标?

    如何实现zabbix监控windows机器的N卡GPU指标呢? Nvidia卡在安装驱动程序的时候,已经自带安装了一个命令行工具来获取显卡的各个性能指标值 在windows机器上,我们可以把该路径加入 ...

  4. Python开发的入门教程(七)-切片

    介绍 本文主要介绍Python中切片的基本知识和使用 对list进行切片 取一个list的部分元素是非常常见的操作.比如,一个list如下: >>> L = ['Adam', 'Li ...

  5. POJ - 3037-Skiing(邻接表+Dijkstra)

    Bessie and the rest of Farmer John's cows are taking a trip this winter to go skiing. One day Bessie ...

  6. Mybatis源码学习第八天(总结)

    源码学习到这里就要结束了; 来总结一下吧 Mybatis的总体架构 这次源码学习我们,学习了重点的模块,在这里我想说一句,源码的学习不是要所有的都学,一行一行的去学,这是错误的,我们只需要学习核心,专 ...

  7. 关于Vue-loader的那些事儿

    什么是Vue-loader 一个webpack的加载器,负责将vue组件编译成普通的JavaScript模块. 关于webpack的介绍 这里呢?用到webpack,在项目的编译打包的过程中,将复杂的 ...

  8. MVC中将枚举类型数据应用到下拉列表中的方法

    例如: public enum ItemTypes   {      Movie = 1,      Game = 2,      Book = 3   }    在MVC2.0中如何将以上枚举类型使 ...

  9. Solr专题(二)详解Solr查询参数

    一.前言 上节我们讲到了怎样去搭建solr服务,作为全文检索引擎,怎样去使用也是比较关键的.Solr有一套自己的查询方式,所以我们需要另外花时间去学习它的这套模式. 启动solr solr start ...

  10. linux下设置账户锁定阈值:登录失败n次,多长时间后解锁重新登录

    在centos系统下: 1.执行命令 vim /etc/pam.d/system-auth或vim /etc/pam.d/ login 2.执行命令 vim /etc/pam.d/sshd 3.在上面 ...