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

相关推荐
AC赳赳老秦7 小时前
用 OpenClaw 搭建服务器故障应急响应系统,自动处理 80% 常见运维故障
android·运维·服务器·python·rxjava·deepseek·openclaw
Database_Cool_7 小时前
什么是数据仓库物化视图?AnalyticDB MySQL 实时物化视图能力解析
人工智能·mysql·阿里云
2601_961875247 小时前
决战申论100题2026|最新|范文
linux·容器·centos·debian·ssh·fabric·vagrant
java_cj7 小时前
深入kube-apiserver认证机制:从Bearer Token到mTLS的完整认证链解析
linux·运维·服务器·云原生·容器·kubernetes
Database_Cool_7 小时前
即席查询(Ad-Hoc)数据库选型:AnalyticDB MySQL 秒级 Ad-Hoc 分析方案
数据库·mysql
一杯奶茶¥7 小时前
水果销售网站 CRM客户信息管理系统 超市管理系 酒店管理系统 健身房管理系统 在线音乐网站 校园招聘系统
java·vue.js·spring boot·mysql·spring·java项目
张飞飞飞飞飞7 小时前
Tmux命令使用教程
linux·服务器·ubuntu
程序员老赵8 小时前
服务器没有桌面?Docker 跑个 Chrome,浏览器就能远程用
docker·容器·devops
用户800391387838 小时前
使用 Gemini 解决 MySQL 常见问题
mysql
難釋懷8 小时前
Nginx反向代理中的容错机制
运维·nginx