整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

MYSQL 入门全套

源:www.cnblogs.com/aylin/p/5744312.html


MySQL简介

1、什么是数据库 ?

数据库(Database)是按照数据结构来组织、存储和管理数据的仓库,它产生于距今六十多年前,随着信息技术和市场的发展,特别是二十世纪九十年代以后,数据管理不再仅仅是存储和管理数据,而转变成用户所需要的各种数据管理的方式。数据库有很多种类型,从最简单的存储有各种数据的表格到能够进行海量数据存储的大型数据库系统都在各个方面得到了广泛的应用。

主流的数据库有:sqlserver,mysql,Oracle、SQLite、Access、MS SQL Server等,本文主要讲述的是mysql

2、数据库管理是干什么用的?

  • a. 将数据保存到文件或内存
  • b. 接收特定的命令,然后对文件进行相应的操作


PS:如果有了以上管理系统,无须自己再去创建文件和文件夹,而是直接传递 命令 给上述软件,让其来进行文件操作,他们统称为数据库管理系统(DBMS,Database Management System)

MySQL安装

MySQL是一种开放源代码的关系型数据库管理系统(RDBMS),MySQL数据库系统使用最常用的数据库管理语言–结构化查询语言(SQL)进行数据库管理。在 WEB 应用方面MySQL是最好的 RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件之一。

使用mysql必须具备一下条件

  • a. 安装MySQL服务端
  • b. 安装MySQL客户端
  • c. 【客户端】连接【服务端】
  • d. 【客户端】发送命令给【服务端MySQL】服务的接受命令并执行相应操作(增删改查等)


1、下载地址:http://dev.mysql.com/downloads/mysql/

2、安装

  • windows安装请参考:http://www.cnblogs.com/lonelywolfmoutain/p/4547115.html
  • linux下安装:http://www.cnblogs.com/chenjunbiao/archive/2011/01/24/1940256.html


注:以上两个链接有完整的安装方式,撸主也是参考他的安装的,安装完以后mysql.server start启动mysql服务

MySQL操作

一、连接数据库

mysql -u user -p 
例:mysql -u root -p

常见错误如下:

ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2), it means that the MySQL server daemon (Unix) or service (Windows) is not running.


退出连接:

QUIT 或者 Ctrl+D

二、查看数据库,创建数据库,使用数据库查看数据库:

show databases;

默认数据库:

mysql - 用户权限相关数据
test - 用于用户测试数据
information_schema - MySQL本身架构相关数据

创建数据库:

create database db1 DEFAULT CHARSET utf8 COLLATE utf8_general_ci; # utf8编码
create database db1 DEFAULT CHARACTER SET gbk COLLATE gbk_chinese_ci; # gbk编码

使用数据库:

 use db1;

显示当前使用的数据库中所有表:

SHOW TABLES;

三、用户管理

创建用户

create user '用户名'@'IP地址' identified by '密码';

删除用户

drop user '用户名'@'IP地址';

修改用户

rename user '用户名'@'IP地址'; to '新用户名'@'IP地址';

修改密码

set password for '用户名'@'IP地址' = Password('新密码');

注:用户权限相关数据保存在mysql数据库的user表中,所以也可以直接对其进行操作(不建议)

四、权限管理

mysql对于权限这块有以下限制:

all privileges:除grant外的所有权限
select:仅查权限
select,insert:查和插入权限
...
usage:无访问权限
alter:使用alter table
alter routine:使用alter procedure和drop procedure
create:使用create table
create routine:使用create procedure
create temporary tables:使用create temporary tables
create user:使用create user、drop user、rename user和revoke all privileges
create view:使用create view
delete:使用delete
drop:使用drop table
execute:使用call和存储过程
file:使用select into outfile 和 load data infile
grant option:使用grant 和 revoke
index:使用index
insert:使用insert
lock tables:使用lock table
process:使用show full processlist
select:使用select
show databases:使用show databases
show view:使用show view
update:使用update
reload:使用flush
shutdown:使用mysqladmin shutdown(关闭MySQL)
super:使用change master、kill、logs、purge、master和set global。还允许mysqladmin调试登陆
replication client:服务器位置的访问
replication slave:由复制从属使用

