CentOS离线安装MySQL

目录

前沿

一、安装libaio

 二、卸载系统自带的Mariadb 

三、下载安装包

四、创建MySQL用户

五、创建配置文件

六、安装MySQL服务

七、获得mysql初始密码

八、开启远程登录

九、问题处理 


前沿

MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件之一。MySQL数据库按用户群分为社区版(Community Server)和企业版(Enterprise/commercial)。commercial为授权版本,社区版是免费下载的,企业版需要付费且不能在线下载。

社区版分为3种:

GA(General Availability):官方推荐使用的版本,生产环境中还是建议使用GA版本。

RC(Release Candidate):候选版本,该版本是接近正式版的版本。

Alpha和Beta都是测试版本,Alpha是内测版本,Beta是公测版本。

本文安装版本为MySQL Community Server 5.7.39

一、安装libaio

yum install -y libaio

 二、卸载系统自带的Mariadb 

# 查询已安装的mariadb
rpm -qa|grep mariadb
# 卸载,文件名为使用rpm -qa|grep mariadb 命令查出的所有文件,依次执行
rpm -e --nodeps 文件名 
#删除etc目录下的my.cnf文件,不管有没有,先删了
rm /etc/my.cnf

三、下载安装包

访问MySql官网下载安装包,打开网址,按照步骤选择,可以找到5.7.39版本

将下载的安装包上传到服务器的指定目录/mnt/software/tools下

把下载的文件夹解压缩并移动到/mnt/software下:

tar -zxvf mysql-5.7.39-linux-glibc2.12-x86_64.tar.gz
mv mysql-5.7.39-linux-glibc2.12-x86_64 /mnt/software/mysql

四、创建MySQL用户

创建用户组,接着创建mysql用户并加入用户组

groupadd mysql
useradd -g mysql mysql

五、创建配置文件

创建my.cnf

vim /etc/my.cnf
[mysqld]
# 设置3306端口
port=3306
 
# 自定义设置mysql的安装目录,即解压mysql压缩包的目录
basedir=/mnt/software/mysql
 
# 自定义设置mysql数据库的数据存放目录
datadir=/mnt/data/mysql/data
 
socket=/var/lib/mysql/mysql.sock

# 允许最大连接数
max_connections=200
 
# 允许连接失败的次数,这是为了防止有人从该主机试图攻击数据库系统
max_connect_errors=10
 
# 服务端使用的字符集默认为UTF8
character-set-server=utf8
 
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
 
# 默认使用“mysql_native_password”插件认证
default_authentication_plugin=mysql_native_password

# 解决group by问题
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
# lower_case_table_names=1

explicit_defaults_for_timestamp=true
[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8
 
[client]
# 设置mysql客户端连接服务端时默认使用的端口和默认字符集
port=3306
default-character-set=utf8

socket=/var/lib/mysql/mysql.sock

 创建目录并将其用户设置为mysql

mkdir /var/lib/mysql
chown -R mysql:mysql /var/lib/mysql

创建数据文件文件夹

mkdir -p /mnt/data/mysql
cd /mnt/data/mysql
# 修改当前目录拥有者为mysql用户
chown -R mysql:mysql ./

授予my.cnf最大权限

chown 777 /mnt/software/mysql/my.cnf

六、安装MySQL服务

初始化MySQL

cd /mnt/software/mysql/bin
./mysqld --initialize --user=mysql --basedir=/mnt/software/mysql --datadir=/mnt/data/mysql/data
#授权data目录
chown -R mysql:mysql /mnt/data/mysql/data

启动MySQL

/etc/init.d/mysql start
#复制启动脚本
cp /mnt/software/mysql/support-files/mysql.server  /etc/init.d/mysql
chmod +x /etc/rc.d/init.d/mysql
#设置开机启动
chkconfig --level 35 mysql on
#查看服务列表
chkconfig --list

   mysql已经被设置成服务了我们关闭刚刚启动的mysql

/etc/init.d/mysql stop

启动MySQL服务,并验证是否成功

#开启
service mysql start
#查看状态
service mysql status
#停止mysql服务
service mysql stop

 添加环境变量 

#在/etc/profile最后一行加入:
echo 'export PATH=$PATH:/mnt/software/mysql/bin' >> /etc/profile
#重新加载配置文件使配置的环境变量生效:
source /etc/profile

七、获得mysql初始密码

cat /root/.mysql_secret
# Password set for user 'root@localhost' at 2022-08-14 18:14:09 

FhALk2pN*Tx-

#登录mysql
mysql -uroot -pFhALk2pN*Tx-
#切换数据库
use mysql;
#更新密码
update user set authentication_string=password('root') where user='root';
flush privileges;
quit

八、开启远程登录

GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root' WITH GRANT OPTION;

九、问题处理 

--initialize specified but the data directory has files in it. Aborting.

删除 /mnt/data/mysql/data目录即可


TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details).

在mysqld下面添加

explicit_defaults_for_timestamp=true

mysqld: Can't create directory '/mnt/data/mysql/data/' (Errcode: 2 - No such file or directory)

创建文件夹/mnt/data/mysql


ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing this .
alter user 'root'@'localhost' identified by 'root';

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值