在Windows上弄一个redis的docker容器

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: [本文出自天外归云的博客园] Docker核心概念简介 镜像是一个面向docker引擎的只读模板,包含了文件系统。 镜像是创建容器的基础,容器类似于一个沙箱,用来运行和隔离应用。 容器是从镜像创建的应用运行实例,可以启动、开始、停止、删除,容器之间是相互隔离的。

[本文出自天外归云的博客园]

Docker核心概念简介

镜像是一个面向docker引擎的只读模板,包含了文件系统。

镜像是创建容器的基础,容器类似于一个沙箱,用来运行和隔离应用。

容器是从镜像创建的应用运行实例,可以启动、开始、停止、删除,容器之间是相互隔离的。

 

通过boot2docker创建与启动docker环境

下载最新的docker-installer.exe:https://github.com/boot2docker/windows-installer/releases/latest

安装过程中所有选项全选,安装后会自动重启机器。

重启后点击桌面上的“Boot2Docker Start”启动docker,同时可以打开VirtualBox会看到出现了一个叫boot2docker的虚拟机在运行!这东西是用来在Windows机器上运行docker用的一个虚拟机外壳。

启动docker后可以在这个命令行窗口内看到docker容器的ip地址。

 

Docker环境中下载与启动redis容器

1. 搜索redis镜像:

docker search redis

2. 下载redis镜像(不要直接docker pull redis,因为默认的tag是latest,如果没有这个tag下载就会失败,直接选择tag为3.2的redis镜像进行下载):

docker pull redis:3.2

3. 列出已有镜像:

docker images

4. 删除指定id的镜像(如果删不了就关闭虚拟机电源然后重新启动docker再删):

docker rmi IMAGE ID

5. 运行redis容器(指定端口号、dockerfile、在容器内执行redis-server命令启动redis server):

docker run -p 6379:6379 -d redis:3.2 redis-server

6. 查看所有容器启动情况:

docker ps -a

我们可以看到redis容器已经启动!现在就可以用这个docker的ip地址作为redis server所在的ip地址对redis进行访问了。

7. 根据redis容器的id我们还可以查看redis的log信息:

docker logs IMAGE ID

如下:

8. 如果有容器已经退出,在docker ps -a下看到了已经停止的容器可以根据其IMAGE ID进行删除:

docker rm IMAGE ID

 也可以删除所有已经停止的容器:

docker rm $(docker ps -a -q)

 

通过docker-machine创建与启动docker环境

通过docker-machine创建docker是第二种创建docker的方法。

首先下载docker-machine并把docker-machine.exe所在的路径加入环境变量中。

打开cmd,输入docker-machine env default会提示你没有default环境让你创建一个docker环境,我创建一个叫docker的docker环境:

docker-machine create --driver virtualbox docker

然后执行命令:

docker-machine ls

就可以看到创建的docker环境了。执行命令查看名为docker的docker环境的环境信息:

docker-machine env docker

结果如下:

至此就知道了docker环境的ip,这样我们就可以通过ssh软件访问创建的docker机器了。这里我用的是SecureCRT这个软件,创建一个session,host填写的就是上面的ip:192.168.99.100,然后用户名是docker,密码是tcuser这些都是默认的,创建好session后双击访问,界面如下,然后执行我们之前的命令来下载并启动redis容器:

用完了以后执行关机指令:

docker-machine stop docker

再启动名为docker的docker环境:

docker-machine start docker

查看docker环境ip:

docker-machine ip docker

持续观察容器最新10行log:

docker logs IMAGE ID --tail 10 -f

避免每次打开SecureCRT都执行相同的命令启动redis可以把启动的过程写成python脚本:

# coding:utf-8
import paramiko

server_ip = '192.168.99.100'
server_port = 22
username = 'docker'
password = 'tcuser'
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect(server_ip,server_port,username,password)
command1 = 'docker rm $(docker ps -a -q)'
command2 = 'docker run -p 6379:6379 -d redis:3.2 redis-server'
stdin,stdout,stderr = ssh.exec_command(command1)
outmsg,errmsg = stdout.read(),stderr.read()
if not errmsg:
    stdin,stdout,stderr = ssh.exec_command(command2)
    outmsg = stdout.read(),stderr.read()
    print(outmsg)
ssh.close()

执行python脚本来完成redis容器启动的过程。 

PS:不要把redis容器启动的过程写成shell脚本保存到docker环境中,因为通过docker-machine重启docker环境会让保存在docker环境中的脚本文件丢失。

 

Docker带来了什么好处?

之前我的flask应用所依赖的redis server安装在了我的mac本上,所以我每天得带着mac本上班。

在Docker里部署了redis server以后,从明天开始就不用带mac本上班啦。

这就是docker给我带来的好处。(ง •̀_•́)ง

而且docker是轻量级的,安装使用都很快,相对于在一个linux虚拟机中安装redis server来说占用本机的资源是少很多的。所以我在本机上不用虚拟机,而用docker。虽然docker在Windows上运行也依赖于一个虚拟机外壳,但是这个外壳是非常小的,几乎可以忽略,就是我们刚才看到的那个boot2docker虚拟机外壳。

 

疑难问题解决

运行docker images命令如果出现如下错误:

  • An error occurred trying to connect: Post https://192.168.59.103:2376/v1.19/containers/create: x509: certificate is valid for 127.0.0.1, 10.0.2.15, not 192.168.59.103

之前的docker的ip是59.104,关闭电源重新打开boot2docker后发现docker的ip变成了59.103。

