好吧, 这是我第二次玩这个玩意了, 其实我现在这家公司是没有接触到docker的, 因此对它也是半桶水的状态, 之前有朋友叫我写过shell去离线部署它, 部署都那样不值一提, 后来到我第二次去接触它的时候有了不一样的感悟。

它确实是一个很好的中间件, 到目前为止我接触到的来说, 对我来说就像发现了一个新世界。后来我发现, 现在大部分搞linux的都必须会用docker和ansible了, 而我还局限于shell, python还是半桶水, 一言难尽, 这次就说说我第二次用到的docker各种命令以作一份笔记纪念我逝去的青春。

第一, 动手了重新弄了centos7.6minimal版, 扔vm开机...省略。

开始拉取docker, 直接yum了, 离线编译的方法也差不多, 太简单不说了, 说yum了, 老套路, 先拉一个安装脚本爽一下

curl -fsSL https://get.docker.com -o get-docker.sh

这个玩意能干嘛呢, 自动部署, 自动创建服务, 跟yum install ***差不多吧。

下一步,扔源, 这个就是用到烂了, 就是下面的一坨东西

[docker-ce-stable]
name=Docker CE Stable - $basearch
baseurl=https://download.docker.com/linux/centos/7/$basearch/stable
enabled=0
gpgcheck=1
gpgkey=https://download.docker.com/linux/centos/gpg [docker-ce-stable-debuginfo]
name=Docker CE Stable - Debuginfo $basearch
baseurl=https://download.docker.com/linux/centos/7/debug-$basearch/stable
enabled=0
gpgcheck=1
gpgkey=https://download.docker.com/linux/centos/gpg [docker-ce-stable-source]
name=Docker CE Stable - Sources
baseurl=https://download.docker.com/linux/centos/7/source/stable
enabled=0
gpgcheck=1
gpgkey=https://download.docker.com/linux/centos/gpg [docker-ce-edge]
name=Docker CE Edge - $basearch
baseurl=https://download.docker.com/linux/centos/7/$basearch/edge
enabled=1
gpgcheck=1
gpgkey=https://download.docker.com/linux/centos/gpg [docker-ce-edge-debuginfo]
name=Docker CE Edge - Debuginfo $basearch
baseurl=https://download.docker.com/linux/centos/7/debug-$basearch/edge
enabled=0
gpgcheck=1
gpgkey=https://download.docker.com/linux/centos/gpg [docker-ce-edge-source]
name=Docker CE Edge - Sources
baseurl=https://download.docker.com/linux/centos/7/source/edge
enabled=0
gpgcheck=1
gpgkey=https://download.docker.com/linux/centos/gpg [docker-ce-test]
name=Docker CE Test - $basearch
baseurl=https://download.docker.com/linux/centos/7/$basearch/test
enabled=0
gpgcheck=1
gpgkey=https://download.docker.com/linux/centos/gpg [docker-ce-test-debuginfo]
name=Docker CE Test - Debuginfo $basearch
baseurl=https://download.docker.com/linux/centos/7/debug-$basearch/test
enabled=0
gpgcheck=1
gpgkey=https://download.docker.com/linux/centos/gpg [docker-ce-test-source]
name=Docker CE Test - Sources
baseurl=https://download.docker.com/linux/centos/7/source/test
enabled=0
gpgcheck=1
gpgkey=https://download.docker.com/linux/centos/gpg [docker-ce-nightly]
name=Docker CE Nightly - $basearch
baseurl=https://download.docker.com/linux/centos/7/$basearch/nightly
enabled=0
gpgcheck=1
gpgkey=https://download.docker.com/linux/centos/gpg [docker-ce-nightly-debuginfo]
name=Docker CE Nightly - Debuginfo $basearch
baseurl=https://download.docker.com/linux/centos/7/debug-$basearch/nightly
enabled=0
gpgcheck=1
gpgkey=https://download.docker.com/linux/centos/gpg [docker-ce-nightly-source]
name=Docker CE Nightly - Sources
baseurl=https://download.docker.com/linux/centos/7/source/nightly
enabled=0
gpgcheck=1
gpgkey=https://download.docker.com/linux/centos/gpg

