上一节我们安装好了docker,那么这节我们讲一下docker基本命令使用

查看版本

$ sudo docker --version

返回:Docker version 18.09.0, build 4d60db4
操作命令前需要使用管理员权限,每次操作都要添加sudo有点麻烦,有没有办法省略掉sudo呢?答案是有的:

$ sudo gpasswd -a ${USER} docker

这里的${USER}代表当前用户,比如我的用户名是mantishell

mantishell@zkl:~$ sudo gpasswd -a mantishell docker

重启docker

$ sudo service docker restart

然后再次使用version命令查看版本:

$ docker --version

同样可以查看到当前docker的版本。

启动容器

$ docker run [OPTIONS] IMAGE [COMMAND] [ARG...]
ARG如果是name,表示命令自定义的容器名字

eg: $ docker run  ubuntu

它首先检查本地是否有ubuntu这个镜像,没有的话就从官网拉取。这条命令执行完以后,什么也没有返回,如何查看呢?

查看容器

$ docker ps [OPTIONS]

$ docker ps  默认查看正在运行的

options:

  • -a :显示所有的容器,包括未运行的。
  • -l :显示最近创建的容器。
mantishell@zkl:~$ docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
285843bc50ec ubuntu "/bin/bash" 7 minutes ago Exited (0) 10 seconds ago affectionate_mendeleev

启动、停止、重启容器

docker start [OPTIONS] CONTAINER [CONTAINER...]
docker stop [OPTIONS] CONTAINER [CONTAINER...]
docker restart [OPTIONS] CONTAINER [CONTAINER...]

可以是id,也可以是名字

eg:$ docker start 285843bc50ec 或者 $ docker start affectionate_mendeleev

这个id和name都是自动生成的,写起来比较麻烦,有没有简单的办法呢?答案仍然是有的:我们可以在创建容器的时候指定容器的名字

mantishell@zkl:~$ docker run --name dc1 ubuntu 
mantishell@zkl:~$ docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
2ced2dbbd472 ubuntu "/bin/bash" 6 seconds ago Exited (0) 4 seconds ago dc1

再次启动容器的时候可以是:$ docker start dc1 是不是方便了很多!

如果我们想在容器里操作一些东西,怎么办呢?现在创建的容器创建完就停止了,肯定是不能操作的,那怎么办呢?

启动交互式容器

$ docker run -i -t IMAGE /bin/bash
  -i --interactive=true|false 默认是false
  -t --tty=true|false 默认是false

eg: $ docker run -i -t ubuntu /bin/bash

这时候创建完容器并不会停止掉,我们可以在里面执行ubuntu的命令,ls,cd,mkdir等等。

如果想退出当前容器怎么办呢?

一种方式:直接退出并停止:exit

一种方式:CTRL+P,CTRL+Q,让它在后台运行变成守护式容器

守护式容器

另外一种方式:在创建容器的同时指定是守护式容器:

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

docker run --name dc1 -d ubuntu /bin/bash -c "while true; do echo hello world; sleep 1; done"

附加到运行中的容器

$ docker attach 容器的name

运行中的容器启动新进程

$ docker exec [-d] [-i] [-t] 容器名 [COMMAND] [ARG...]
docker exec -i -t dc1 /bin/bash 打开一个会话

停止容器的第二种方式

 $ docker kill 容器名

删除停止的容器

$ docker rm 容器名

查看容器日志

$ docker logs [-f] [-t] [--tail] 容器名
  -f, --follows=true|false 默认false
  -t, -- timestamps=true|false默认false
  --tail="all"

eg: $ docker logs -tf --tail 10 dc1

查看容器内进程

$ docker top 容器名

容器端口映射

$ docker run [-P] [-p]
  -P, --publish-all=true|false 默认false
$ docker run -P -i -t ubuntu /bin/bash
  -p, --publish=[]
containerPort 宿主机的任意端口:docker的端口80
$ docker run -p 80 -i -t ubuntu /bin/bash
hostPort:containerPort 宿主机的端口8080:docker的端口80
$ docker run -p 8080:80 -i -t ubuntu /bin/bash-i
ip::containerPort 宿主机的ip:docker的端口80
$ docker run -p 0.0.0.0:80 -i -t ubuntu /bin/bash
ip:hostPort:containerPort 宿主机的ip和端口8080:docker的端口80
$ docker run -p 0.0.0.0:8080:80 -i -t ubuntu /bin/bash

我们做个小测试,访问docker的网站

$ docker run -p 80 --name web -it ubuntu /bin/bash
# apt-get install update
# apt-get inistall -y nginx
# apt-get install -y vim
# apt-get install -y curl
# mkdir -p /var/www/html
# ls /etc/nginx
# vim /etc/nginx/sites-enabled/default

使用ctrl+p,ctrl+q退出

把/home/docker/demo/index.html拷贝到docker中

docker -p /home/docker/demo/index.html dc1:/var/www/html

