使用Docker部署MySQLRedis容器与常见命令

目录

  • 1. 检查WSL配置
  • 2. 设置WSL版本
  • 3. 拉取MySQL镜像
  • 4. 验证镜像
  • 5. 运行MySQL容器
    • 在WSL环境中使用以下命令启动MySQL容器
    • 查看容器/镜像的完整信息
    • 显式指定宿主机挂载路径
    • 可选:在Windows的cmd中使用以下命令启动MySQL容器
  • 6. 管理容器
    • 启动已创建的容器
    • 查看运行中的容器
    • 查看容器的日志
    • 通过docker进入mysql命令行
  • 7. 连接通过Docker部署的MySQL容器
  • 8. Redis部署

1. 检查WSL配置

检查当前 Windows Subsystem for Linux (WSL) 的配置,确保Linux系统和docker桌面版使用同一个版本的WSL

wsl --list --verbose

在这里插入图片描述

2. 设置WSL版本

如果WSL版本不统一,可通过以下命令更改WSL配置

wsl --set-version <distribution name> <versionNumber>
wsl --set-version Ubuntu-22.04 2

参考网址:将 WSL 版本设置为 1 或 2

3. 拉取MySQL镜像

从Docker Hub拉取MySQL镜像:

docker pull mysql:8.4

检查已下载的Docker镜像:

4. 验证镜像

docker images

在这里插入图片描述

5. 运行MySQL容器

在WSL环境中使用以下命令启动MySQL容器

docker run -p 4406:3306 --name mysql-8.4 \
-v "mysql-data:/var/lib/mysql" \
-v "mysql-conf:/etc/mysql/conf.d" \
-v "mysql-log:/var/log/mysql" \
-v "mysql-files:/var/lib/mysql-files" \
-e MYSQL_ROOT_PASSWORD=root -d mysql:8.4 \
--character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci

在创建容器时,若未显式指定宿主机挂载路径,Docker将自动生成/var/lib/docker/volumes/mysql-data/_data等匿名卷,并与MySQL容器建立挂载关联 参考文章:docker安装mysql并实现数据卷挂载

查看容器/镜像的完整信息

docker inspect mysql-8.4
"Mounts": [{"Type": "volume","Name": "mysql-data","Source": "/var/lib/docker/volumes/mysql-data/_data","Destination": "/var/lib/mysql","Driver": "local","Mode": "z","RW": true,"Propagation": ""},...
]

显式指定宿主机挂载路径

docker run -p 4406:3306 --name mysql-8.4 \-v "/var/lib/docker/mysql8.4/data:/var/lib/mysql" \-v "/var/lib/docker/mysql8.4/conf:/etc/mysql/conf.d" \-v "/var/lib/docker/mysql8.4/log:/var/log/mysql" \-v "/var/lib/docker/mysql8.4/mysql-files:/var/lib/mysql-files" \-e MYSQL_ROOT_PASSWORD=root -d mysql:8.4 \--character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci
"Mounts": [{"Source": "/var/lib/docker/mysql8.4/data","Destination": "/var/lib/mysql","Mode": "","RW": true,"Propagation": "rprivate"},...
}

可选:在Windows的cmd中使用以下命令启动MySQL容器

docker run -p 4406:3306 --name mysql-8.4 -v "mysql-data:/var/lib/mysql" -v "mysql-conf:/etc/mysql/conf.d" -v "mysql-log:/var/log/mysql" -v "mysql-files:/var/lib/mysql-files" -e MYSQL_ROOT_PASSWORD=root -d mysql:8.4 --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci

在这里插入图片描述

这个 docker run 命令用于启动一个 MySQL 8.4 容器,并将数据、配置和日志持久化存储在宿主机的 /mnt/d/docker/mysql8.4/ 目录下。下面是对每个参数的详细解释:

参数说明
docker run启动一个新容器
-p 4406:3306端口映射:将宿主机的 4406 端口映射到容器的 3306(MySQL 默认端口)
--name mysql-8.4为容器指定名称 mysql-8.4
-d后台运行容器(守护进程模式)
mysql:8.4使用的镜像

6. 管理容器

启动已创建的容器

docker start mysql-8.4

查看运行中的容器

docker ps

在这里插入图片描述

查看容器的日志

docker logs mysql-8.4

在这里插入图片描述

通过docker进入mysql命令行

docker exec -it mysql bash

按住Ctrl+d可退出mysql命令行

查看文件资源在宿主机的映射

在这里插入图片描述

