Docker从0开始

安装

参考官网即可。我在Ubuntu-14.04上通过User Guide没有任何问题。

Docker神奇的AUFS文件系统


AUFS (AnotherUnionFS in version 1, but advanced multi layered unification filesystem since version 2) implements a union mount for Linux file systems. Developed by Junjiro Okajima in 2006. aufs is a complete rewrite of the earlier Unionfs. It aimed to improve reliability and performance, but also introduced some new concepts, like writable branch balancing, and other improvements - some of which are now implemented in the Unionfs 2.x branch.


执行:docker info可以看到系统级别的信息。如下所示,可以看到docker使用的存储驱动叫aufs。简而言之,AUFS就是一个可堆叠联合文件系统,通过aufs可灵活组装一个目标容器,如在一个只读的操作系统上叠加一个可读可写的应用程序容器,当应用程序执行过程中发生数据变化,只在可写的容器层发生,这样可实现灵活的容器组装(如替换操作系统层而不影响应用程序层),同时无需像image一样需要保存成一个大文件,节省存储空间。

Containers: 2
Images: 20
Storage Driver: aufs
 Root Dir: /var/lib/docker/aufs
 Dirs: 24
Execution Driver: native-0.2
Kernel Version: 3.13.0-24-generic
WARNING: No swap limit support

烦人的sudo

ubuntu下每次执行docker都要输入sudo,比较烦人,可通过如下配置简化

# 添加当前用户到docker用户组里,注意这里的littcai为ubuntu server登录用户名
sudo gpasswd -a littcai docker
# 重启Docker后台监护进程
sudo service docker restart
# 重启之后,尝试一下,是否生效
docker version
#若还未生效,则系统重启,则生效
sudo reboot


运行

运行一个Redis服务

执行如下命令:运行一个名为common-redis的docker容器,-d表示以daemon方式运行,-p表示将容器内的6379端口映射到宿主主机的6379端口,这样一个最简单的redis服务就创建好了。

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


连接到Redis服务

运行redis-cli命令并link到之前运行的common-redis服务上,-it表示开一个tty终端,提供交互模式,--rm表示自动删除已运行存在的相同image的容器

sudo docker run -it --link common-redis:redis --rm redis sh -c 'exec redis-cli -h "$REDIS_PORT_6379_TCP_ADDR" -p "$REDIS_PORT_6379_TCP_PORT"'


Attach到Container

有时候我们需要重新进入一个正在运行的container,这里我们可以使用attach命令,其中-i表示以交互方式访问。当需要退出时,需使用ctrl-p + ctrl-q(注意是连续两个指令)而不是exit(exit会导致容器停止)。

docker attach -i f2b0ae55d07a



保存修改(new image)

首先用docker ps -a命令查询所有已创建的容器,如下图所示,得知其CONTAINER ID=f2b0ae55d07a

执行如下命令保存镜像,其中-m表示本次提交的注释,-a为author,f2b0ae55d07a为容器ID,ycai/ubuntu-jdk为镜像名称(此处通过前缀方式增加了用户名作为分类,方便查询),v1为tag名。

docker commit -m="Basic JDK ENV" -a="ycai" f2b0ae55d07a ycai/ubuntu-jdk:v1

提交成功后,可通过docker images命令查看镜像仓库中是否有刚才保存的镜像,如下图所示


拷贝文件

拷贝容器内文件到Host

sudo docker cp container:/path hostpath


拷贝Host文件到容器内
注:这个操作不修改原来的image内容,而是再它的基础上新建一个image.
sudo docker insert image url path


挂载Host目录到容器中

通过-v参数可以将Host的指定目录mount到目标容器的指定目录,这样就可以直接在Host中修改文件而不用每次都复制到容器中了。

sudo docker run --name tomcat -v /home/user/webapps:/opt/tomcat/webapps ubuntu-tomcat


Docker容器连接

未理解问题

问题:通过-v挂载了Host的一个目录到容器中,然而退出后通过start命令再启动该容器,则Host该目录下的文件变化没法体现到容器中,容器中在该目录下的文件操作无法体现到Host中,及mount失效了。
现象:将容器内挂载目录下的文件删掉,退出容器,再重新启动进入容器,发现目录又被重新mount上了,而且又支持双向同步了,诡异
分析:该目录同时也是Host通过mount方式挂载的一个远端存储,由于Host上mount失效导致三者之间不同步

转载于:https://my.oschina.net/u/699015/blog/294594

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值