使用curl访问80端口查看结果

# curl http://localhost:80

退回到宿主机ubuntu中

首先查看宿主机对应的端口

$ docker ps

使用浏览器访问刚查到的端口号假如是32768

http://localhost:32768

docker 入坑2的更多相关文章

  1. Docker 入坑教程笔记

    Docker 入坑教程笔记 视频网址B站:点这里 查询命令 man docker 简单启动和退出 docker run --name [容器名] -i -t ubuntu /bin/bash 交互启动 ...

  2. Docker入坑系列(二)

    Docker入坑系列(二) 上一篇我们为Docker创造了一个良好的生活环境,这一篇我们就开始让Docker活起来. 安装Docker ok,原文地址在这里. 当然,我只是自己翻译了一下而已- -跟着 ...

  3. Docker入坑系列(一)

    Docker入坑系列(一) 引用嘛,当然是来引用别人说的东西啦. Docker 是一个开源项目,诞生于 2013 年初,它基于 Google 公司推出的 Go 语言实现. 项目后来加入了 Linux ...

  4. Docker入坑指南之RUN

    总有一些场景,我们需要自己制作一个镜像,可以快速还原环境,又不想被其他因素干扰镜像的纯净,这个时候,就可以选择Docker了,启动便捷,镜像还原很快捷,除了上手不容易. 最近入坑研究了一番,小有心得, ...

  5. 一、docker 入坑(win10和Ubuntu 安装)

    前言 终究还是绕不过去了,要学的知识真的是太多了,好在我们还有时间,docker 之前只闻其声,不曾真正的接触过,现在docker 越来越火,很多公司也都开始使用了.所以对于我们程序员而言,又得修炼一 ...

  6. docker 入坑4

    搭建mongodb $ docker run --name mongo -it -d -p : -v ~/docker-data/mongo:/data/db -e MONGO_INITDB_ROOT ...

  7. docker 入坑3

    查看镜像 docker images [OPTIONS] [REPOSITORY[:TAG]] -a, --all=false -f, --filter=[] --no-trunc=false -q, ...

  8. docker 入坑1

    本文是记录一下学习docker的过程,希望可以帮助到入门的朋友. 系统:ubuntu16.04 docker:18.09 打开官网:https://docs.docker.com/install/li ...

  9. Docker入坑指南之EXEC

    容器启动之后,如果我们需要进入容器内修改配置,比如mysql修改启动配置 我们启动的附加参数是不是shell,这个时候就可以用docker exec了,docker除了对image参数以外,大部分命令 ...

随机推荐

  1. log4j 1.2 配置和使用简述

    本文通过MetaWeblog自动发布,原文及更新链接:https://extendswind.top/posts/technical/log4j_properties_simple_introduct ...

  2. 使用ADO.NET

    Program using System; using System.Collections.Generic; using System.Linq; using System.Text; using ...

  3. Oracle in不超过1000,List<String>参数拆分,代码举例

    public Map<String,Map<String, Object>> getConsInfo(List<String> consIdList) { Map& ...

  4. OpenFOAM——气泡上升

    计算域的顶部为大气,其余部分为壁面 流体的物性参数为: 首先进行建模操作,任何建模软件均可,本算例采用ICEM直接建模,生成网格,然后利用OpenFOAM下转化网格,划分完成的网格如下: 网格比较密集 ...

  5. Tcl二进制数据

    binary format 格式化描述符 参数1 参数2...参数N binary scan 二进制数据 格式化描述符 变量1 变量2 ... 变量N 格式化描述符由两部分组成,第一是格式化类型关键字 ...

  6. MySQL各种类型实验

    实验一:整数 -- 测试一 create database test;-- 新建数据库,如果已经有了就不需要再创建了 USE test;-- 打开数据库 drop table if exists te ...

  7. 关于证书如何完成身份验证(SSL证书)

    一.写在前面 SSL和IPsec是现在VPN技术中最为常见的,在云计算的应用环境中,SSL更受企业青睐,至于原因的话简单的说就是SSL更为简洁,不需要像IPsec那样需要额外安装客户端,这会带来软件维 ...

  8. Nacos学习

    Nacos是阿里开源的一个新框架,在分布式的架构中,Nacos同时扮演着服务注册中心和配置中心的角色.今天主要讲的是Nacos作为服务注册中心. 分布式中著名的CAP理论,任何一种服务注册中心都只能实 ...

  9. XNOR-Net:二值化卷积神经网络

    https://www.jianshu.com/p/f9b015cc4514 https://github.com/hpi-xnor/BMXNet  BMXNet:基于MXNet的开源二值神经网络实现 ...

  10. 搭建SpringCloud微服务

    建立spring父模块 删除不必要的src目录 父模块中的pom.xml中添加相应的依赖以及插件.远程仓库地址 <!-- 项目的打包类型, 即项目的发布形式, 默认为 jar. 对于聚合项目的父 ...