Mysql 三种安装方式

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: Mysql 三种安装方式

二进制安装

1) 安装依赖包

yum install ncurses-devel libaio-devel -y

2)创建用户

groupadd mysql -g 666useradd mysql -u 666 -g 666-s /sbin/nologin -M

3)解压

mkdir /application 
mkdir /server/tools -p
cd /server/tools/
tar xf mysql-5.7.20-linux-glibc2.12-x86_64.tar.gz
mv mysql-5.7.20-linux-glibc2.12-x86_64 /application/mysql-5.7.20

4)创建日志

mkdir /application/mysql-5.7.20/data  #用于存放数据库数据
mkdir /application/mysql-5.7.20/tmp    #用于存放socket文件
ln -s /application/mysql-5.7.20/ /application/mysql
touch  /application/mysql-5.7.20/mysql.log

5)初始化数据

#初始化数据库命令
/application/mysql-5.7.20/bin/mysqld --initialize --initialize  --user=mysql --basedir=/application/mysql-5.7.20 --datadir=/application/mysql-5.7.20/data
#这里会生成MySQL第一次登录使用的临时密码,需要保存下来
2019-01-13T16:11:48.234884Z 1 [Note] A temporary password is generated for root@localhost: ,rK+/7/AvOF:
参数解释:
--initialize #初始化mysql
--user=mysql #指定mysql用户
--basedir  #指定mysql基础目录
--datadir #指定mysql数据存放目录

6)授权

chown -R mysql.mysql /application/mysql-5.7.20

7)添加配置文件

#1.修改启动脚本内容中的路径
cd /application/mysql/support-files/
sed -i 's#/usr/local#/application/mysql#g' mysql.server
cp mysql.server /etc/init.d/mysqld
#2.配置my.cnf
[root@db01 /]# vim /etc/my.cnf
[mysqld]
basedir=/application/mysql
datadir=/application/mysql/data
socket=/application/mysql/tmp/mysql.sock
character-set-server=utf8
port=3306
server_id=10
log-error=/application/mysql/mysql.log
log-bin=/application/mysql/data/mysql-bin
binlog_format=row
skip_name_resolve
[mysql]
socket=/application/mysql/tmp/mysql.sock
[mysqladmin]
socket=/application/mysql/tmp/mysql.sock
#3.启动mysql
/etc/init.d/mysqld start

8)配置环境变量

echo 'export "PATH=/application/mysql/bin:$PATH"' >>/etc/profile
source /etc/profile

9)修改密码

[root@db01 /]# mysql -uroot -p,rK+/7/AvOF:
[root@db01 /]# mysqladmin -uroot -p password 123456
Enter password:  #输入旧密码

源码安装

1)依赖包

yum install ncurses-devel libaio-devel cmake -y

2)创建用户

groupadd mysql -g 666useradd
mysql -u 666 -g 666 -s /sbin/nologin -M

3)安装目录

mkdir /server/tools -p
mkdir /application -p

4)编译

cd /server/tools/
rz mysql-5.7.20.tar.gz
[root@db01 tools]# tar xf mysql-5.7.20.tar.gz
[root@db01 tools]# cd mysql-5.7.20/
[root@db02 mysql-5.7.20]# cmake . -DCMAKE_INSTALL_PREFIX=/application/mysql-5.7.20 \
 -DMYSQL_DATADIR=/application/mysql-5.7.20/data \
 -DMYSQL_UNIX_ADDR==/application/mysql-5.7.20/tmp/mysql.sock \
 -DDEFAULT_CHARSET=utf8 \
 -DDEFAULT_COLLATION=utf8_general_ci \
 -DMYSQL_TCP_PORT=3306 \
 -DMYSQL_USER=mysql  \
 -DWITH_MYISAM_STORAGE_ENGINE=1  \
 -DWITH_INNOBASE_STORAGE_ENGINE=1  \
 -DWITH_ARCHIVE_STORAGE_ENGINE=1  \
 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
 -DWITH_MEMORY_STORAGE_ENGINE=1  \
 -DENABLE_DOWNLOADS=1   \
 -DDOWNLOAD_BOOST=1  \
 -DWITH_BOOST=/usr/local/boost 
