当前位置:首页 > 数据库 > MySQL > 正文内容

Linux安装Mysql

前提

使用Centos7进行安装教程

1、查看是否安装过mysql

rpm -qa | grep mysql

如果你查看出来有东西,可以使用下面命令将其删除(xxx 为文件全名)

rpm -e xxx# 强力删除模式,如果使用上面命令删除时,提示有依赖的其它文件,则用该命令可以对其进行强制删除rpm -e --nodeps mysql

如果没有直接进入第2步

2、下载官方Mysql安装包:https://downloads.mysql.com/archives/community/

选择对应的包,如下5.7:

 已下载安装包:mysql-5.7.35-Linux-glibc2.12-x86_64.tar.gz

 Mysql安装与配置

1、上传安装包至服务器并进行解压

# 创建安装包上传路径
mkdir -p /usr/local/mysql
# 进入到该目录下

cd /usr/local/mysql
#(解压后可删除安装包,节省空间)

tar -zxvf mysql-5.7.35-linux-glibc2.12-x86_64.tar.gz
# 重命名解压后的mysql

#安装目录
mv mysql-5.7.35-linux-glibc2.12-x86_64 mysql-5.7.35
# 进入该目录

cd mysql-5.7.35

 2、创建用户组和用户

 Root用户是最高权限用户,所以一般都是创建用户和用户组,防止最高权限用户进行操作。

# 添加用户组,命名为mysqlgroupadd mysql# 创建用户mysql,并指定所属群组为mysqluseradd -r -g mysql mysql

3、赋权,用用户组和用户具有操作权限

注意:.表示本级目录,一定要保证当前所在文件夹是/usr/local/mysql/mysql-5.7.35中

# 变更mysql用户组有操作当前文件夹权限chgrp -R mysql .# 变更mysql用户具有操作本级目录权限chown -R mysql .# 上面两个命令也可换成一条命令chown -R mysql:mysql ./

4、配置Mysql

# 创建数据存储目录
mkdir /usr/local/service/mysql/mysql-5.7.35/data/

# 创建数据日志目录
mkdir /usr/local/service/mysql/mysql-5.7.35/log/

# 创建临时文件目录
mkdir /usr/local/service/mysql/mysql-5.7.35/tmp/

# 创建运行文件目录
mkdir /usr/local/service/mysql/mysql-5.7.35/run/

# 创建启动错误日志
touch /usr/local/service/mysql/mysql-5.7.35/log/mysqld_safe_error.log

# 创建默认的错误日志目的地
touch /usr/local/service/mysql/mysql-5.7.35/log/alert.log

# 创建慢查询日志文件
touch /usr/local/service/mysql/mysql-5.7.35/log/slow.log

# 创建通用查询日志文件的
touch /usr/local/service/mysql/mysql-5.7.35/log/general.log

5、编辑my.cnf配置文件

将以下内容写入配置文件 /etc/my.cnf


# mysqld_safe脚本启动时读取的配置

[mysqld_safe]

# 存放 MySQL 后台程序 pid 的文件位置

pid-file=/usr/local/service/mysql/mysql-5.7.35/run/mysqld.pid



# 启动错误日志

log-error=/usr/local/service/mysql/mysql-5.7.35/log/mysqld_safe_error.log



# 本地 mysql 客户端程序的配置块

[mysql]

# 本地 mysql 客户端连接的端口

port=3306



# 本地 mysql 客户端命令行提示信息

prompt=\\u@\\d \\r:\\m:\\s>



# 本地 mysql 客户端字符集

default-character-set=utf8mb4



# 开启命令补全

no-auto-rehash



# 所有mysql客户端程序读取的配置块

[client]



# 连接端口

port=3306



# mysql的主机和客户机在同一host上的时候,使用unix domain socket做为通讯协议的载体文件

socket=/usr/local/service/mysql/mysql-5.7.35/run/mysql.sock



# mysql服务端程序mysqld、mysqld_safe和mysqld_multi的配置文件

[mysqld]

# 进程崩溃时生成core file dump文件,便于程序调试和问题排查

core-file



# 该参数指定了安装 MySQL 的安装路径(mysql安装目录),填写全路径可以解决相对路径所造成的问题。

basedir=/usr/local/service/mysql/mysql-5.7.35



# 该参数指定MySQL的数据文件的存放目录,数据库文件即我们常说的 MySQL data 文件。

datadir=/usr/local/service/mysql/mysql-5.7.35/data



# 临时目录

tmpdir=/usr/local/service/mysql/mysql-5.7.35/tmp



# 用于错误消息的区域设置。默认值是en_US。服务器将参数转换为语言名,并将其与lc_messages_dir的值结合,以生成错误消息文件的位置。