不好意思, 太长了, 扔进/etc/yum.repos.d, 命名吧随便,只要后缀是repo就行。

清一下yum之前的缓存

yum clean all  &&  yum list

重头戏来了, 刚才下来的get-docker.sh, 授个执行权给它吧。

chmod +x get-docker.sh

懒人就这样别介意, 你也可以sh get-docker.sh,

跑一下吧小shell儿。

./get-docker.sh

ok! 稍等一会待他自动配置。

ok!配置好了, 就是这样的了。呃, 没图, 就是就是which docker出来指定目录说明执行程序在bin里面了。

先启动看一下吧。

systemctl start docker

查看一下进程

[root@localhost yum.repos.d]# ps aux | grep docker
root 7431 0.1 4.3 561032 62084 ? Ssl 17:39 0:20 /usr/bin/dockerd -H fd://
root 7452 0.1 2.4 393784 34332 ? Ssl 17:39 0:19 containerd --config /var/run/docker/containerd/containerd.toml --log-level info
root 8720 0.0 0.0 112728 988 pts/2 S+ 21:01 0:00 grep --color=auto docker

下面记录一下基本的命令吧。

run:创建一个容器并运行一个命令, 具体用法就是docker run -it 镜像名 shell, 基本这样就能跑。但是局限于各种需求, 他有各种参数, 比如常用的

  • -d: 后台运行容器,并返回容器ID;

  • -i: 以交互模式运行容器,通常与 -t 同时使用;

  • -p: 端口映射,格式为:主机(宿主)端口:容器端口

  • -t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用;

  • --name="nginx-lb": 为容器指定一个名称;

start/stop/restart:启动,停止,重启一个容器, 具体用法就是 docker start 容器名

rm:删除一个或多个容器, 具体用法docker rm 容器名或者docker rm 容器名1 容器名2

  • -f :通过SIGKILL信号强制删除一个运行中的容器

  • -l :移除容器间的网络连接,而非容器本身

  • -v :-v 删除与容器关联的卷

exec:在容器中执行命令, 具体用法docker exec -it 容器名 shell 命令, 例如这样, docker exec -it nginx /bin/bash /root/chenglee.sh

  • -d :分离模式: 在后台运行

  • -i :即使没有附加也保持STDIN 打开

  • -t :分配一个伪终端

ps:列出容器, 具体用法docker ps 或者docker ps -a

  • -a :显示所有的容器,包括未运行的。

  • -f :根据条件过滤显示的内容。

  • --format :指定返回值的模板文件。

  • -l :显示最近创建的容器。

  • -n :列出最近创建的n个容器。

  • --no-trunc :不截断输出。

  • -q :静默模式,只显示容器编号。

  • -s :显示总的文件大小。

top:查看容器中运行的进程信息, 具体用法docker top 容器名

logs:获取容器中的日志, 具体用法 docker logs 容器名或者是docker logs -f 容器名(动态查看), 很熟悉是吧, 没错, 跟tail -f一样的功能

  • -f : 跟踪日志输出

  • --since :显示某个开始时间的所有日志

  • -t : 显示时间戳

  • --tail :仅列出最新N条容器日志

port:列出指定容器的端口映射, 具体用法docker port 容器名

pull:从镜像仓库拉取或更新指定镜像到本地, 具体用法docker pull 镜像名, 比如拉取tomcat, docker pull tomcat

  • -a :拉取所有 tagged 镜像

  • --disable-content-trust :忽略镜像的校验,默认开启

search:从仓库中查找相关的镜像, 具体用法docker search 模糊镜像名