[root@db01 mysql-5.6.36]# make && make install
编译参数解释:
-DCMAKE_INSTALL_PREFIX   #MySQL安装的路径
-DMYSQL_DATADIR #存放MySQL数据的路径
-DMYSQL_UNIX_ADDR   #MyQSL启动后的sock存放路径
-DDEFAULT_CHARSET #MySQL数据库中的字符集
-DWITH_BOOST  #mysql源码中用到了C++的Boost库 
-DENABLE_DOWNLOADS #例如boost路径填/usr/local/boost,它会在这个目录找,找不到就会自己下载到该目录

5)目录介绍

[root@db01 mysql-5.7.20]# tree -L 1 /application/mysql-5.7.20/
/application/mysql-5.7.20/
├── bin   #存放mysql命令
├── COPYING
├── COPYING-test
├── docs    #自带帮助文件
├── include
├── lib     #lib库
├── man
├── mysql-test
├── README
├── README-test
├── share
└── support-files

6)配置文件

#1.创建软连接
[root@db01 /]# ln -s /application/mysql-5.7.20/ /application/mysql
#2.配置/etc/my.cnf(5.7版本默认不自带my.cnf模板文件)
[root@db01 /]#vim /etc/my.cnf
[mysqld]
basedir=/application/mysql
datadir=/application/mysql/data
socket=/application/mysql/tmp/mysql.sock
character-set-server=utf8
port=3306
server_id=10
log-error=/application/mysql/mysql.log
log-bin=/application/mysql/data/mysql-bin
binlog_format=row
skip_name_resolve
[client]
socket=/application/mysql/tmp/mysql.sock
#3.创建/application/mysql/tmp目录用于存放mysql sock文件,并设置mysql目录权限
[root@db01 ~]# mkdir /application/mysql/tmp -p
[root@db01 ~]# chown -R mysql.mysql /application/mysql/
#4.创建错误日志文件
[root@db01 ~]# touch  /application/mysql-5.7.20/mysql.log
#5.初始化数据库(所有的初始化信息都保存在mysql日志文件中,包括初始化的root密码)
[root@db01 ~]# mkdir /application/mysql-5.7.20/data
[root@db01 ~]# /application/mysql-5.7.20/bin/mysqld --initialize --user=mysql --basedir=/application/mysql-5.7.20 --datadir=/application/mysql-5.7.20/data
#6.复制mysql启动脚本至/etc/init.d/mysqld,该脚本用于mysql启动,重启以及关闭
[root@db01 ~]# cp /application/mysql/support-files/mysql.server /etc/init.d/mysqld
#7.启动mysql数据库,mysql默认端口为3306
[root@db01 ~]# /etc/init.d/mysqld start
[root@db01 ~]# netstat -lntup |grep 3306
#8.增加mysql环境变量,为了可以直接在命令行执行mysql命令
[root@db01 ~]# echo 'export "PATH=/application/mysql/bin:$PATH"' >>/etc/profile
[root@db01 ~]# tail -1 /etc/profile
[root@db01 ~]# source /etc/profile
[root@db01 ~]# echo $PATH

7)修改密码

[root@db01 /]# grep "temporary password" /application/mysql/mysql.log
2019-01-14T03:22:24.841670Z 1 [Note] A temporary password is generated for root@localhost: H#hbzsuPl1/-
[root@db01 /]# mysqladmin -uroot -p password "123456"
Enter password:  #输入旧密码进行更改
[root@db01 /]# mysql -uroot -p123456 #输入新密码进入数据库

Yum安装

1)安装目录

mkdir /server/tools -p
cd /server/tools/

2)下载对应源

wget http://repo.mysql.com//mysql57-community-release-el7-8.noarch.rpm

3)安装

yum -y install mysql57-community-release-el7-8.noarch.rpm
yum -y install mysql-community-server.x86_64

4)启动

systemctl start mysqldsystemctl enable mysqldnetstat -lntup |grep 3306

5)修改密码

# mysql安装完成后,会在/var/log/mysqld.log文件中给root生成一个默认的登录密码
[root@db01 /]# grep "temporary password" /var/log/mysqld.log
2019-01-14T02:04:55.465890Z 1 [Note] A temporary password is generated for root@localhost: al_gF&9eZUjW
#进入mysql命令行,修改密码为:MyNewPass4!
[root@db01 /]# mysql -uroot -p"al_gF&9eZUjW"
mysql> set password = password('MyNewPass4!');
注意:mysql5.7默认安装了密码安全检查插件(validate_password),默认密码检查策略要求密码必须包含:大小写字母、数字和特殊符号,并且长度不能少于8位

6)修改mysql组策略

