docker实践入门之二

Posted 猛禽

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了docker实践入门之二相关的知识,希望对你有一定的参考价值。

开始动手

先准备一个空的系统,现在要在上面装一个redis,传统的做法就是用系统的包管理器装一个呗,比如debian下可以用

sudo apt-get install -y redis-server
sudo service redis-server start

然而在docker下是这样:

docker pull redis
docker run -d --name redis redis

第一步是从docker官方registry上下载最新版的redis image,第二步是把redis运行起来(也就是生成一个运行着redis的container)。

那么二者有什么不同呢?前者是直接把redis安装到你的系统里,当然同时也会安装上一堆依赖包。后者则是下载一个image,然后在docker里跑,所有的依赖都在image里,与host系统完全没有影响,按这个命令跑起来,甚至都不会占用host的6379端口。

为什么不会占用端口?不占用端口怎么使用?

docker的网络

docker的网络是很特殊的,它默认会在系统里创建一个网桥叫docker0,而所有的container默认都是挂在这个网桥里的,所以端口也是开放在这个网桥里,如果你想在host里使用redis,那就要这样运行:

docker run -d --name redis -p 6379:6379 redis

其中-p参数就是把container里的6379映射到host的6379。

完整的用法是: -p [[hostip:]hostport:]containerport

除此之外,二者还有一个很大的区别就是,安装到系统里的redis只能跑一个实例(除非绑定不同的端口号),而docker可以跑多个container(同一端口号),只要用--name指定不同的名字即可——因为不同的container在docker0网桥里是不同的主机。

如果是把端口开放到host,那么这个redis用起来跟直接装在系统里没什么不同,直接用redis-cli -h localhost即可连上使用。如果没有开放端口,那么就只能在docker网络里用。比如开一个交互的docker container:

docker pull debian
docker run -it --link redis:redis debian /bin/bash

然后在这个container里用apt装一个redis-client,即可用redis-cli -h redis连接到之前运行的是那个redis contianer。

这里的--link redis:redis就是把redis container映射为这个container里的redis主机名。

其用法是: --link container:name_in_hosts

以上即为基本的docker网络应用,更高级和复杂的网络应用详见相关文档。

以上是关于docker实践入门之二的主要内容,如果未能解决你的问题,请参考以下文章

Docker入门到实践——简单操作

Docker 入门到实践笔记1

docker入门之二:docker常用命令

docker实践入门之一

ELK实践:基础入门

docker 实践(一)安装