Ubuntu22.04在Docker下安装Mysql5.7

Ubuntu22.04在Docker下安装Mysql5.7

通常在项目研发阶段为了开发测试方便此处mysql安装在docker下(便于移至和扩展比较灵活),必须要注意在生产环境中不推荐直接安装在docker下

打开官网地址:https://hub.docker.com/(需要挂vpn科学上网)

搜索mysql选择5.7.44进行下载(其他myql版本类似操作,例如下安装mysql8.0x版本同理)

下载mysql5.7.44镜像

docker pull mysql:5.7.44 拉取镜像
docker images 查看当前已有镜像

启动mysql容器

docker run [启动参数] IMAGE [镜像启动的运行命令(一般不写)]

使用如下命令来启动mysql容器(端口映射、文件挂载、密码设置、数据库格式):

docker run -p 3306:3306 --name mysql \
-v /home/mysql5.7/log:/var/log/mysql \
-v /home/mysql5.7/data:/var/lib/mysql \
-v /home/mysql5.7/conf:/etc/mysql \
-v /home/mysql5.7/mysql-files:/var/lib/mysql-files \
-e MYSQL_ROOT_PASSWORD=root \
-d mysql:5.7.44 \
--character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci
  • docker run: 运行一个容器,每个容器相互隔离,他都是独立的运行环境,是一个完整的实例。

  • -p 3306:3306:把mysql容器自己的端口映射到虚拟主机,这样我们才能访问,这是端口映射。(左侧是本地端口:右侧是docker容器里的端口)

  • --name mysql:为容器取名,这个名字随意。

  • -v:文件路径的挂载。(数据库文件,日志,配置文件)

  • -e MYSQL_ROOT_PASSWORD:添加环境参数,比如密码。

  • d mysql:5.7.44:在后端运行,指定使用的是哪个镜像。

通过命令进入mysql docker exec -it mysql bash,进入mysql命令模式后输入ls /查看目录

可以看到,这相当于是一个独立的linux文件目录树结构,那么我们要设置挂载路径,就是把mysql内部的文件映射到我们在外部的,也就是咱们自己的虚拟机里的路径,这样会更加方便的查看以及修改。相当于是创建了一个文件夹的快捷方式。

查看当前docker运行的容器docker ps

查看当前docker运行的包含抱错的容器docker ps -a,可以看到在创建的第一秒mysql服务就已经退出了

查看docker容器下的mysql日志寻找报错信息,发现无法创建文件目录

首先移除mysql容器docker rm mysql

删除运行容器时的conf文件目录挂载

docker run -p 3306:3306 --name mysql \
-v /home/mysql5.7/log:/var/log/mysql \
-v /home/mysql5.7/data:/var/lib/mysql \
-v /home/mysql5.7/mysql-files:/var/lib/mysql-files \
-e MYSQL_ROOT_PASSWORD=root \
-d mysql:5.7.44 \
--character-set-server=utf8mb4 \
--collation-server=utf8mb4_unicode_ci

可以看到容器运行成功,端口已经成功映射

查看docker容器运行的状态docker stats

输入docker exec -it mysql bash通过docker进入mysql

输入mysql -u root -p进入mysql命令模式,输入之前设置的密码root

输入use mysql;进入mysql数据库

输入如下命令修改数据库的访问密码

alter user 'root'@'localhost' identified with mysql_native_password by 'lvdamaoluguo';

给root账户授予所有权限

grant all privileges on test_grant.* to 'root'@'%' with grant option;

修改root账户外部访问权限密码模式

ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'lvdamaoluguo';

输入flush privileges;刷新配置

使用Navicat重新连接数据库后输入重新设置好的密码输入以下代码查看

sql 复制代码
SELECT `host`,`user`,`plugin` FROM `user`

本地桌面新建my.cnf文件设置mysql字符集,使用记事本打开复制如下代码保存

[client]
port=3306
default_character_set=utf8mb4

[mysql]
default_character_set=utf8mb4

[mysqld]
character-set-server=utf8mb4
collation-server=utf8mb4_unicode_ci
skip-character-set-client-handshake

kip-name-resovle: mysql连接慢,不把ip地址解析为域名,无用,有问题
skip-character-set-client-handshake: 忽略客户端的字符集,使用服务器的设置

使用xftp文件传输工具传入至服务器上的/home/mysql5.7/conf目录下

相关推荐
爱学习的白杨树11 分钟前
MySQL中有哪几种锁?
数据库·mysql
MXsoft6181 小时前
华为服务器(iBMC)硬件监控指标解读
大数据·运维·数据库
颜淡慕潇1 小时前
【K8S系列】kubectl describe pod显示ImagePullBackOff,如何进一步排查?
后端·云原生·容器·kubernetes
1900431 小时前
linux6:常见命令介绍
linux·运维·服务器
wanmei0021 小时前
Dockerfile复制目录进入镜像里
docker
inter_peng1 小时前
[Docker-显示所有容器IP] 显示docker-compose.yml中所有容器IP的方法
tcp/ip·docker·eureka
Camellia-Echo1 小时前
【Linux从青铜到王者】Linux进程间通信(一)——待完善
linux·运维·服务器
Linux运维日记1 小时前
k8s1.31版本最新版本集群使用容器镜像仓库Harbor
linux·docker·云原生·容器·kubernetes
嚯——哈哈2 小时前
轻量云服务器:入门级云计算的最佳选择
运维·服务器·云计算
我是唐青枫2 小时前
Linux dnf 包管理工具使用教程
linux·运维·服务器