#1.查看系统密码策略
[root@db01 /]# mysql -uroot -pMyNewPass4! -e "show variables like '%password%';" |grep "length"
validate_password_length    8
#2.在/etc/my.cnf配置文件中添加validate_password_policy配置,指定密码策略
[mysqld]
#validate_password_policy=0 
#指定密码策略 0(LOW),1(MEDIUM),2(STRONG)其中一种,选择2需要提供密码字典文件
validate_password = off  #禁用密码策略
#重新启动mysql服务使配置生效:
systemctl restart mysqld
#再次修改mysql密码
[root@db01 /]# mysqladmin -uroot -p password 123456
Enter password:      #输入旧密码MyNewPass4!完成更改

默认配置文件

/etc/my.cnf #配置文件/var/log/mysqld.log 
#日志文件/var/run/mysqld/mysqld.pid 
#socket文件

忘记密码如何登陆?

#在[mysqld]的段中加上一句:skip-grant-tables 保存并且退出vi。
mysql  -u root
update mysql.user set authentication_string=password('123qwe') where user='root' and Host = 'localhost';
flush privileges
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1月前
|
安全 关系型数据库 MySQL
mysql8安装
本文介绍了在 CentOS 7 上安装 MySQL 5.7 的详细步骤,包括下载、环境准备、系统配置、安装过程及启动方法。首先通过wget下载MySQL压缩包并解压至指定目录,接着进行主机名修改、依赖安装、用户与用户组创建、ulimit配置等环境准备工作。随后,对操作系统环境进行调整,如文件句柄和进程数的设置、内核参数优化、SELinux和防火墙的关闭等。最后,完成MySQL的安装配置,创建数据和日志目录,初始化MySQL,并设置启动脚本和环境变量,确保MySQL能够正常运行。
71 4
|
1月前
|
安全 关系型数据库 MySQL
Linux下安装mysql8.0(以tar.xz包安装--编译安装)
通过上述步骤,您完成了从下载、编译、安装到配置MySQL 8.0的全过程。此过程虽然较为复杂,但提供了对MySQL安装环境的完全控制,有助于满足特定的部署需求。在实际操作中,根据具体的系统环境,可能还需调整部分步骤或解决未预见的依赖问题。始终参考官方文档和社区资源,保持安装过程与最新版本的兼容性。
585 67
|
7天前
|
SQL 关系型数据库 MySQL
go语言数据库中mysql驱动安装
【11月更文挑战第2天】
20 4
|
28天前
|
关系型数据库 MySQL Linux
Docker安装Mysql5.7,解决无法访问DockerHub问题
当 Docker Hub 无法访问时,可以通过配置国内镜像加速来解决应用安装失败和镜像拉取超时的问题。本文介绍了如何在 CentOS 上一键配置国内镜像加速,并成功拉取 MySQL 5.7 镜像。
240 2
Docker安装Mysql5.7,解决无法访问DockerHub问题
|
13天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。通过具体案例,读者可以了解如何准备环境、下载源码、编译安装、配置服务及登录 MySQL。编译源码安装虽然复杂,但提供了更高的定制性和灵活性,适用于需要高度定制的场景。
44 3
|
13天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。
本文介绍了在 CentOS 7 中通过编译源码安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。内容涵盖准备工作、下载源码、编译安装、配置服务、登录设置及实践心得,帮助读者根据需求选择最适合的安装方法。
27 2
|
15天前
|
存储 SQL 关系型数据库
2024Mysql And Redis基础与进阶操作系列(1)作者——LJS[含MySQL的下载、安装、配置详解步骤及报错对应解决方法]
Mysql And Redis基础与进阶操作系列(1)之[MySQL的下载、安装、配置详解步骤及报错对应解决方法]
|
16天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据需求选择最合适的方法。通过具体案例,展示了编译源码安装的灵活性和定制性。
59 2
|
1天前
|
运维 关系型数据库 MySQL
安装MySQL8数据库
本文介绍了MySQL的不同版本及其特点,并详细描述了如何通过Yum源安装MySQL 8.4社区版,包括配置Yum源、安装MySQL、启动服务、设置开机自启动、修改root用户密码以及设置远程登录等步骤。最后还提供了测试连接的方法。适用于初学者和运维人员。
16 0
|
28天前
|
SQL Oracle 关系型数据库
安装最新 MySQL 8.0 数据库(教学用)
安装最新 MySQL 8.0 数据库(教学用)
104 4