服务器 
首页 > 服务器 > 浏览文章

docker创建redis镜像的方法

(编辑:jimmy 日期: 2025/1/28 浏览:3 次 )

本文介绍了docker创建redis镜像的方法,分享给大家,具体如下:

直接pull redis 镜像

创建redis的镜像有几种方式,可以直接从仓库中拉取。

首先说说docker的生命周期

1.docker的创建方式,有两种方式:

1)可以直接run ,跳过上面的步骤。举个栗子:

在构建镜像,要提供访问的端口,-p为端口映射的

1.创建并启动,设置端口映射

docker run -p 127.0.0.1:6379:6379 redis

docker run

备注:docker run命令:重新创建一个容器并运行命令,语法:

Docker run [OPTIONS] IMAGES [COMMAND][ARG]

通常用的OPTIONS为:

-t 为容器分配一个伪输入终端
-I 以交互模式运行容器
-name 为容器指定名称
-d 以后台模式运行
-p 端口映射

[root@vm000949 ~]# docker run -p 127.0.0.1:6379:6379 -it --name="my-redis-server" -d redis 
d66037100bddcd230e0c9955bdfb9b0dbae8ce4028a81534e1693ab95737c90a
[root@vm000949 ~]# docker ps 
CONTAINER ID    IMAGE        COMMAND         CREATED       STATUS       PORTS           NAMES
d66037100bdd    redis        "docker-entrypoint.sh"  6 seconds ago    Up 5 seconds    127.0.0.1:6379->6379/tcp  my-redis-server
[root@vm000949 ~]# docker exec -it d66037100bdd redis-cli
127.0.0.1:6379> exit

查看端口映射情况,其中e24b3e0a7df0为redis的容器。

[root@vm000949 ~]# docker port e24b3e0a7df0
6379/tcp -> 127.0.0.1:6379

2.进入redis容器里面

docker exec -it e24b3e0a7df0 redis-cli
127.0.0.1:6379> set day newDay
OK
127.0.0.1:6379> get day
"newDay"
127.0.0.1:6379> exit

这就是一个简单的创建过程。直接run就是一个创建并启动的

进入到熟悉的界面,真是令人振奋

首先我们好好了解下docker exec命令的使用方法:

Docker exec [OPTIONS] CONTAINER COMMAND [ARG]

其中,OPTIONS包括:

这种方式是直接到仓库中拉取。

更进一步的,通过查看当前虚拟机上的端口映射情况:

[root@vm000949 ~]# netstat -apn|grep 6379
tcp    0   0 127.0.0.1:6379     0.0.0.0:*        LISTEN   2270/docker-proxy-c 

2)上述是直接采用run方式,而更为正确的生命周期应该为:

create->start->exec 

如果容器已经停止了,直接start,然后exec。采用run将会根据命令再创建一个docker

比如要重新开始,需要删除现在这个容器

[root@vm000949 ~]# docker rm 695d5f6afc27 

Error response from daemon: You cannot remove a running container 695d5f6afc27415126a40384a868c751ba635df2d4d7fb578424bc1bd9167166. Stop the container before attempting removal or use -f

提示不能删除一个正在运行的容器。

[root@vm000949 ~]# docker ps
CONTAINER ID    IMAGE        COMMAND         CREATED       STATUS       PORTS           NAMES
695d5f6afc27    redis        "docker-entrypoint.sh"  14 minutes ago   Up 8 minutes    127.0.0.1:6379->6379/tcp  ecstatic_lamarr

果然这个容器正在运行,将该容器stop,并再次删除容器

[root@vm000949 ~]# docker stop 695d5f6afc27
695d5f6afc27

(2)docker create

1.首先创建,其语法与run相似

[root@vm000949 ~]# docker create -p 127.0.0.1:6379:6379 -it --name="my-redis-server" -d redis
unknown shorthand flag: 'd' in -d
See 'docker create --help'.

我就直接将run修改为create。但是可以想象的是create里面还是没有这个选项,且没有开始运行怎么会有-d

b.再次尝试创建。去掉-d