对比mysql容器内部文件发现所有文件成功映射

在这里插入图片描述

7. 连接通过Docker部署的MySQL容器

注意此处的端口为将容器的3306端口的映射到宿主机的4406端口

在这里插入图片描述

8. Redis部署

同样的启动方法可以在docker部署Redis容器(WSL)

docker pull redis:8.0.2
cd /var/lib/docker/redis8/conf/
sudo touch redis.conf
sudo chmod 777 redis.conf
vim redis.conf

在redis.conf中使用vim编辑器写入

requirepass [your_password] # 设置密码
appendonly yes # 持久层相关
docker run -p 5379:6379 --name redis-8.0.2 \
-v /var/lib/docker/redis8/data:/data \
-v /var/lib/docker/redis8/conf/redis.conf:/etc/redis/redis.conf \
-d redis:8.0.2 \
redis-server /etc/redis/redis.conf
docker start redis-8.0.2
docker exec -it redis-8.0.2 bash
# redis-cli
> auth mq20011103
OK
> set name abc
OK
> get name
"abc"
>

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/bicheng/84291.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

01__C++入门

一、C的语法框架 首先学习一门语言&#xff0c;我们需要了解语言的基本框架&#xff0c;这一小节&#xff0c;我们学习C的历史应用&#xff0c;c和c的区别和c的标准 二、认识C 1、C的历史 所有的主流C编译器都支持这个版本的C&#xff08;1998年的版本&#xff09;。 2、C的应…

2024 CKA题库+详尽解析| 15、备份还原Etcd

目录 免费获取题库配套 CKA_v1.31_模拟系统 15、 备份还原Etcd 题目&#xff1a; 开始操作: 1&#xff09;、切换集群 2&#xff09;、登录master并提权 3&#xff09;、备份Etcd现有数据 4&#xff09;、验证备份数据快照 5&#xff09;、查看节点和Pod状态 6&am…

Flotherm许可的并发用户数限制

在电子产品热设计领域&#xff0c;Flotherm软件以其卓越的性能和精确的仿真能力而受到广大用户的青睐。然而&#xff0c;在使用Flotherm软件时&#xff0c;了解其许可的并发用户数限制对于优化资源配置和提升工作效率至关重要。本文将详细介绍Flotherm软件许可的并发用户数限制…

读取宝塔方法,查找容别名存放位置

可以查到对应方法 根据参数名可知 查找到 得到位置

【1】跨越技术栈鸿沟:字节跳动开源TRAE AI编程IDE的实战体验

2024年初&#xff0c;人工智能编程工具领域发生了一次静默的变革。当字节跳动宣布退出其TRAE项目&#xff08;一款融合大型语言模型能力的云端AI编程IDE&#xff09;时&#xff0c;技术社区曾短暂叹息。然而这一退场并非终点——通过开源社区的接力&#xff0c;TRAE在WayToAGI等…

git连接本地仓库以及gitee

参考:gitee创建新仓库并上传代码_gitee新建仓库导入代码-CSDN博客 git初始化以及添加git分支 在idea查看master主分支 报错 原因gitee推送更新失败问题记录&#xff1a;remote: error: hook declined to update refs/heads/master-CSDN博客 取消邮箱暴露

pocketflow库实现guardrail

目录 代码代码解释1. 系统架构2. 核心组件详解2.1 LLM调用函数2.2 UserInputNode&#xff08;用户输入节点&#xff09;2.3 GuardrailNode&#xff08;安全防护节点&#xff09;2.4 LLMNode&#xff08;LLM处理节点&#xff09; 3. 流程控制机制 示例运行 代码 from pocketflo…

Fetch API 使用详解:Bearer Token 与 localStorage 实践

Fetch API&#xff1a;现代浏览器内置的用于发送 HTTP 请求的 API&#xff0c;Bearer Token&#xff1a;一种基于令牌的身份验证方案&#xff0c;常用于 JWT 认证&#xff0c;localStorage&#xff1a;浏览器提供的持久化存储方案&#xff0c;用于在客户端存储数据。 token是我…

Netty自定义协议解析

目录 自定义协议设计 实现消息解码器 实现消息编码器 自定义消息对象 配置ChannelPipeline Netty提供了强大的编解码器抽象基类,这些基类能够帮助开发者快速实现自定义协议的解析。 自定义协议设计 在实现自定义协议解析之前,需要明确协议的具体格式。例如,一个简单的…

驭码 CodeRider 2.0 产品体验:智能研发的革新之旅

