【MAC】M2 安装docker 与 mysql

一、docker下载地址

下载地址

二、安装docker完成

罗列一下docker常用命令

shell 复制代码
# 查看docker版本
docker --version

# 拉取镜像
docker pull 镜像名

# 查看当前所有镜像
docker images

# 查看运行中的容器
docker ps -a
docker ps grep| 镜像名

#镜像启动操作:
sudo docker start 镜像名
sudo docker stop 镜像名
sudo docker restart 镜像名

# 删除镜像
docker rm 镜像名/镜像id

# 进入容器内部
docker exec -it 镜像名/镜像id /bin/bash

# 宿主机复制文件到镜像内部
docker cp 文件 容器id:/etc/
docker cp text.txt c10fec6c05d0:/etc/

三、安装mysql

一、拉取镜像

复制代码
# 拉取镜像
docker pull mysql
 
# 或者
docker pull mysql:latest
 
# 以上两个命令是一致的,默认拉取的就是 latest 版本的
 
# 我们还可以用下面的命令来查看可用版本:
docker search mysql

二、查看镜像

使用以下命令来查看是否已安装了 mysql镜像

复制代码
docker images

三、运行镜像

初始化时运行以下文件:

复制代码
docker run --name mysql --restart=always --privileged=true \
-v /usr/local/mysql/data:/var/lib/mysql \
-v /usr/local/mysql/conf.d:/etc/mysql/conf.d \
-v /etc/localtime:/etc/localtime:ro \
-e MYSQL_ROOT_PASSWORD=123456 -p 3306:3306 -d mysql:latest

修改容器配置文件:

复制代码
# 查看正在运行的容器
docker ps
# 查看所有的docker容器
docker ps -a

进入容器内部:

复制代码
docker exec -it mysql /bin/bash

查看本地是否有配置文件:

复制代码
/usr/local/mysql/conf/my.cnf

如果没有创建一个my.cnf:

复制代码
vi my.cnf

[client]

default-character-set=utf8mb4

[mysql]

default-character-set=utf8mb4

[mysqld]

# 设置东八区时区
default-time_zone = '+8:00'

# 设置密码验证规则,default_authentication_plugin参数已被废弃

# 改为authentication_policy

#default_authentication_plugin=mysql_native_password
authentication_policy=mysql_native_password

# 限制导入和导出的数据目录
# 为空,不限制导入到处的数据目录;
# 指定目录,必须从该目录导入到处,且MySQL不会自动创建该目录;
# 为NULL,禁止导入与导出功能
#secure_file_priv=/var/lib/mysql
secure_file_priv=

init_connect='SET collation_connection = utf8mb4_0900_ai_ci'

init_connect='SET NAMES utf8mb4'

character-set-server=utf8mb4

collation-server=utf8mb4_0900_ai_ci

skip-character-set-client-handshake

skip-name-resolve

复制文件到容器内部:

复制代码
docker cp my.cnf 容器id:/etc/mysql/conf.d/

在进入容器内部:

复制代码
docker exec -it mysql /bin/bash
复制代码
exit 退出

四、设置docker启动时启动mysql

复制代码
docker update mysql --restart=always

五、重启mysql

复制代码
docker restart mysql

四、授权访问问题

一、进入容器

复制代码
docker exec -it mysql /bin/bash

此时我们使用mysql客户端连接服务器是失败的,因为默认的root不具有远程连接的权限。

上面的密码不要输入,直接回车进入。

二、选择数据库

复制代码
show databases;
use mysql;

三、查看用户连接情况

复制代码
select host, user, plugin,  authentication_string, password_expired from user;

四、修改密码认证方式

复制代码
ALTER USER root@'%' IDENTIFIED WITH mysql_native_password BY '123456';
 
ALTER USER root@'localhost' IDENTIFIED WITH mysql_native_password BY '123456';
 
-- 刷新权限
FLUSH PRIVILEGES;

-- 退出
exit

五、重启 再试试

复制代码
docker restart mysql

六、错误解决

1、Unable to load authentication plugin 'caching_sha2_password'.

修改两个地方:

1、mysql5.6,升级到8.0,连接数据库就报错:,修改pom.xml中的 mysql-connector-java 版本为8.x.xx

2、修改项目中数据库连接配置文件,改为 com.mysql.cj.jdbc.Driver

相关推荐
sc.溯琛6 小时前
MySQL 高级实战:触发器、事务与数据库备份恢复全攻略
android·adb
韩立学长7 小时前
【开题答辩实录分享】以《自助游网站的设计与实现》为例进行选题答辩实录分享
java·mysql·spring
q_19132846959 小时前
基于Springboot+MySQL+RuoYi的会议室预约管理系统
java·vue.js·spring boot·后端·mysql·若依·计算机毕业设计
学海_无涯_苦作舟9 小时前
MySQL面试题
数据库·mysql·面试
君子剑mango10 小时前
MySQL8.0 窗口函数
数据库·mysql
vortex511 小时前
ORM是什么?如何理解ORM?ORM的优缺点?
java·数据库·sql·mysql·oracle·orm
九章-11 小时前
国企国产化替代标杆实践:金仓数据库赋能贵州磷化EMS系统自主可控升级
数据库·mysql·安全
天庭鸡腿哥12 小时前
国外软件,安装即时专业版!
stm32·microsoft·macos·everything
麦麦鸡腿堡14 小时前
Java_MySQL介绍
java·开发语言·mysql
程序员阿鹏15 小时前
MySQL中给字段添加唯一约束的方式有哪些?
android·数据库·mysql