lc_messages=zh_CN



# 错误消息所在的目录。服务器使用该值和lc_messages的值来生成错误消息文件的位置。

lc_messages_dir=/usr/local/service/mysql/mysql-5.7.35/share



# 默认的错误日志目的地。如果目标是控制台,则值为stderr。否则,目标是一个文件,log_error值是文件名。

log-error=/usr/local/service/mysql/mysql-5.7.35/log/alert.log



# 慢查询日志文件名。默认值是host_name-slow.log,但可以通过slow_query_log_file选项更改初始值。

slow_query_log_file=/usr/local/service/mysql/mysql-5.7.35/log/slow.log



# 通用查询日志文件的名称。默认值是host_name.log,但初始值可以通过general_log_file选项更改。

general_log_file=/usr/local/service/mysql/mysql-5.7.35/log/general.log



# mysql的主机和客户机在同一host上的时候,使用unix domain socket做为通讯协议的载体文件

socket=/usr/local/service/mysql/mysql-5.7.35/run/mysql.sock



# 服务端字符集

character-set-server=utf8mb4



# 此变量控制写入错误日志的消息中的时间戳的时区,以及写入文件的一般查询日志和慢查询日志消息中的时间戳的时区。

log_timestamps=SYSTEM



# 操作系统中可用于mysqld的文件描述符的数量。

open_files_limit=61535



# 同时允许的最大客户端连接数。

max_connections=1000



# mysql_stmt_send_long_data() C API函数发送的一个包或任何生成/中间字符串的最大大小,或任何参数的最大大小。默认是64MB。

max_allowed_packet=1G



# 如果设置为0,表名将按指定的方式存储,并且比较区分大小写。如果设置为1,表名将以小写形式存储在磁盘上,比较不区分大小写。如果设置为2,则表名按给定值存储,但以小写进行比较。此选项也适用于数据库名称和表别名。

lower_case_table_names=1



# 慢查询日志是否开启。取值为0(或OFF)表示关闭日志,取值为1(或ON)表示打开日志。默认值取决于是否给出——slow_query_log选项。日志输出的目标由log_output系统变量控制;如果该值为NONE,则即使启用了日志,也不会写入任何日志项。

slow_query_log=1



# validate_password插件的加载方法

plugin-load-add=validate_password.so



# validate-password在服务器启动时使用该选项来控制插件的激活

validate-password=FORCE_PLUS_PERMANENT

 6、初始化

# 将安装目录的所有权授予用户、属组 mysql:mysqlchown -R mysql:mysql /usr/local/service/mysql/mysql-5.7.35# 初始化数据库cd /usr/local/service/mysql/mysql-5.7.35./bin/mysqld --initialize --user=mysql --basedir=/usr/local/service/mysql/mysql-5.7.35/ --datadir=/usr/local/service/mysql/mysql-5.7.35/data/# 再次将安装目录的所有权授予用户、属组 mysql:mysqlchown -R mysql:mysql /usr/local/service/mysql/mysql-5.7.35

7、配置开机自启动

把启动脚本 mysql.server 放到开机初始化目录 /etc/init.d/ ,同时改名为 mysqld

cp /usr/local/service/mysql/mysql-5.7.35/support-files/mysql.server /etc/init.d/mysqld

 8、启动

启动、重启、关闭mysql服务

# start:启动 restart:重启 关闭:stopservice mysqld start

Mysql必须在启动状态下,才可修改密码(下一步操作)

9、操作Mysql数据库

在mysql日志文件中找到初始密码,命令如下:

tail -n 1000 /usr/local/service/mysql/mysql-5.7.35/log/alert.log | grep root@localhost

root@localhost后面的内容,就是本机root用户的初始密码,需要记录下来。

初始密码: >Al+fUZdP6ZU

进入到mysql编辑模式

# 进入mysql安装目录cd /usr/local/service/mysql/mysql-5.7.35# 登录mysqlmysql -u root -p# 如果提示没有mysql命令,需要添加软连接ln -s /usr/local/mysql/mysql-5.7.35/bin/mysql /usr/bin/mysql

会提示要求输入密码,此时输入在mysql日志文件中找到初始密码,此时不能做任何事情,因为MySQL默认必须修改密码之后才能操作数据库

注意:输入密码期间不能输入其他内容,输入密码是隐藏不可见的

-- 修改为自己的密码ALTER USER 'root'@'localhost' IDENTIFIED BY 'new password';

注意:Mysql密码设定有默认策略,简单的密码设置不了,还会报以下错误

解决方法:

可先按照策略修改一个密码,然后使用密码重新登录过后修改策略,策略修改后即可重复修改密码语句进行重新设定密码

