首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >虚拟机中使用docker部署MySql8.0并进行连接与设置允许远程连接

虚拟机中使用docker部署MySql8.0并进行连接与设置允许远程连接

作者头像
工藤学编程
发布2025-12-22 09:31:34
发布2025-12-22 09:31:34
1680
举报

大家好,我是工藤学编程 🦉

一个正在努力学习的小博主,期待你的关注

实战代码系列最新文章😉

C++实现图书管理系统(Qt C++ GUI界面版)

SpringBoot实战系列🐷

【SpringBoot实战系列】Sharding-Jdbc实现分库分表到分布式ID生成器Snowflake自定义wrokId实战

环境搭建大集合

环境搭建大集合(持续更新)

分库分表

分库分表技术栈讲解-Sharding-JDBC


一、docker的安装

1、Ubuntu

代码语言:javascript
复制
# 更新包索引
sudo apt update

# 安装必要的依赖
sudo apt install -y apt-transport-https ca-certificates curl software-properties-common

# 添加 Docker 官方 GPG 密钥
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg

# 添加 Docker 软件源
echo "deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null

# 更新包索引(包含新添加的 Docker 源)
sudo apt update

# 安装 Docker CE
sudo apt install -y docker-ce docker-ce-cli containerd.io
#执行以下命令,检查Docker是否安装成功。
sudo docker -v

#执行以下命令,启动Docker服务,并设置开机自启动。
sudo systemctl start docker
sudo systemctl enable docker

#执行以下命令,查看Docker是否启动。
sudo systemctl status docker

最终执行结果如下,说明我们成功安装docker

在这里插入图片描述
在这里插入图片描述

安装成功之后,我们还需要配置镜像加速

代码语言:javascript
复制
([ -f /etc/docker/daemon.json ] || mkdir -p /etc/docker) && echo '{ "registry-mirrors" : [ "https://docker.m.daocloud.io", "https://noohub.ru", "https://huecker.io", "https://dockerhub.timeweb.cloud" ] }' > /etc/docker/daemon.json && sudo systemctl restart docker && sleep 1 && docker info | grep -A 4 "Registry Mirrors"
镜像加速报权限不够错误解决

我这里执行镜像加速命令报/etc/docker/deamon.json权限不够

在这里插入图片描述
在这里插入图片描述

这是因为直接使用 > 重定向符号尝试写入受保护的系统文件,而没有使用 sudo 提升权限。 要解决这个问题,你需要使用 sudo 来执行文件写入操作。以下是修正后的命令:

代码语言:javascript
复制
([ -f /etc/docker/daemon.json ] || sudo mkdir -p /etc/docker) && \
echo '{ "registry-mirrors" : [ "https://docker.m.daocloud.io", "https://noohub.ru", "https://huecker.io", "https://dockerhub.timeweb.cloud" ] }' | \
sudo tee /etc/docker/daemon.json > /dev/null && \
sudo systemctl restart docker && \
sleep 1 && \
docker info | grep -A 4 "Registry Mirrors"
用户没有权限访问 Docker 守护进程导致没有权限访问docker解决

执行修改后的命令之后,仍有报错

在这里插入图片描述
在这里插入图片描述

解决方案:

代码语言:javascript
复制
# 添加当前用户到 docker 组
sudo usermod -aG docker $USER

# 刷新用户组(立即生效)
newgrp docker

# 验证权限
docker info | grep -A 4 "Registry Mirrors"
在这里插入图片描述
在这里插入图片描述

docker安装成功!

2、Red Hat/CentOS

代码语言:javascript
复制
#运行以下命令,下载docker-ce的yum源。
sudo wget -O /etc/yum.repos.d/docker-ce.repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

#运行以下命令,安装Docker。
sudo yum -y install docker-ce

#执行以下命令,检查Docker是否安装成功。
sudo docker -v

#执行以下命令,启动Docker服务,并设置开机自启动。
sudo systemctl start docker
sudo systemctl enable docker

