容器部署MySQL

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: docker run -d --name mysql --restart always \ -e MYSQL_ROOT_PASSWORD=admin \ -e TZ=Asia/Shanghai -p 3306:3306 \ -v /data/mysql:/var/lib/mysql \ mysql:5.7.31 \ --character-set-server=utf8 \ --collation-server=utf8_general_ci

1673477237447.png

一、镜像准备

mysql镜像下载地址:https://hub.docker.com/_/mysql

这里以下载5.7.31为例

docker pull mysql:5.7.31

下载后可以通过命令查看

docker images

可以将下载好的命令保存为本地文件,方便日后使用,避免重复下载(会保存在当前目录下)

docker save mysql:5.7.31 -o mysql.5.7.31.tar

可以将保存的镜像文件加载

docker load -i mysql.5.7.31.tar

二、一个简单的实例

运行实例

docker run -d --name mysql --restart always \
-e MYSQL_ROOT_PASSWORD=admin \
-e TZ=Asia/Shanghai -p 3306:3306 \
-v /data/mysql:/var/lib/mysql \
mysql:5.7.31 \
--character-set-server=utf8 \
--collation-server=utf8_general_ci

说明:

  • name mysql 指定实例名称 “mysql” 可以根据需要更改
    restart always 容器退出时总是重启容器
    e MYSQL_ROOT_PASSWORD=admin 配置root用户的密码为 “admin”
    e TZ=Asia/Shanghai 设置容器时区为 亚洲/上海
    p 3306:3306 暴露容器的端口给主机,前面是主机端口,后面是容器端口
    v /data/mysql:/var/lib/mysql 容器卷挂载,宿主机的 “/data/mysql” 目录与容器的 "/var/lib/mysql" 挂载
    character-set-server=utf8 --collation-server=utf8_general_ci 设置默认编码格式为utf8,解决中文乱码问题

查看mysql日志

docker logs -f mysql

说明:

  • f 参数持续跟踪日志变化 可以省略
  • mysql 为容器名称,根据实际名称调整

通过shell访问容器内部

docker exec -it mysql bash

通过sql文件初始化数据库

docker exec -i mysql sh -c 'exec mysql -uroot -p"$MYSQL_ROOT_PASSWORD"' < /data/db_backup.sql

三、可能出现的问题

创建mysql容器失败

创建mysql容器成功
docker run --name mysql \
-v /media/yoyo/w/MyDocument/Python_Test_Project/2020_08/20200825/mysql/conf:/etc/mysql/mysql.conf.d \
-v /media/yoyo/w/MyDocument/Python_Test_Project/2020_08/20200825/mysql/data:/var/lib/mysql \
-v /media/yoyo/w/MyDocument/Python_Test_Project/2020_08/20200825/mysql/logs:/logs \
-e MYSQL_ROOT_PASSWORD=123456 \
-d mysql:5.7

可能的原因:

  1. -v 映射宿主的路径太长
  2. 宿主路径权限问题
  3. 如果目录中有文件,第二次创建容器失败

四、Docker创建进入mysql容器

运行”docker pull mysql”获取mysql镜像

[root@localhost ~]# docker pull mysql
Using default tag: latest
latest: Pulling from library/mysql
85b1f47fba49: Pull complete
5671503d4f93: Pull complete
3b43b3b913cb: Pull complete
4fbb803665d0: Pull complete
05808866e6f9: Pull complete
1d8c65d48cfa: Pull complete
e189e187b2b5: Pull complete
02d3e6011ee8: Pull complete
d43b32d5ce04: Pull complete
2a809168ab45: Pull complete
Digest: sha256:1a2f9361228e9b10b4c77a651b460828514845dc7ac51735b919c2c4aec864b7
Status: Downloaded newer image for mysql:latest

在后台启动mysql容器(–name指定了容器的名称,方便之后进入容器的命令行,MYSQL_ROOT_PASSWORD=admin指定了mysql的root密码,-d表示在后台运行)