images:列出本地镜像, 具体用法docker images或者docker images 镜像名

  • -a :列出本地所有的镜像(含中间映像层,默认情况下,过滤掉中间映像层);

  • --digests :显示镜像的摘要信息;

  • -f :显示满足条件的镜像;

  • --format :指定返回值的模板文件;

  • --no-trunc :显示完整的镜像信息;

  • -q :只显示镜像ID。

rmi:删除本地一个或多个镜像, 具体用法docker rmi 镜像名或者docker rmi 镜像名1 镜像名2

  • -f :强制删除;

  • --no-prune :不移除该镜像的过程镜像,默认移除;

import:导入容器, 具体用法docker import 容器名字 新名字

export:导出容器, 具体用法docker export -o 新名字 容器名字

save:导出镜像, 具体用法docker save -o 新名字 镜像名

load:导入镜像, 具体用法docker load -i 镜像名

info:信息, 用法docker info

version:版本, 用法docker version

有一堆东西, 好累...继续了。

先拉取一个镜像试试

docker pull tomcat

拉取失败或者特别慢的, 可能是源的问题,下面配置国内源.

vim /etc/docker/daemon.json

{
"registry-mirrors": ["https://registry.docker-cn.com"]
}

ok, 重启一下docker

systemctl restart docker

再拉, 发现速度很快, 刷刷刷...完成!

就像这样(上贴图了有嗲急冻)

这就是本地镜像了, 假装是刚拉下来的[滑稽]

先跑一个这个tomcat, 把它的端口映射到主机的随机端口看看

docker run -it -d -P tomcat

-P参数大有来头

  • -d:让容器在后台运行。

  • -P:将容器内部使用的网络端口映射到我们使用的主机上。

这个32768端口是随机的哈, 意思就是把容器中的8080映射到了我们主机上的32768上面了, 下面启动一下吧

docker start dreamy_bhabha

后面的dreamy_bhabha是这个容器的随机名字, 要想指定也可以, 一会介绍.

好了, 查看一下容器内部日志

docker logs dreamy_bhabha

tomcat启动日志, 下面在浏览器看一下

简直是不能再明显了, 好了, 下面移除这个镜像, 说一下这个映射指定端口以及容器指定名字

docker run -it -d -p 80:80 --name mynginx nginx

-p(小写), 前一个是主机的端口, 后一个是容器的端口

--name, 指定容器名字

好了, 现在启动nginx跑一下吧, 一般run的时候已经是启动的了, 如果没有启动那么就docker start mynginx

这个肯定是没问题的。

那么如果想进容器里面呢, exec该上场了, 现在进tomcat容器里面看看

docker exec -it dreamy_bhabha /bin/bash

那么查看一下容器里面的进程呢

docker top dreamy_bhabha

下一篇即将放出dockerfile构建镜像的实现方式。

简单不过了, 没啥难度。
基本就到这了。