#执行以下命令,查看Docker是否启动。
sudo systemctl status docker

#配置Docker镜像加速
([ -f /etc/docker/daemon.json ] || mkdir -p /etc/docker) && echo '{ "registry-mirrors" : [ "https://docker.m.daocloud.io", "https://noohub.ru", "https://huecker.io", "https://dockerhub.timeweb.cloud" ] }' > /etc/docker/daemon.json && sudo systemctl restart docker && sleep 1 && docker info | grep -A 4 "Registry Mirrors"

二、docker部署Mysql8.0与配置连接

1、docker部署Mysql(切换为root用户)

代码语言:javascript
复制
#创建目录
mkdir -p /home/data/mysql/
#创建配置文件
touch /home/data/mysql/my.cnf

#部署
docker run \
    -p 3306:3306 \
    -e MYSQL_ROOT_PASSWORD=123456 \
    -v /home/data/mysql/conf:/etc/mysql/conf.d \
    -v /home/data/mysql/data:/var/lib/mysql:rw \
    -v /home/data/mysql/my.cnf:/etc/mysql/my.cnf \
    --name ccc_mysql \
    --restart=always \
    -d mysql:8.0

-e MYSQL_ROOT_PASSWORD=123456 记得将123456修改为自己想要设置的密码 –name ccc_mysql ccc_mysql可以修改为自己想要的容器名称

2、虚拟机中使用Mysql

安装 MySQL 客户端
  1. Ubuntu/Debian 系统
代码语言:javascript
复制
sudo apt update
sudo apt install mysql-client -y
  1. CentOS/RHEL 系统
代码语言:javascript
复制
sudo yum localinstall https://dev.mysql.com/get/mysql80-community-release-el7-5.noarch.rpm

sudo yum install mysql-community-client -y

安装完成后,通过以下命令验证客户端是否正常工作:

代码语言:javascript
复制
mysql --version
在这里插入图片描述
在这里插入图片描述
连接mysql
代码语言:javascript
复制
mysql -h 127.0.0.1 -P 3306 -u root -p

输入密码后连接成功

在这里插入图片描述
在这里插入图片描述

三、配置远程访问

编辑挂载的配置文件 /home/data/mysql/my.cnf:

代码语言:javascript
复制
vim /home/data/mysql/my.cnf

vim需要先键盘点击 i,然后把内容进行修改,修改完成后使用esc键退出编辑,然后再输入:wq,报错并退出

添加或修改以下内容:

代码语言:javascript
复制
[mysqld]
bind-address = 0.0.0.0  # 允许所有IP访问

重启 MySQL 容器使配置生效:

代码语言:javascript
复制
docker restart ccc_mysql

ccc_mysql记得改成自己的容器名称

确保容器端口正确映射

代码语言:javascript
复制
docker ps | grep ccc_mysql
# 输出应包含类似: 0.0.0.0:3306->3306/tcp

开放防火墙端口(如果有防火墙)如果虚拟机启用了防火墙(如 Ubuntu 的 ufw),开放 3306 端口:

代码语言:javascript
复制
sudo ufw allow 3306/tcp
sudo ufw reload

验证远程连接是否成功

大家可以通过 MySQL 客户端工具尝试,这里我通过java代码尝试,插入数据成功!

在这里插入图片描述
在这里插入图片描述

觉得有用请点赞收藏! 如果有相关问题,欢迎评论区留言讨论~

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2025-06-30,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、docker的安装
    • 1、Ubuntu
      • 镜像加速报权限不够错误解决
      • 用户没有权限访问 Docker 守护进程导致没有权限访问docker解决
    • 2、Red Hat/CentOS
  • 二、docker部署Mysql8.0与配置连接
    • 1、docker部署Mysql(切换为root用户)
    • 2、虚拟机中使用Mysql
      • 安装 MySQL 客户端
      • 连接mysql
  • 三、配置远程访问
    • 验证远程连接是否成功
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档