美文网首页
docker 的个人总结

docker 的个人总结

作者: 都江堰古巨基 | 来源:发表于2018-07-29 22:12 被阅读0次

    最近鼓捣了一个星期的docker,终于弄得有点懂了。
    1.docker是一个打包的容器,里面的运行的程序的沙盒隔离的,意味着每个镜像里面其实都是装有一个Linux操作系统的。
    比如:
    docker pull Python
    它拉下来的这个镜像900多M的大小,为什么呢?
    这个镜像拉下来的时候其实也是拉了一个Ubuntu的操作系统的,然后这个Python是跑在这个Ubuntu里面的,真是一个很神奇的设计,不过确实这样的设计很好。

    2.docker拉下来的镜像大多数都是基于Ubuntu的,意味着不能使用centos的命令,如
    yum install

    3.docker的重要地方其实在于写dockerfile,这个dockerfile,从第一步,from开始,有点类似一个脚本
    run 后面接的指令是运行在Linux程序里面的,
    如:

    RUN mkdir /opt/test \
        && cd /opt/test
    

    后面还有很多指令不是很熟悉,待我去研究下,哈哈~
    docker run 常用的options指令:

    -a stdin: 指定标准输入输出内容类型,可选 STDIN/STDOUT/STDERR 三项;
    
    -d: 后台运行容器,并返回容器ID;
    
    -i: 以交互模式运行容器,通常与 -t 同时使用;
    
    -p: 端口映射,格式为:主机(宿主)端口:容器端口
    
    -t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用;
    
    --name="nginx-lb": 为容器指定一个名称;
    
    --dns 8.8.8.8: 指定容器使用的DNS服务器,默认和宿主一致;
    
    --dns-search example.com: 指定容器DNS搜索域名,默认和宿主一致;
    
    -h "mars": 指定容器的hostname;
    
    -e username="ritchie": 设置环境变量;
    
    --env-file=[]: 从指定文件读入环境变量;
    
    --cpuset="0-2" or --cpuset="0,1,2": 绑定容器到指定CPU运行;
    
    -m :设置容器使用内存最大值;
    
    --net="bridge": 指定容器的网络连接类型,支持 bridge/host/none/container: 四种类型;
    
    --link=[]: 添加链接到另一个容器;
    
    --expose=[]: 开放一个端口或一组端口;
    

    栗子:

    // 以交互式命令打开一个新的窗口启动centos6.8,退出容器后自动删除容器:
    docker run -it --rm  centos6.8
    

    docker中如果容器间要相互通信,如Python应用要使用redis,则不能直接连接127.0.0.1:6379,要先使用命令查看host:
    docker network inspect bridge

    docker中挂载宿主主机的db文件到Redis、MongoDB等数据库的方法:
    假设挂载宿主本地的/usr/local/db
    docker run -v /usr/local/db:data/db -d mongo

    清理docker的空间

    最近重新部署pyspider的时候报错no space left on device.
    一看df -h

    清理前.jpg

    ,99%的空间木有了!!!
    找了好久,终于找到了这个命令:
    docker system prune

    清理后.jpg

    直接清理了54个G的垃圾!!!

    docker中的-v、volume指令的注意事项

    在docker中-v、volume指令通常是用来挂载宿主的文件到容器上的,
    栗子:
    docker run -v /etc/mydocument:/etc/mydocument image_name
    -v、volume指令主要用处是当你修改宿主主机的文件时也能更新容器内的文件
    但如果你挂载的是某个具体的文件,则修改宿主的这个文件,不会更新到容器内,只能挂载文件夹才行!!!
    栗子:
    更改test.txt则不会更新到容器
    docker run -v /etc/mydocument/test.txt:/etc/mydocument/test.txt image_name
    更改test.txt会更新到容器
    docker run -v /etc/mydocument:/etc/mydocument image_name

    实时查看docker容器的日志

    sudo docker logs -f -t --tail 行数 容器名

    复制宿主主机的内容到容器,或从容器复制内容到宿主主机

    将主机./RS-MapReduce目录拷贝到容器30026605dcfe的/home/cloudera目录下:
    docker cp RS-MapReduce 30026605dcfe:/home/cloudera
    将容器30026605dcfe的/home/cloudera/RS-MapReduce目录拷贝到主机的/tmp目录中:
    docker cp 30026605dcfe:/home/cloudera/RS-MapReduce /tmp/

    docker-compose 以及docker中links的含义:

    links可以将多个容器的网络接口连接起来,一个将nginx的80端口映射到app的端口(假设为2368)具体例子如下:

    docker-compose.yml:
    
    nginx:
        image: nginx
        restart: always
        links:
            - myapp:app
        ports:
            - 80:2368
        volumes :
            - /root/nginx/conf.d: /etc/nginx/conf.d
    myapp:
        image: app_name
        restart: always
    

    由于国内的网络情况问题,在远程控制服务器打包镜像的时候可能出现各种下载失败,导致镜像不全的情况,这时候请使用daoclound、淘宝npm、清华大学pip等国内源!!

    前端常用的启动命令:
    docker run -p 80:80 -it --rm --name twy -v "${PWD}/nginx":/etc/nginx djytwy/tillage_data_center:latest

    相关文章

      网友评论

          本文标题:docker 的个人总结

          本文链接:https://www.haomeiwen.com/subject/tbbtvftx.html