对于数据库及内部其他权限如下:

数据库名.* 数据库中的所有
数据库名.表 指定数据库中的某张表
数据库名.存储过程 指定数据库中的存储过程
*.* 所有数据库

对于用户和IP的权限如下:

用户名@IP地址 用户只能在改IP下才能访问
用户名@192.168.1.% 用户只能在改IP段下才能访问(通配符%表示任意)
用户名@% 用户可以再任意IP下访问(默认IP地址为%)

1、查看权限:

show grants for '用户'@'IP地址'

2、授权

grant 权限 on 数据库.表 to '用户'@'IP地址'

3、取消授权

revoke 权限 on 数据库.表 from '用户名'@'IP地址'

授权实例如下:

grant all privileges on db1.tb1 TO '用户名'@'IP'
grant select on db1.* TO '用户名'@'IP'
grant select,insert on *.* TO '用户名'@'IP'
revoke select on db1.tb1 from '用户名'@'IP'


MySQL表操作

1、查看表

show tables; # 查看数据库全部表
select * from 表名; # 查看表所有内容

2、创建表

create table 表名(
 列名 类型 是否可以为空,
 列名 类型 是否可以为空
)ENGINE=InnoDB DEFAULT CHARSET=utf8

来一个实例好详解

CREATE TABLE `tab1` (
 `nid` int(11) NOT NULL auto_increment,
 `name` varchar(255) DEFAULT zhangyanlin,
 `email` varchar(255),
 PRIMARY KEY (`nid`) 
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

注:

  • 默认值,创建列时可以指定默认值,当插入数据时如果未主动设置,则自动添加默认值
  • 自增,如果为某列设置自增列,插入数据时无需设置此列,默认将自增(表中只能有一个自增列)注意:1、对于自增列,必须是索引(含主键)2、对于自增可以设置步长和起始值
  • 主键,一种特殊的唯一索引,不允许有空值,如果主键使用单个列,则它的值必须唯一,如果是多列,则其组合必须唯一。


3、删除表

drop table 表名

4、清空表内容

delete from 表名
truncate table 表名

5、修改表

添加列: 
alter table 表名 add 列名 类型
删除列: 
alter table 表名 drop column 列名
修改列:
 
alter table 表名 modify column 列名 类型; -- 类型
alter table 表名 change 原列名 新列名 类型; -- 列名,类型
添加主键:
 
alter table 表名 add primary key(列名);
删除主键:
 
alter table 表名 drop primary key;
alter table 表名 modify 列名 int, drop primary key;
添加外键: 
alter table 从表 add constraint 外键名称(形如:FK_从表_主表) foreign key 从表(外键字段) references 主表(主键字段);
删除外键: 
alter table 表名 drop foreign key 外键名称
修改默认值:
ALTER TABLE testalter_tbl ALTER i SET DEFAULT 1000;
删除默认值:
ALTER TABLE testalter_tbl ALTER i DROP DEFAULT;

对于上述这些操作是不是看起来很麻烦,很浪费时间,别慌!有专门的软件能提供这些功能,操作起来非常简单,这个软件名字叫Navicat Premium ,大家自行在网上下载,练练手,但是下面的即将讲到表内容操作还是建议自己写命令来进行

6、基本数据类型

MySQL的数据类型大致分为:数值、时间和字符串

bit[(M)]
 二进制位(101001),m表示二进制位的长度(1-64),默认m=1
tinyint[(m)] [unsigned] [zerofill]
 小整数,数据类型用于保存一些范围的整数数值范围:
 有符号:
 -128 ~ 127.
 无符号:
 0 ~ 255
 特别的: MySQL中无布尔值,使用tinyint(1)构造。
int[(m)][unsigned][zerofill]
 整数,数据类型用于保存一些范围的整数数值范围:
 有符号:
 -2147483648 ~ 2147483647
 无符号:
 0 ~ 4294967295
 特别的:整数类型中的m仅用于显示,对存储范围无限制。例如: int(5),当插入数据2时,select 时数据显示为:00002
bigint[(m)][unsigned][zerofill]
 大整数,数据类型用于保存一些范围的整数数值范围:
 有符号:
 -9223372036854775808 ~ 9223372036854775807
 无符号:
 0 ~ 18446744073709551615
decimal[(m[,d])] [unsigned] [zerofill]
 准确的小数值,m是数字总个数(负号不算),d是小数点后个数。 m最大值为65,d最大值为30。
 特别的:对于精确数值计算时需要用此类型
 decaimal能够存储精确值的原因在于其内部按照字符串存储。
FLOAT[(M,D)] [UNSIGNED] [ZEROFILL]
 
 单精度浮点数(非准确小数值),m是数字总个数,d是小数点后个数。
 无符号:
 -3.402823466E+38 to -1.175494351E-38,
 0
 1.175494351E-38 to 3.402823466E+38
 有符号:
 0
 1.175494351E-38 to 3.402823466E+38
 **** 数值越大,越不准确 ****
DOUBLE[(M,D)] [UNSIGNED] [ZEROFILL]
 双精度浮点数(非准确小数值),m是数字总个数,d是小数点后个数。
 无符号:
 -1.7976931348623157E+308 to -2.2250738585072014E-308
 0
 2.2250738585072014E-308 to 1.7976931348623157E+308
 有符号:
 0
 2.2250738585072014E-308 to 1.7976931348623157E+308
 **** 数值越大,越不准确 ****
char (m)
 char数据类型用于表示固定长度的字符串,可以包含最多达255个字符。其中m代表字符串的长度。
 PS: 即使数据小于m长度,也会占用m长度
 
varchar(m)
 varchars数据类型用于变长的字符串,可以包含最多达255个字符。其中m代表该数据类型所允许保存的字符串的最大长度,只要长度小于该最大值的字符串都可以被保存在该数据类型中。
 注:虽然varchar使用起来较为灵活,但是从整个系统的性能角度来说,char数据类型的处理速度更快,有时甚至可以超出varchar处理速度的50%。因此,用户在设计数据库时应当综合考虑各方面的因素,以求达到最佳的平衡
text
 text数据类型用于保存变长的大字符串,可以组多到65535 (2**16 − 1)个字符。
mediumtext
 A TEXT column with a maximum length of 16,777,215 (2**24 − 1) characters.
longtext
 A TEXT column with a maximum length of 4,294,967,295 or 4GB (2**32 − 1) characters.
enum
 枚举类型,
 An ENUM column can have a maximum of 65,535 distinct elements. (The practical limit is less than 3000.)
 示例:
 CREATE TABLE shirts (
 name VARCHAR(40),
 size ENUM('x-small', 'small', 'medium', 'large', 'x-large')
 );
 INSERT INTO shirts (name, size) VALUES ('dress shirt','large'), ('t-shirt','medium'),('polo shirt','small');
set
 集合类型
 A SET column can have a maximum of 64 distinct members.
 示例:
 CREATE TABLE myset (col SET('a', 'b', 'c', 'd'));
 INSERT INTO myset (col) VALUES ('a,d'), ('d,a'), ('a,d,a'), ('a,d,d'), ('d,a,d');
DATE
 
 YYYY-MM-DD(1000-01-01/9999-12-31)
TIME
 HH:MM:SS('-838:59:59'/'838:59:59')
YEAR
 YYYY(1901/2155)
DATETIME
 YYYY-MM-DD HH:MM:SS(1000-01-01 00:00:00/9999-12-31 23:59:59 Y)
TIMESTAMP
 YYYYMMDD HHMMSS(1970-01-01 00:00:00/2037 年某时)


MySQL表内容操作

表内容操作无非就是增删改查,当然用的最多的还是查,而且查这一块东西最多,用起来最难,当然对于大神来说那就是so easy了,对于我这种小白还是非常难以灵活运用的,下面咱来一一操作一下

1、增

insert into 表 (列名,列名...) values (值,值,...)
insert into 表 (列名,列名...) values (值,值,...),(值,值,值...)
insert into 表 (列名,列名...) select (列名,列名...) from 表
例:
 insert into tab1(name,email) values('zhangyanlin','zhangyanlin8851@163.com')

2、删

delete from 表 # 删除表里全部数据
delete from 表 where id=1 and name='zhangyanlin' # 删除ID =1 和name='zhangyanlin' 那一行数据

3、改

update 表 set name = 'zhangyanlin' where id>1

4、查

select * from 表
select * from 表 where id > 1
select nid,name,gender as gg from 表 where id > 1

查这块的条件太多太多我给列举出来至于组合还得看大家的理解程度哈

a、条件判断where

select * from 表 where id > 1 and name != 'aylin' and num = 12;
select * from 表 where id between 5 and 16;
select * from 表 where id in (11,22,33)
select * from 表 where id not in (11,22,33)
select * from 表 where id in (select nid from 表)

b、通配符like

select * from 表 where name like 'zhang%' # zhang开头的所有(多个字符串)
select * from 表 where name like 'zhang_' # zhang开头的所有(一个字符)

c、限制limit

select * from 表 limit 5; - 前5行
select * from 表 limit 4,5; - 从第4行开始的5行
select * from 表 limit 5 offset 4 - 从第4行开始的5行

d、排序asc,desc

select * from 表 order by 列 asc - 根据 “列” 从小到大排列
select * from 表 order by 列 desc - 根据 “列” 从大到小排列
select * from 表 order by 列1 desc,列2 asc - 根据 “列1” 从大到小排列,如果相同则按列2从小到大排序

e、分组group by

select num from 表 group by num
select num,nid from 表 group by num,nid
select num,nid from 表 where nid > 10 group by num,nid order nid desc
select num,nid,count(*),sum(score),max(score),min(score) from 表 group by num,nid
select num from 表 group by num having max(id) > 10
特别的:group by 必须在where之后,order by之前

关注头条号 程序员乔戈里 关注以后私信我,送你一份价值19889元的某平台内部的编程资料和一堆实用软件。

. 忘记root密码

编辑mysql主配置文件 my.cnf 在[mysqld]字段下添加参数 skip-grant ,重启数据库服务,这样就可以进入数据库不用授权了 mysql -uroot ,修改相应用户密码 use mysql; update user set password=password('your password') where user='root';flush privileges; 最后修改/etc/my.cnf 去掉 skip-grant , 重启mysql服务

2. skip-innodb 我们可以增加这个参数不使用innodb引擎。

3. 配置慢查询日志

#log_slow_queries = /path/to/slow_queries

#long_query_time = 1

4. mysql常用操作

查看都有哪些库 show databases;

查看某个库的表 use db; show tables;

查看表的字段 desc tb;

查看建表语句 show create table tb;

当前是哪个用户 select user();

当前库 select database();

创建库 create database db1;

创建表 create table t1 (`id` int(4), `name` char(40));

查看数据库版本 select version();

查看mysql状态 show status;

修改mysql参数 show variables like 'max_connect%'; set global max_connect_errors = 1000;

查看mysql队列 show processlist;

创建普通用户并授权 grant all on *.* to user1 identified by '123456';

grant all on db1.* to 'user2'@'10.0.2.100' identified by '111222';

grant all on db1.* to 'user3'@'%' identified by '231222';insert into tb1 (id,name) values(1,'aming');

更改密码 UPDATE mysql.user SET password=PASSWORD("newpwd") WHERE user='username' ;

查询 select count(*) from mysql.user; select * from mysql.db; select * from mysql.db where host like '10.0.%';

插入 update db1.t1 set name='aaa' where id=1;

清空表 truncate table db1.t1;

删除表 drop table db1.t1;

删除数据库 drop database db1;

修复表 repair table tb1 [use frm];

5. mysql备份与恢复

备份 mysqldump -uroot -p db >1.sql

恢复 mysql -uroot -p db <1.sql

只备份一个表 mysqldump -uroot -p db tb1 > 2.sql

备份时指定字符集 mysqldump -uroot -p --default-character-set=utf8 db >1.sql

恢复也指定字符集 mysql -uroot -p --default-character-set=utf8 db < 1.sql

扩展知识:

myisam 和innodb引擎对比 http://www.pureweber.com/article/myisam-vs-innodb/

一台mysql服务器启动多个端口 http://www.lishiming.net/thread-63-1-1.html

SQL语句教程 http://blog.51cto.com/zt/206

sql教程pdf文档 http://class.ccshu.net/00864091/ ... %95%99%E7%A8%8B.pdf

什么是事务?事务的特性有哪些? http://blog.csdn.net/yenange/article/details/7556094

mysql常用引擎 http://c.biancheng.net/cpp/html/1465.html

批量更改表的引擎 http://www.361way.com/change-mysql-engine/1729.html

mysql 二进制日志binlog的模式 http://lihuipeng.blog.51cto.com/3064864/833017

mysql根据binlog恢复指定时间段的数据 http://www.centoscn.com/mysql/2015/0204/4630.html

mysql字符集调整 http://xjsunjie.blog.51cto.com/999372/1355013

使用xtrabackup备份innodb引擎的数据库 http://www.aminglinux.com/bbs/thread-956-1-1.html

innobackupex 备份 Xtrabackup 增量备份 http://www.aminglinux.com/bbs/thread-1012-1-1.html

、概述

MySQL是世界上最受欢迎的开源数据库。凭借其经过验证的性能,可靠性和易用性,MySQL已成为基于Web的应用程序的领先数据库选择,涵盖了从个人项目和网站到电子商务和信息服务的所有范围,一直到备受瞩目。

官方仓库镜像:https://hub.docker.com/_/mysql



二、镜像说明

1.环境变量

启动mysql映像时,可以通过在docker run命令行上传递一个或多个环境变量来调整MySQL实例的配置。请注意,如果使用已包含数据库的数据目录启动容器,则以下任何变量都将无效:容器启动时,任何现有数据库都将保持不变。

另请参阅https://dev.mysql.com/doc/refman/5.7/en/environment-variables.html,以获取MySQL本身尊重的环境变量的文档(尤其是类似的变量MYSQL_HOST,该变量在与该映像一起使用时会引起问题) )。

  • MYSQL_ROOT_PASSWORD

此变量是必需变量,它指定将为MySQL root超级用户设置的密码。在上面的示例中,将其设置为my-secret-pw。

  • MYSQL_DATABASE

该变量是可选的,并允许您指定要在映像启动时创建的数据库的名称。如果提供了用户名/密码(请参阅下文),则将授予该用户对该数据库的超级用户访问权限(与相对应GRANT ALL)。

  • MYSQL_USER, MYSQL_PASSWORD

这些变量是可选的,与创建新用户和设置该用户的密码一起使用。将为该用户授予该MYSQL_DATABASE变量指定的数据库的超级用户权限(请参见上文)。这两个变量都是创建用户所必需的。

请注意,无需使用此机制来创建根超级用户,该用户默认情况下是使用MYSQL_ROOT_PASSWORD变量指定的密码创建的。

  • MYSQL_ALLOW_EMPTY_PASSWORD

这是一个可选变量。设置为非空值,例如yes,以允许使用root用户的空白密码启动容器。注意:yes除非您真的知道自己在做什么,否则不建议将此变量设置为,因为这将使您的MySQL实例完全不受保护,从而使任何人都可以获得完全的超级用户访问权限。

  • MYSQL_RANDOM_ROOT_PASSWORD

这是一个可选变量。设置为非空值,例如yes,以为root用户生成一个随机的初始密码(使用pwgen)。生成的root密码将被打印到stdout(GENERATED ROOT PASSWORD: .....)。

  • MYSQL_ONETIME_PASSWORD

初始化完成后,将root用户(不是MYSQL_USER!中指定的用户)设置为过期用户,从而在首次登录时强制更改密码。任何非空值都将激活此设置。注意:仅MySQL 5.6+支持此功能。在MySQL 5.5上使用此选项将在初始化期间引发适当的错误。

  • MYSQL_INITDB_SKIP_TZINFO

默认情况下,入口点脚本会自动加载该CONVERT_TZ()功能所需的时区数据。如果不需要,则任何非空值都将禁用时区加载。

2.注意事项

重要说明:有几种方法可以存储在Docker容器中运行的应用程序使用的数据。我们鼓励mysql图像用户熟悉可用的选项,包括:

  • 让Docker通过使用自己的内部卷管理将数据库文件写入主机系统上的磁盘,从而管理数据库数据的存储。这是默认设置,对用户来说是简单且相当透明的。不利之处在于,对于直接在主机系统(即外部容器)上运行的工具和应用程序而言,文件可能很难找到。
  • 在主机系统上(容器外部)创建一个数据目录,并将其安装到从容器内部可见的目录中。这会将数据库文件放置在主机系统上的已知位置,并使主机系统上的工具和应用程序易于访问文件。缺点是用户需要确保目录存在,并且例如必须正确设置主机系统上的目录权限和其他安全机制。



三、部署环境说明:

本文中使用本地VM虚机部署测试。

OS:CentOS Linux release 7.6.1810 (Core) 3.10.0-957.el7.x86_64

IP:192.168.168.100

Docker Version:v20.10.6

虚机配置:2核CPU、4G内存

注:①系统为最小化安装,部署前已完成系统初始化、内核及安全优化;

②Docker已安装。



四、部署MySQL-v5.7.34

1.拉取镜像

docker pull mysql:5.7.34

注:tag为5.7、5的目前(2021年04月25日前)都是5.7.34版本。


2.使用镜像构建MySQL容器

## 创建数据目录,用于挂载,实现数据持久化

mkdir -p /data/mysql

## 创建MySQL用户组、用户及修改挂载目录权限,防止容器启动时出现目录权限问题,用户组及用户MySQL是镜像内MySQL目录的属主和属组。也可不创建用户组及用户,修改宿主机用于挂载的目录权限为777即可。

groupadd -r mysql
useradd -g mysql -r -s /sbin/nologin -M -d /data/mysql mysql
chown -R mysql.mysql /data/mysql
chmod -R 0700 /data/mysql

## 创建配置文件,挂载替换容器内的配置文件,方便后续优化。

mkdir -p /etc/mysql
vi /etc/mysql/my.cnf
//输入以下配置内容
[client]
port = 3306
socket = /var/lib/mysql/mysql.sock
default-character-set = utf8mb4

[mysqld]
port = 3306
socket = /var/lib/mysql/mysql.sock
datadir = /var/lib/mysql
character-set-server = utf8mb4
collation-server = utf8mb4_general_ci
init_connect = 'SET NAMES utf8mb4'
server-id = 1
log-slave-updates=true
skip-external-locking
skip-name-resolve
back_log = 300
table_open_cache = 128
max_allowed_packet = 16M
read_buffer_size = 8M
read_rnd_buffer_size = 64M
sort_buffer_size = 16M
join_buffer_size = 8M
key_buffer_size = 128M
thread_cache_size = 16
log-bin = mysql-bin
binlog_format = row
######主从
log-slave-updates = true
######慢日志
slow_query_log = on
long_query_time = 1
slow_query_log_file = /var/lib/mysql/db-slow.log
gtid_mode = ON
enforce_gtid_consistency = ON
expire_logs_days = 7   
default_storage_engine = InnoDB
innodb_buffer_pool_size = 1G
innodb_data_file_path = ibdata1:10M:autoextend
innodb_file_per_table = on
innodb_write_io_threads = 4
innodb_read_io_threads = 4
innodb_thread_concurrency = 8
innodb_purge_threads = 1
innodb_flush_log_at_trx_commit = 1
innodb_log_buffer_size = 8M
innodb_log_file_size = 512M
innodb_log_files_in_group = 3
innodb_max_dirty_pages_pct = 90
innodb_lock_wait_timeout = 60
max_connections = 5000
interactive_timeout = 28800
wait_timeout = 28800
sql_mode = STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION
symbolic-links=0

[mysqldump]
quick
max_allowed_packet = 32M

[mysql]
no-auto-rehash
default-character-set = utf8mb4

[myisamchk]
key_buffer_size = 64M
sort_buffer_size = 64M
read_buffer = 8M
write_buffer = 8M

[mysqlhotcopy]
interactive-timeout

[mysqld_safe]
log-error = /var/lib/mysql/mysql_err.log
pid-file = /var/lib/mysql/mysqld.pid


备注:请根据实际环境需求修改参数,此处配置仅供参考。

## 构建容器

docker run -d --restart=always --name MySQL57 -p 3306:3306 \
 -v /etc/localtime:/etc/localtime \
 -v /data/mysql:/var/lib/mysql \
-v /etc/mysql:/etc/mysql \
-e MYSQL_ROOT_PASSWORD=123456 mysql:5.7.34

部分参数说明:

-p 3306:3306:将容器的 3306 端口映射到主机的 3306 端口。
-v /data/mysql:/var/lib/mysql :挂载数据目录,实现数据持久化。
-e MYSQL_ROOT_PASSWORD=123456 :初始化 root 用户的密码。


3.查看容器

docker ps -a


4.工具远程连接

本文中使用Navicat工具连接。构建容器时映射的端口防火墙默认已放开。

## Navicat新建MySQL连接

## 点击“测试连接”

## 连接成功如下图所示,即可在Navicat工具上进行创建\删除用户、数据库等其他操作,无需进入容器操作。


5.容器内相关操作

## 进入容器

docker exec -it MySQL57 /bin/bash

## 登录MySQL操作

mysql -uroot -p                   //输入密码登录MySQL

## 查看数据库

show databases;

## 查看用户

select user,host from mysql.user;



五、部署MySQL-v8.0.24

1.拉取镜像

docker pull mysql:8.0.24

注:tag为latest、8.0、8的目前(2021年04月28日前)都是8.0.24版本。


2.使用镜像构建MySQL容器

## 创建数据目录,用于挂载,实现数据持久化

注意:新版需要挂载 /var/lib/mysql-files/ 目录,否则无法启动容器。

mkdir -p /data/mysql/{data,mysql-files}

## 创建MySQL用户组、用户及修改挂载目录权限,防止容器启动时出现目录权限问题,用户组及用户MySQL是镜像内MySQL目录的属主和属组。也可不创建用户组及用户,修改宿主机用于挂载的目录权限为777即可。

groupadd -r mysql
useradd -g mysql -r -s /sbin/nologin -M -d /data/mysql mysql
chown -R mysql.mysql /data/mysql
chmod -R 0700 /data/mysql

## 创建配置文件,挂载替换容器内的配置文件,方便后续优化。

mkdir -p /etc/mysql
vi /etc/mysql/mysql8.cnf 
//输入以下配置内容
[client]
port = 3306
socket = /var/lib/mysql/mysql.sock
default-character-set=utf8mb4

[mysqld]
port = 3306
user = mysql
socket = /var/lib/mysql/mysql.sock
datadir = /var/lib/mysql
character-set-server = utf8mb4
collation-server = utf8mb4_general_ci
init_connect = 'SET NAMES utf8mb4'
lower_case_table_names = 1
skip-external-locking
skip-name-resolve
server-id = 1
transaction_isolation = REPEATABLE-READ
explicit_defaults_for_timestamp = true
thread_stack = 512K
external-locking = FALSE
gtid_mode = ON
enforce_gtid_consistency = ON
##最大连接数
max_connections=5000
max_connect_errors = 1000
back_log = 300
##二进制日志
log-bin = /var/lib/mysql/mysql-bin
binlog_format = ROW
binlog_row_image = FULL
binlog_expire_logs_seconds = 0
binlog_cache_size=16M
max_binlog_cache_size=1G
max_binlog_size=512M
sync_binlog = 1
##慢日志
slow_query_log = on
slow_query_log_file = /var/lib/mysql/db-slow.log
long_query_time = 1
log_slow_admin_statements = 1
#作为从库时生效
log_slow_slave_statements = 1
log-queries-not-using-indexes=0
log_throttle_queries_not_using_indexes=60
##缓冲区
table_open_cache = 600
table_definition_cache = 700
table_open_cache_instances = 64
max_allowed_packet = 32M
sort_buffer_size = 16M
join_buffer_size = 8M
tmp_table_size = 64M
max_heap_table_size = 64M
##对MyISAM表起作用
key_buffer_size = 128M
read_buffer_size = 8M
read_rnd_buffer_size = 32M
bulk_insert_buffer_size = 64M
thread_cache_size = 16
##主从复制配置
log_slave_updates=1
relay-log = /var/lib/mysql
master-info-repository=TABLE
relay-log-info-repository=TABLE
relay-log-recovery=on
##innodb性能设置
default_storage_engine = InnoDB
innodb_thread_concurrency = 0
innodb_buffer_pool_size = 1G
innodb_buffer_pool_instances = 8
innodb_buffer_pool_load_at_startup = 1
innodb_buffer_pool_dump_at_shutdown = 1
innodb_data_file_path = ibdata1:10M:autoextend
innodb_log_buffer_size = 16M
innodb_log_files_in_group = 3
innodb_log_file_size = 512M
innodb_undo_log_truncate = 1
innodb_max_undo_log_size = 4G
#innodb_undo_directory = /var/lib/mysql/undolog
##CPU多核处理能力设置,假设CPU是2颗8核的,设置如下
innodb_write_io_threads = 8
innodb_read_io_threads = 8
innodb_purge_threads = 4
innodb_page_cleaners = 4
innodb_open_files = 65535
innodb_max_dirty_pages_pct = 50
#innodb_flush_method = O_DIRECT
innodb_lock_wait_timeout = 60
innodb_rollback_on_timeout = 1
innodb_print_all_deadlocks = 1
innodb_autoinc_lock_mode = 1
innodb_file_per_table = on
innodb_flush_log_at_trx_commit = 1
##设置时区
default_time_zone = "+8:00"
##超时时间
interactive_timeout = 3600
wait_timeout = 3600
##默认使用“mysql_native_password”插件认证
#default_authentication_plugin = mysql_native_password

[mysqldump]
quick
max_allowed_packet = 64M

[mysql]
no-auto-rehash
default-character-set = utf8mb4

[myisamchk]
key_buffer_size = 64M
sort_buffer_size = 64M
read_buffer = 8M
write_buffer = 8M

[mysqlhotcopy]
interactive-timeout

[mysqld_safe]
log-error = /var/lib/mysql/mysql_err.log
pid-file = /var/lib/mysql/mysqld.pid

备注:请根据实际环境需求修改参数,此处配置仅供参考。

镜像内默认配置文件是 /etc/mysql/my.cnf 文件。如果想要自定义配置,建议向 /etc/mysql/conf.d 目录中创建 .cnf 文件。新建的文件可以任意起名,只要保证后缀名是 .cnf 即可。新建的文件中的配置项可以覆盖 /etc/mysql/my.cnf 中的配置项。 当然也可以向 /etc/mysql 目录中挂载在宿主机上创建的 my.cnf 文件,直接覆盖所有默认配置文件。

## 构建容器

docker run -d --restart=always --name MySQL8 -p 3306:3306 \
-v /etc/localtime:/etc/localtime \
-v /data/mysql/data:/var/lib/mysql \
-v /data/mysql/mysql-files:/var/lib/mysql-files \
-v /etc/mysql:/etc/mysql/conf.d \
-e MYSQL_ROOT_PASSWORD=123456 mysql:8.0.24

部分参数说明:

-p 3306:3306:将容器的 3306 端口映射到主机的 3306 端口。
-v /data/mysql/data:/var/lib/mysql :挂载数据目录,实现数据持久化。
-e MYSQL_ROOT_PASSWORD=123456 :初始化 root 用户的密码。


3.查看容器

docker ps -a


4.配置远程操作权限

Navicat等工具远程连接MySQL不支持caching_sha2_password加密方法,需修改为 mysql_native_password 加密方式并重置密码。

## 进入容器

docker exec -it MySQL8 /bin/bash

## 登录MySQL操作

mysql -uroot -p 
//输入密码123456进入数据库
 mysql> use mysql;
 mysql> alter user 'root'@'%' identified by '123456' password expire never;
 mysql> alter user 'root'@'%' identified with mysql_native_password by '123456';
 mysql> flush privileges;


5.工具远程连接

请参考5.7版本中的相关操作步骤。