Administrator@SKY-20170607FIJ MINGW64 ~
$ docker run --name mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=admin -d mysql
c6215e8c1fd73bc395a0c92e93f7e7145baedbe99c7ff639ccc9f5641bddf583

进入容器bash并进入mysql命令行:

Administrator@SKY-20170607FIJ MINGW64 ~
$ docker exec -it mysql bash
root@c6215e8c1fd7:/# mysql -uroot -padmin
mysql: [Warning] Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 5
Server version: 5.7.20 MySQL Community Server (GPL)
Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
mysql> show databases;
Database
information_schema
mysql
performance_schema
sys

4 rows in set (0.00 sec)
mysql>

退出mysql镜像

exit
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
24天前
|
网络协议 关系型数据库 MySQL
如何实现无公网ip远程访问本地安卓Termux部署的MySQL数据库【内网穿透】
如何实现无公网ip远程访问本地安卓Termux部署的MySQL数据库【内网穿透】
|
26天前
|
分布式计算 关系型数据库 MySQL
Sqoop【部署 01】CentOS Linux release 7.5 安装配置 sqoop-1.4.7 解决警告并验证(附Sqoop1+Sqoop2最新版安装包+MySQL驱动包资源)
【2月更文挑战第8天】Sqoop CentOS Linux release 7.5 安装配置 sqoop-1.4.7 解决警告并验证(附Sqoop1+Sqoop2最新版安装包+MySQL驱动包资源)
82 1
|
5天前
|
运维 监控 Devops
构建高效自动化运维体系:基于容器技术的持续集成与持续部署实践
在数字化转型的浪潮中,企业的IT基础设施和软件交付模式正经历着深刻的变革。传统的运维方式已难以满足快速迭代、灵活扩展的现代业务需求。本文将探讨如何通过容器技术实现高效的自动化运维体系,重点分析持续集成(CI)与持续部署(CD)的实践方法及其对企业运维效率的影响。通过引入微服务架构、容器编排、DevOps文化等概念,我们旨在为读者提供一套全面的自动化运维解决方案,以支持业务的敏捷性和可扩展性。
|
8天前
|
存储 Kubernetes 关系型数据库
KubeSphere 核心实战之一【在kubesphere平台上部署mysql】(实操篇 1/4)
KubeSphere 核心实战之一【在kubesphere平台上部署mysql】(实操篇 1/4)
25 0
|
16天前
|
Shell Docker 容器
Docker的常用命令:加速你的容器化开发与部署
Docker的常用命令:加速你的容器化开发与部署
45 0
|
21天前
|
SQL 关系型数据库 MySQL
MySQL多实例部署:从概念到实操的全面指南
MySQL多实例部署:从概念到实操的全面指南
36 0
|
28天前
|
SQL 关系型数据库 MySQL
docker部署mysql
docker环境下部署mysql8.x和mysql5.x
|
1月前
|
关系型数据库 MySQL Docker
在win10安装docker及部署mysql5.6过程
在win10安装docker及部署mysql5.6过程
|
1月前
|
Java 关系型数据库 MySQL
docker 部署springboot项目,连接mysql容器
docker 部署springboot项目,连接mysql容器
49 0
|
1月前
|
NoSQL Redis Docker
深入浅出:使用Docker容器化改进Python应用部署
在快速演进的软件开发领域,持续集成和持续部署(CI/CD)已成为加速产品上市的关键。本文将探索如何利用Docker,一种流行的容器化技术,来容器化Python应用,实现高效、可靠的部署流程。我们将从Docker的基本概念入手,详细讨论如何创建轻量级、可移植的Python应用容器,并展示如何通过Docker Compose管理多容器应用。此外,文章还将介绍使用Docker的最佳实践,帮助开发者避免常见陷阱,优化部署策略。无论是初学者还是有经验的开发人员,本文都将提供有价值的见解,助力读者在自己的项目中实现容器化部署的转型。

相关产品

  • 容器镜像服务
  • 容器服务Kubernetes版