来自docker的嚎叫的更多相关文章

  1. 在Linux和Windows的Docker容器中运行ASP.NET Core

    (此文章同时发表在本人微信公众号"dotNET每日精华文章",欢迎右边二维码来关注.) 译者序:其实过去这周我都在研究这方面的内容,结果周末有事没有来得及总结为文章,Scott H ...

  2. Docker入门教程(四)Docker Registry

    Docker入门教程(四)Docker Registry [编者的话]DockerOne组织翻译了Flux7的Docker入门教程,本文是系列入门教程的第四篇,介绍了Docker Registry,它 ...

  3. 【云计算】docker相关开源项目、工具

    十大基于Docker的开发工具 作者                     郭蕾        发布于     2014年8月19日     |              注意:QCon全球软件开发 ...

  4. Docker基础技术:AUFS

    AUFS是一种Union File System,所谓UnionFS就是把不同物理位置的目录合并mount到同一个目录中.UnionFS的一个最主要的应用是,把一张CD/DVD和一个硬盘目录给联合 m ...

  5. Docker容器中运行ASP.NET Core

    在Linux和Windows的Docker容器中运行ASP.NET Core 译者序:其实过去这周我都在研究这方面的内容,结果周末有事没有来得及总结为文章,Scott Hanselman就捷足先登了. ...

  6. 使用 Docker 容器应该避免的 10 个事情

    当你最后投入容器的怀抱,发现它能解决很多问题,而且还具有众多的优点: 第一:它是不可变的 – 操作系统,库版本,配置,文件夹和应用都是一样的.您可以使用通过相同QA测试的镜像,使产品具有相同的表现. ...

  7. docker - 关于network的一些理解

    docker 提供给我们多种(4种)网络模式,我们可以根据自己的需求来使用.例如我们在一台主机(host)或者同一个docker engine上面运行continer的时候,我们就可以选择bridge ...

  8. Docker Machine 简介

    Docker Machine 是什么? Docker Machine 是 Docker 官方提供的一个工具,它可以帮助我们在远程的机器上安装 Docker,或者在虚拟机 host 上直接安装虚拟机并在 ...

  9. Ubuntu Docker 版本的更新与安装

    突然发现自己的docker 版本特别的低,目前是1.9.1 属于古董级别的了,想更新一下最新版本,这样最新的一下命令就可以被支持.研究了半天都没有更新成功,更新后的版本始终都是1.9.1 :蒙圈了,找 ...

随机推荐

  1. 使用ReentrantLock和Condition来代替内置锁和wait(),notify(),notifyAll()

    使用ReentrantLock可以替代内置锁,当使用内置锁的时候,我们可以使用wait() nitify()和notifyAll()来控制线程之间的协作,那么,当我们使用ReentrantLock的时 ...

  2. MultipartFile实现文件上传

    一.主要有两个java类,和一般的servlet放在一起即可. 1.FileUploadBean.java package chb.demo.web;import org.springframewor ...

  3. yarn卸载或增加节点

    yarn卸载或增加节点   卸载节点或者增加节点: 方式一:静态的增添删除:将集群关闭,修改配置文件(etc/hadoop/slaves),重新启动集群(很黄很暴力,不够人性化). 方式二:动态的增加 ...

  4. duilib中字体font设置

    <Font name="微软雅黑" size="9" bold="false"/> <Label name="n ...

  5. Interllij IDEA中启动web项目

    1.在IDEA中打开你的Web应用,点击一下绿色三角形左边的框框,然后在弹出框上选择Edit Configurations,会弹出一个配置面板. 2.在弹出的面板中我们点击Defaults,然后找到T ...

  6. 洛谷P4092 [HEOI2016/TJOI2016]树 并查集/树链剖分+线段树

    正解:并查集/树链剖分+线段树 解题报告: 传送门 感觉并查集的那个方法挺妙的,,,刚好又要复习下树剖了,所以就写个题解好了QwQ 首先说下并查集的方法趴QwQ 首先离线,读入所有操作,然后dfs遍历 ...

  7. sql中遍历字符串

    在sql或者存储过程中会需要遍历字符串. ), --如111,222,333,尾部加, ), @Id int, ) set @split = ',' ) begin ,) ,charindex(@sp ...

  8. jdbc--取大量数据

    最近使用jdbc方式查询数据,保存为csv文件中.当然你可以在pl/sql中直接查出来,copy to excel就好了.但我想通过程序实现 @Test public void test() thro ...

  9. kubectl批量删除pvc

    #!/bin/bashkubectl get pvc |grep hub > tmp.txtcat tmp.txt |awk '{split($0,a," ");print ...

  10. Ceph与Gluster之开源存储的对比

    一.Ceph与Gluster之开源存储的对比 一.Ceph与Gluster的原理对比 Ceph和Gluster是Red Hat旗下的成熟的开源存储产品,Ceph与Gluster在原理上有着本质上的不同 ...