一个不得已的办法是删除掉本地的虚拟机外壳程序后重新运行boot2docker start程序,这样之前下载的镜像就都没了,还得重新下载。

Github上提供了一种解决方法,试了以后发现不管用。唯一一个碰运气的方法就是多关闭几次虚拟机电源让docker的ip再分配回之前的ip……反正不是192.168.59.104就是192.168.59.103。但这得看运气!没准一直ip都不变,所以这个也不是好办法。

目前看,唯一的好办法就是不使用boot2docker的启动程序启动docker环境,而是使用docker-machine来启动docker环境,默认分配的ip是192.168.99.100。

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
1月前
|
存储 NoSQL Redis
Docker 部署 Redis
在使用 Docker 部署 Redis 时,为实现数据持久化,需正确挂载容器内的数据目录到宿主机。推荐命令如下: ``` docker run -d --name redis -v /mnt/data/redis:/data -p 6379:6379 redis ``` 该命令将宿主机的 `/mnt/data/redis` 目录挂载到容器的 `/data` 目录,确保 Redis 数据持久化。此路径更通用,适合大多数场景。避免使用不匹配的挂载路径,如 `/var/lib/redis` 或 `/mnt/data/redis` 到非默认目录,以防止数据无法正确持久化。
|
9天前
|
安全 持续交付 云计算
课时5:阿里云容器服务:最原生的集成Docker和云服务
阿里云容器服务以服务化形式构建容器基础设施,大幅提升开发效率,简化应用部署流程。通过Docker容器和DevOps工具(如Jenkins),实现自动化部署与迭代,优化企业内部复杂部署问题。该服务支持GPU调度、混合云架构无缝迁移,并与阿里云产品体系无缝集成,提供安全防护、网络负载均衡等多重功能支持。凭借微服务架构,帮助企业突破业务瓶颈,提高资源利用率,轻松应对海量流量。
课时5:阿里云容器服务:最原生的集成Docker和云服务
|
1月前
|
Ubuntu API 网络虚拟化
ubuntu22 编译安装docker,和docker容器方式安装 deepseek
本脚本适用于Ubuntu 22.04,主要功能包括编译安装Docker和安装DeepSeek模型。首先通过Apt源配置安装Docker,确保网络稳定(建议使用VPN)。接着下载并配置Docker二进制文件,创建Docker用户组并设置守护进程。随后拉取Debian 12镜像,安装系统必备工具,配置Ollama模型管理器,并最终部署和运行DeepSeek模型,提供API接口进行交互测试。
344 15
|
2月前
|
Ubuntu NoSQL Linux
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
218 6
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
|
3月前
|
Ubuntu Linux 开发工具
docker 是什么?docker初认识之如何部署docker-优雅草后续将会把产品发布部署至docker容器中-因此会出相关系列文章-优雅草央千澈
Docker 是一个开源的容器化平台,允许开发者将应用程序及其依赖项打包成标准化单元(容器),确保在任何支持 Docker 的操作系统上一致运行。容器共享主机内核,提供轻量级、高效的执行环境。本文介绍如何在 Ubuntu 上安装 Docker,并通过简单步骤验证安装成功。后续文章将探讨使用 Docker 部署开源项目。优雅草央千澈 源、安装 Docker 包、验证安装 - 适用场景:开发、测试、生产环境 通过以上步骤,您可以在 Ubuntu 系统上成功安装并运行 Docker,为后续的应用部署打下基础。
108 8
docker 是什么?docker初认识之如何部署docker-优雅草后续将会把产品发布部署至docker容器中-因此会出相关系列文章-优雅草央千澈
|
3月前
|
存储 Kubernetes 开发者
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
Docker 是一种开源的应用容器引擎,允许开发者将应用程序及其依赖打包成可移植的镜像,并在任何支持 Docker 的平台上运行。其核心概念包括镜像、容器和仓库。镜像是只读的文件系统,容器是镜像的运行实例,仓库用于存储和分发镜像。Kubernetes(k8s)则是容器集群管理系统,提供自动化部署、扩展和维护等功能,支持服务发现、负载均衡、自动伸缩等特性。两者结合使用,可以实现高效的容器化应用管理和运维。Docker 主要用于单主机上的容器管理,而 Kubernetes 则专注于跨多主机的容器编排与调度。尽管 k8s 逐渐减少了对 Docker 作为容器运行时的支持,但 Doc
214 5
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
|
2月前
|
Kubernetes Linux 虚拟化
入门级容器技术解析:Docker和K8s的区别与关系
本文介绍了容器技术的发展历程及其重要组成部分Docker和Kubernetes。从传统物理机到虚拟机,再到容器化,每一步都旨在更高效地利用服务器资源并简化应用部署。容器技术通过隔离环境、减少依赖冲突和提高可移植性,解决了传统部署方式中的诸多问题。Docker作为容器化平台,专注于创建和管理容器;而Kubernetes则是一个强大的容器编排系统,用于自动化部署、扩展和管理容器化应用。两者相辅相成,共同推动了现代云原生应用的快速发展。
325 11
|
3月前
|
NoSQL 关系型数据库 Redis
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
144 14
|
2月前
|
关系型数据库 MySQL 应用服务中间件
《docker基础篇:8.Docker常规安装简介》包括:docker常规安装总体步骤、安装tomcat、安装mysql、安装redis
《docker基础篇:8.Docker常规安装简介》包括:docker常规安装总体步骤、安装tomcat、安装mysql、安装redis
151 7
|
3月前
|
NoSQL 算法 Redis
docker高级篇(大厂进阶):安装redis集群
docker高级篇(大厂进阶):安装redis集群
239 24