Docker 之mysql从头开始——Docker下mysql安装、启动、配置、进入容器执行(查询)sql

一、Docker 之mysql安装配置

步骤一:拉取镜像

  1. 查看是否包含已安装的mysql。

docker images | grep mysql

  1. 如上图所示,我们有mysql镜像,所以不必对mysql镜像进行拉取,如若没有上图中的惊喜,使用如下命令进行拉取(8.0.20是mysql版本号,根据自己需求填写即可):

docker pullmysql:8.0.20

步骤二:启动镜像

  1. 启动镜像,这里面最后的":latest"是根据步骤一中"1"截图中的版本来的,可根据自己情况输入。启动容器的同时将/data/yueshen5/codeProgram/KG-2.2-C中的文件挂载到容器中的/data目录下

docker run-v /data/yueshen5/codeProgram/KG-2.2-C:/data -p 3306:3306 --name mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql:latest

以下命令是没有挂载操作的命令,如需挂载如上述命令所示

  1. 查看是否启动成功

步骤三:拷贝配置文件

启动成功后,进入容器内部拷贝配置文件到宿主主机。因此,在宿主主机中需要提前创建存储配置文件的文件夹,这里我们使用mysqllatest存储

mkdir mysqllatest

docker cp mysql:/etc/mysql /data/yueshen5/codeProgram/KG-2.2-C/mysqllatest

步骤四:删除mysql容器,重新创建容器

docker stop mysql

docker rm mysql

步骤五:启动mysql ,挂载配置文件,数据持久化到宿主主机

  1. 在系统目录下创建并运行脚本文件mysqllatest.sh,输入命令sh mysqllatest.sh

#!/bin/sh

docker run

-v /data/yueshen5/codeProgram/KG-2.2-C:/data

-p 3306:3306

--name mysql

--privileged=true

--restart unless-stopped

-v /data/yueshen5/codeProgram/KG-2.2-C/mysqllatest/mysql:/etc/mysql

-v /data/yueshen5/codeProgram/KG-2.2-C/mysqllatest/logs:/logs

-v /data/yueshen5/codeProgram/KG-2.2-C/mysqllatest/data:/var/lib/mysql

-v /etc/localtime:/etc/localtime

-e MYSQL_ROOT_PASSWORD=123456

-d mysql:latest

命令解释:

挂载本地文件

-v /data/yueshen5/codeProgram/KG-2.2-C:/data

端口映射

-p 3306:3306

挂载文件权限设置

--privileged=true

设置 开机后自动重启容器

--restart unless-stopped

挂载配置文件

-v /data/yueshen5/codeProgram/KG-2.2-C/mysqllatest/mysql:/etc/mysql

挂载日志

-v /data/yueshen5/codeProgram/KG-2.2-C/mysqllatest/logs:/logs

挂载数据文件 持久化到主机

-v /data/yueshen5/codeProgram/KG-2.2-C/mysqllatest/data:/var/lib/mysql

容器时间与宿主机同步

-v /etc/localtime:/etc/localtime

设置密码

-e MYSQL_ROOT_PASSWORD=123456

后台启动mysql:latest

-d mysql:latest

  1. 查看是否启动成功

docker ps -a

二、Docker 之进入容器执行sql

  1. 进入容器,并进入mysql数据库

docker exec -it mysql bash #mysql 是容器名

mysql -u root -p密码 #mysql没有任何含义,这只是进入mysql的必须命令

  1. 查看数据库

show databases;

  1. 使用数据库,在数据库里对表格进行增删改查操作

use mysql; # 此处mysql是数据库的名字

show tables; # 查看数据库中包含的表格

  1. 创建数据库

create database test; #test是数据库的名字

  1. 创建表格
  1. 向表格插入数据

三、和NAVICAT进行连接以及执行sql文件方法

可参考:

Docker 之mysql从头开始------Docker下mysql安装、启动、配置、恢复备份sql、进入容器执行(查询)sql_docker mysql 查看数据库-CSDN博客

相关推荐
暴力求解15 分钟前
Mysql数据库基础
数据库·mysql·操作系统
SpikeKing32 分钟前
LLM - 集成 Hermes Agent 与 WebUI 至同一个 Docker 镜像配置
docker·webui·vibecoding·hermes agent
意倾城42 分钟前
MySQL最左前缀匹配原则
数据库·mysql
暴躁小师兄数据学院1 小时前
【AI大数据工程师特训笔记】第13讲:数据库性能手术刀
大数据·数据库·数据仓库·sql·postgresql
杨浦老苏1 小时前
网络连接实时可视化利器TapMap
网络·docker·可视化·监控·群晖
香气袭人知骤暖2 小时前
PG数据库 Docker 容器自动备份方案
数据库·docker·容器
AI服务老曹2 小时前
解耦异构算力:基于 Docker 与 GB28181/RTSP 的边缘计算 AI 视频管理平台架构设计与源码交付实践
人工智能·docker·边缘计算
weixin_468466853 小时前
Prometheus监控服务部署与实战指南
服务器·后端·python·docker·自动化·prometheus
土狗TuGou3 小时前
SQL内功笔记 · 第2篇:列的约束
数据库·笔记·sql
java_cj3 小时前
MySQL 执行原理深度剖析:查询成本计算与优化器内幕
数据库·后端·mysql