[root@vm000949 ~]# docker create -p 127.0.0.1:6379:6379 -it --name="my-redis-server" redis
Error response from daemon: Conflict. The name "/my-redis-server" is already in use by container d66037100bddcd230e0c9955bdfb9b0dbae8ce4028a81534e1693ab95737c90a. You have to remove (or rename) that container to be able to reuse that name.

好吧,上次run创建的还没有删除

[root@vm000949 ~]# docker ps 
CONTAINER ID    IMAGE        COMMAND       CREATED       STATUS       PORTS        NAMES
[root@vm000949 ~]# docker ps -a
CONTAINER ID    IMAGE        COMMAND         CREATED       STATUS             PORTS        NAMES
d66037100bdd    redis        "docker-entrypoint.sh"  3 minutes ago    Exited (0) About a minute ago            my-redis-server

[root@vm000949 ~]# docker rm d66037100bdd
D66037100bdd

删除后重新创建:

[root@vm000949 ~]# docker create -p 127.0.0.1:6379:6379 -it --name="my-redis-server" redis
2596bd8886b4095dc80e23315a5e073addb50fc9aa959456e026e6ca31676d28
[root@vm000949 ~]# docker ps -a
CONTAINER ID    IMAGE        COMMAND         CREATED       STATUS          PORTS        NAMES
2596bd8886b4    redis        "docker-entrypoint.sh"  8 seconds ago    Created                    my-redis-server

启动容器:

[root@vm000949 ~]# docker start my-redis-server
my-redis-server
[root@vm000949 ~]# docker ps
CONTAINER ID    IMAGE        COMMAND         CREATED       STATUS       PORTS           NAMES
2596bd8886b4    redis        "docker-entrypoint.sh"  About a minute ago  Up 3 seconds    127.0.0.1:6379->6379/tcp  my-redis-server
进入容器:
[root@vm000949 ~]# docker exec -it my-redis-server redis-cli
127.0.0.1:6379> exit

记得redis是分服务端与客户端的。如果安装的是redis-server,那么就需要run两次,一个是server,一个是client,停止后,再次start,然后exec进去。

[root@vm000949 ~]# docker stop my-redis-server
my-redis-server
[root@vm000949 ~]# docker ps -a
CONTAINER ID    IMAGE        COMMAND         CREATED       STATUS           PORTS        NAMES
2596bd8886b4    redis        "docker-entrypoint.sh"  7 minutes ago    Exited (0) 5 seconds ago            my-redis-server
[root@vm000949 ~]# docker start my-redis-server
my-redis-server
[root@vm000949 ~]# docker exec -it my-redis-server redis-cli
127.0.0.1:6379> 

从上面两种方式可以看出create->start->exec的生命周期比较的直观。其中,Docker run命令包括create和start两个生命周期。
最后:docker的日志文件放在/var/lib/docker/containers/下,每个docker都有对应的文件,cat 其-json.log文件获得日志文件.
在磁盘空间中,日志文件也许会占用很大的空间,就需要进行清理。

这是一种直接拉取的方式。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

上一篇:liunx 时间函数与时间格式与字符串之间的转化方法
下一篇:Docker 镜像加速器的方法
一句话新闻
一文看懂荣耀MagicBook Pro 16
荣耀猎人回归!七大亮点看懂不只是轻薄本,更是游戏本的MagicBook Pro 16.
人们对于笔记本电脑有一个固有印象:要么轻薄但性能一般,要么性能强劲但笨重臃肿。然而,今年荣耀新推出的MagicBook Pro 16刷新了人们的认知——发布会上,荣耀宣布猎人游戏本正式回归,称其继承了荣耀 HUNTER 基因,并自信地为其打出“轻薄本,更是游戏本”的口号。
众所周知,寻求轻薄本的用户普遍更看重便携性、外观造型、静谧性和打字办公等用机体验,而寻求游戏本的用户则普遍更看重硬件配置、性能释放等硬核指标。把两个看似难以相干的产品融合到一起,我们不禁对它产生了强烈的好奇:作为代表荣耀猎人游戏本的跨界新物种,它究竟做了哪些平衡以兼顾不同人群的各类需求呢?