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目录下

相关推荐
YRr YRr1 分钟前
解决Ubuntu 20.04上编译OpenCV 3.2时遇到的stdlib.h缺失错误
linux·opencv·ubuntu
G_whang2 分钟前
centos7下docker 容器实现redis主从同步
redis·docker·容器
认真学习的小雅兰.3 分钟前
如何在Ubuntu上利用Docker和Cpolar实现Excalidraw公网访问高效绘图——“cpolar内网穿透”
linux·ubuntu·docker
zhou周大哥19 分钟前
linux 安装 ffmpeg 视频转换
linux·运维·服务器
nbsaas-boot24 分钟前
探索 JSON 数据在关系型数据库中的应用:MySQL 与 SQL Server 的对比
数据库·mysql·json
奥顺43 分钟前
PHPUnit使用指南:编写高效的单元测试
大数据·mysql·开源·php
the丶only1 小时前
单点登录平台Casdoor搭建与使用,集成gitlab同步创建删除账号
linux·运维·服务器·docker·gitlab
书生-w1 小时前
Docker部署GitLab服务器
服务器·docker·gitlab
塔克拉玛攻城狮1 小时前
私有网盘+在线文档:内网离线搭建NextCloud+OnlyOffice详细指南
docker·在线文档·网盘
ccubee2 小时前
docker 安装 ftp
运维·docker·容器