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网络应用,更高级和复杂的网络应用详见相关文档。
推送到[go4pro.org]