驭码 CodeRider 2.0 产品体验&#xff1a;智能研发的革新之旅 在当今快速发展的软件开发领域&#xff0c;研发效率与质量始终是开发者和企业关注的核心。面对开发协作流程繁琐、代码生成补全不准、代码审核低效、知识协同困难以及部署成本与灵活性难以平衡等问题&#xff0c;…

NLP学习路线图(二十六):自注意力机制

一、为何需要你?序列建模的困境 在你出现之前,循环神经网络(RNN)及其变种LSTM、GRU是处理序列数据(如文本、语音、时间序列)的主流工具。它们按顺序逐个处理输入元素,将历史信息压缩在一个隐藏状态向量中传递。 瓶颈显现: 长程依赖遗忘: 随着序列增长,早期信息在传递…

【渲染】Unity-分析URP的延迟渲染-DeferredShading

我是一名资深游戏开发&#xff0c;小时候喜欢看十万个为什么 介绍 本文旨在搞清楚延迟渲染在unity下如何实现的&#xff0c;为自己写延迟渲染打一个基础&#xff0c;打开从知到行的大门延迟渲染 输出物体表面信息(rt1, rt2, rt3, …) 着色(rt1, rt2, rt3, …)研究完感觉核心…

华为OD机考- 简单的自动曝光/平均像素

import java.util.Arrays; import java.util.Scanner;public class DemoTest4 {public static void main(String[] args) {Scanner in new Scanner(System.in);// 注意 hasNext 和 hasNextLine 的区别while (in.hasNextLine()) { // 注意 while 处理多个 caseint[] arr Array…

java 乐观锁的实现和注意细节

文章目录 1. 前言乐观锁 vs. 悲观锁&#xff1a;基本概念对比使用场景及优势简述 2. 基于版本号的乐观锁实现代码示例注意事项 3. 基于CAS机制的乐观锁实现核心思想代码示例关键点说明 4. 框架中的乐观锁实践MyBatis中基于版本号的乐观锁实现示例代码 JPA&#xff08;Hibernate…

河北对口计算机高考C#笔记(2026高考适用)---持续更新~~~~

C#笔记 C#发展史 1998年,C#发布第一个版本。2002年,visual studio开发环境推出C#的特点 1.语法简洁,不允许直接操作内存,去掉了指针操作 2.彻底面向对象设计。 3.与Web紧密结合。 4.强大的安全机制,语法错误提示,引入垃圾回收器机制。 5.兼容性。 6.完善的错误,异常处理…

C# dll版本冲突解决方案

随着项目功能逐渐增加&#xff0c;引入三方库数量也会增多。不可避免遇到库的间接引用dll版本冲突&#xff0c;如System.Memory.dll、System.Buffer.dll等。编译会报警&#xff0c;运行可能偶发异常。 可使用ILMerge工具合并动态库&#xff0c;将一个库的多个dll合并为一个dll。…

深度解析:etcd 在 Milvus 向量数据库中的关键作用

目录 &#x1f680; 深度解析&#xff1a;etcd 在 Milvus 向量数据库中的关键作用 &#x1f4a1; 什么是 etcd&#xff1f; &#x1f9e0; Milvus 架构简介 &#x1f4e6; etcd 在 Milvus 中的核心作用 &#x1f527; 实际工作流程示意 ⚠️ 如果 etcd 出现问题会怎样&am…

随机访问介质访问控制:网络中的“自由竞争”艺术

想象一场自由辩论赛——任何人随时可以发言&#xff0c;但可能多人同时开口导致混乱。这正是计算机网络中随机访问协议的核心挑战&#xff1a;如何让多个设备在共享信道中高效竞争&#xff1f;本文将深入解析五大随机访问技术及其智慧。 一、核心思想&#xff1a;自由竞争 冲突…

设计模式作业

package sdau;public class man {public static void main(String[] args) {show(new Cat()); // 以 Cat 对象调用 show 方法show(new Dog()); // 以 Dog 对象调用 show 方法Animal a new Cat(); // 向上转型 a.eat(); // 调用的是 Cat 的 eatCat c (Cat)a…

Kaspa Wasm SDK

文章目录 1. 简要2. github地址 1. 简要 kaspa wallet SDK&#xff0c;在官方WASM基础上封装了应用层的方法&#xff0c;简便了WASM的初始化及调用。 核心功能包括如下&#xff1a; 账户地址生成及管理Kaspa Api 和 Kasplex Api的封装kaspa结点RPC 封装P2SH的各个场景script封…