docker上面安装mysql

一、docker安装mysql

新建配置 /data/mysql3306/conf/my.cnf(新建logs,data,conf/my.cnf 后面要用)

docker上面安装mysql_第1张图片

 详情:

[mysql]
#设置mysql客户端默认字符集
default-character-set=UTF8MB4

[mysqld]
#设置3306端口
port=3306

#允许最大连接数
max_connections=200

#允许连接失败的次数
max_connect_errors=10

#默认使用“mysql_native_password”插件认证
default_authentication_plugin=mysql_native_password

#服务端使用的字符集默认为8比特编码的latin1字符集
character-set-server=UTF8MB4

#开启查询缓存
explicit_defaults_for_timestamp=true

#创建新表时将使用的默认存储引擎
default-storage-engine=INNODB

#等待超时时间秒
wait_timeout=60

#交互式连接超时时间秒
interactive-timeout=600
secure_file_priv=/var/lib/mysql

[client]
default-character-set=UTF8MB4

 执行启动和挂载mysql (需要修改密码,整体复制)

docker run  --privileged -d -p 3306:3306 -v /data/dockerData/mysql3306/conf/my.cnf:/etc/mysql/my.cnf -v /data/dockerData/mysql3306/logs:/logs -v /data/dockerData/mysql3306/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=数据库密码 --name mysql3306 mysql:5.7

详情(上述具体含义):

--privileged 使用该参数,container内的root拥有真正的root权限。否则,container内的root只是外部的一个普通用户权限。privileged启动的容器,可以看到很多host上的设备,并且可以执行mount。甚至允许你在docker容器中启动docker容器。

-d:以后台方式运行实例。

配置端口映射:
-p 3306:3306
将容器的3306端口映射到主机的3306端口。


配置mysql数据卷挂载
1.-v /data/dockerData/mysql3306/logs:/logs(日志文件挂载)
将容器中的日志文件夹/var/log/mysql挂载到主机对应的/mydata/mysql文件夹中。
2.-v /data/dockerData/mysql3306/data:/var/lib/mysql(数据文件挂载)
将容器中的数据文件夹/var/lib/mysql挂载到主机对应的/mydata/mysql/data文件夹中。
3.-v /data/dockerData/mysql3306/conf/my.cnf:/etc/mysql/my.cnf(配置文件挂载)
将容器的配置文件夹/etc/mysql挂载到主机对应的/mydata/mysql/conf文件夹中。
注(这里所提的主机指的是当前的linux主机)。

MYSQL_ROOT_PASSWORD=数据库密码

设置数据库root的密码。

--name mysql3306

设置mysql容器名称。


mysql:5.7:指定用这个镜像来创建运行实例。

执行到这里就可以用连接工具 mysql Workbentch 连接

常用docker命令学习

###常用docker命令学习
#0. 查看docker 版本
docker version

#1. 拉取镜像 (后面5.7是指定版本,默认是latest最新)
docker pull mysql:5.7

#1. 查看运行的容器 (检查容器是否正在运行)
docker ps

#1. 查看运行的容器 (检查容器是否正在运行)
docker ps

#1. 查看运行的容器 (检查容器是否正在运行)
docker ps

#2. 查看所有容器(包括未运行的)
docker ps -a 

#3. 刪除容器 (前三位的容器id就行,全部输也行)
docker rm 19c

#4. 停止运行容器
docker stop 39c

#5. 启动容器
docker start 39c

#执行. 重启容器 (也可以用容器的名称代替)
docker start 39c

#5. 重启容器 (也可以用容器的名称代替)
docker start 39c

#5. 重启容器 (也可以用容器的名称代替)
docker start 39c

#5. 查看容器日志 (执行了启动容器,但是通过docker ps发现没启动成功,可以通过此命令查看具体日志)
docker start 39c

# 查看Mysql容器的数据目录
docker inspect mysql | grep -i datadir

#进入容器内部
docker exec -it [容器id/容器名称] /bin/bash

#进入之后通过命令查看是否可以访问成功
curl http://localhost:容器端口号

docker上面安装mysql_第2张图片

 docker上面安装mysql_第3张图片

 

 

你可能感兴趣的:(linux,运维,服务器)