默认策略:大写+小写+数字+符号

进入到mysql命令后,出现[mysql>]

此时就可以根据自己需要创建数据库、创建表等CRUD操作。

远程访问

--进入mysql数据库--use mysql;--修改user表的root账户的host内容--update user set host="%" where user="root";--刷新修改立即生效--flush privileges;

10、策略修改

对比Mysql8.+和Mysql5.7及一下版本策略,注意变量名称的不同

-- 查看当前策略SHOW VARIABLES LIKE 'validate_password%';


-- 更改密码验证规则 Mysql5.7-

set global validate_password_policy=0;

set global validate_password_length=1;



-- 更改密码验证规则 Mysql8.*

set global validate_password.policy=0;

set global validate_password.length=1;

更改完成之后就可以重复修改密码步骤进行再次修改啦

11、忘记密码后修改方式

进入/etc/my.cnf在[mysql]下添加skip-grant-tables启动安全模式

vim /etc/my.cnf

登录mysql,输入密码时直接回车

mysql -u root -p

修改密码:update user set password = password("root123") where user = 'root';

刷新权限:flush privileges;

退出Mysql编辑模式:exit

注意:密码修改完成后,将/etc/my.cnf配置文件中的skip-grant-tables去掉

12、设置用户具有远程访问权限

进入mysql编辑模式:mysql -u root -p

执行远程连接权限赋予命令:GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root123' WITH GRANT OPTION;

刷新权限:flush privileges;

mysql8.0需要分步骤执行,命令如下:

-- 创建新用户
create user 'admin'@'%' identified by 'password';
-- 执行授权
GRANT ALL PRIVILEGES ON *.* TO 'admin'@'%';
-- 刷新
flush privileges;
-- 授权远程
ALTER USER 'admin'@'%' IDENTIFIED WITH mysql_native_password BY 'password';
-- 刷新
flush privileges;

退出Mysql编辑模式:exit 


扫描二维码推送至手机访问。

版权声明:本文章来源于网络,版权归原作者所有,如果本站文章侵犯了您的权益,请联系我们删除,联系邮箱:luxd@aliyun.com,感谢支持理解。


本文链接:https://luxd.cc/post/263.html

“Linux安装Mysql” 的相关文章

Mysql 用户权限管理

Mysql 用户权限管理

1. MySQL 权限介绍mysql中存在4个控制权限的表,分别为user表,db表,tables_priv表,columns_priv表,我当前的版本mysql 5.7.22 。mysql权限表的验证过程为:先从user表中的Host,User,Password这3个字段中判断连接的ip、用户名、...

三分钟学会如何找回mysql密码

三分钟学会如何找回mysql密码

一、在测试工作中我们肯定会写一些sq查询语句方便我们验证数据是否正确,从而判断当前软件是否存在缺陷,但是查询的过程中肯定需要我们先连接数据库,如果数据库密码忘记我们就无法完成工作,这里就教会大家如何快速修改密码,和重置数据库密码,这样在工作中很大提高我们工作的效率二、首先我们需要先学会如何修改mys...

mysql数据库乱码解决

mysql数据库乱码解决

一、我们需要将默认的字符集更改为utf-8来解决数据库导入数据的乱码问题:我们需要先查看数据库默认的字符集是什么:show variables like 'character_set_%'查看所有的默认字符集mysql> show&nbs...

MySQL迁移升级解决方案

MySQL迁移升级解决方案

任务背景由于现有业务架构已不能满足当前业务需求,在保证数据完整的前提下,现需要将原有数据库迁移到另外一台单独的服务器上,在保证原有服务正常的情况下,将原有LAMP环境中mysql数据库版本5.6.31升级为5.6.35.任务要求在业务维护时间(02:00-4:00)段对数据库进行全量备份将MySQL...

Windows MySQL安装配置

Windows MySQL安装配置

[MustVIP]1 下载和安装访问达内文档服务器下载安装包用浏览器访问http://doc.canglaoshi.org,在常用下载中找到 Windows 里面的MariaDB下载后双击运行安装安装过程中设置密码为root, 设置默认字符集UTF-8后续安装步骤是一直下一步直至完成。2 测试MyS...

『MySQL快速上手』Centos 7安装MySQL详解

『MySQL快速上手』Centos 7安装MySQL详解

说明:在环境安装中始终保持root身份;以下为Centos 7安装MySQL的详细步骤。若在安装过程中,本文章有未提及的地方,请私信我~1.卸载掉之前安装的MySQL为了确保你的机器上是否自带MySQL或者你曾经是否手动安装过MySQL,我们需要先进行检查。如果你曾经自己下载过某个版本的MySQL并...