docker安装与启动

构建docker镜像:

docker pull centos:laster

慢慢的等待镜像文件的下载。下载完可以通过如下命令查看镜像

docker images //查看镜像信息

REPOSITORY TAG IMAGE ID CREATED SIZE

docker.io/centos 7.2.1511 686672a1d0cc 5 weeks ago 194.6 MB

通过docker run来启动镜像,同时会创建一个容器,看下docker run的启动命令:

[root@localhost /]# docker run --help

Usage: docker run [OPTIONS] IMAGE [COMMAND] [ARG…]

Run a command in a new container

-a, --attach=[] Attach to STDIN, STDOUT or STDERR

–add-host=[] Add a custom host-to-IP mapping (host:ip)

–blkio-weight Block IO (relative weight), between 10 and 1000

–blkio-weight-device=[] Block IO weight (relative device weight)

–cpu-shares CPU shares (relative weight)

–cap-add=[] Add Linux capabilities

–cap-drop=[] Drop Linux capabilities

–cgroup-parent Optional parent cgroup for the container

–cidfile Write the container ID to the file

–cpu-period Limit CPU CFS (Completely Fair Scheduler) period

–cpu-quota Limit CPU CFS (Completely Fair Scheduler) quota

–cpuset-cpus CPUs in which to allow execution (0-3, 0,1)

–cpuset-mems MEMs in which to allow execution (0-3, 0,1)

-d, --detach Run container in background and print container ID

–detach-keys Override the key sequence for detaching a container

–device=[] Add a host device to the container

–device-read-bps=[] Limit read rate (bytes per second) from a device

–device-read-iops=[] Limit read rate (IO per second) from a device

–device-write-bps=[] Limit write rate (bytes per second) to a device

–device-write-iops=[] Limit write rate (IO per second) to a device

–disable-content-trust=true Skip image verification

–dns=[] Set custom DNS servers

–dns-opt=[] Set DNS options

–dns-search=[] Set custom DNS search domains

-e, --env=[] 《一线大厂Java面试题解析+后端开发学习笔记+最新架构讲解视频+实战项目源码讲义》无偿开源 威信搜索公众号【编程进阶路】 Set environment variables

–entrypoint Overwrite the default ENTRYPOINT of the image

–env-file=[] Read in a file of environment variables

–expose=[] Expose a port or a range of ports

–group-add=[] Add additional groups to join

-h, --hostname Container host name

–help Print usage

-i, --interactive Keep STDIN open even if not attached

–ip Container IPv4 address (e.g. 172.30.100.104)

–ip6 Container IPv6 address (e.g. 2001:db8::33)

–ipc IPC namespace to use

–isolation Container isolation level

–kernel-memory Kernel memory limit

-l, --label=[] Set meta data on a container

–label-file=[] Read in a line delimited file of labels

–link=[] Add link to another container

–log-driver Logging driver for container

–log-opt=[] Log driver options

-m, --memory Memory limit

–mac-address Container MAC address (e.g. 92:d0:c6:0a:29:33)

–memory-reservation Memory soft limit

–memory-swap Swap limit equal to memory plus swap: ‘-1’ to enable unlimited swap

–memory-swappiness=-1 Tune container memory swappiness (0 to 100)

–name Assign a name to the container

–net=default Connect a container to a network

–net-alias=[] Add network-scoped alias for the container

–oom-kill-disable Disable OOM Killer

–oom-score-adj Tune host’s OOM preferences (-1000 to 1000)

-P, --publish-all Publish all exposed ports to random ports

-p, --publish=[] Publish a container’s port(s) to the host

–pid PID namespace to use

–privileged Give extended privileges to this container

–read-only Mount the container’s root filesystem as read only

–restart=no Restart policy to apply when a container exits

–rm Automatically remove the container when it exits

–security-opt=[] Security Options

–shm-size Size of /dev/shm, default value is 64MB

–sig-proxy=true Proxy received signals to the process

–stop-signal=SIGTERM Signal to stop a container, SIGTERM by default

–sysctl=map[] Sysctl options

-t, --tty Allocate a pseudo-TTY

–tmpfs=[] Mount a tmpfs directory

-u, --user Username or UID (format: <name|uid>[:<group|gid>])

–ulimit=[] Ulimit options

–uts UTS namespace to use

-v, --volume=[] Bind mount a volume

–volume-driver Optional volume driver for the container

–volumes-from=[] Mount volumes from the specified container(s)

-w, --workdir Working directory inside the container

启动并创建一个交互式的docker容器:

[root@localhost /]# docker run -ti -d 686672a1d0cc

//-d为后台启动

通过docker ps 来查看当前运行的容器,看下docker ps的相关指令:

[root@localhost /]# docker ps --help

Usage: docker ps [OPTIONS]

List containers

-a, --all Show all containers (default shows just running)

-f, --filter=[] Filter output based on conditions provided

–format Pretty-print containers using a Go template

–help Print usage

-l, --latest Show the latest created container (includes all states)

-n=-1 Show n last created containers (includes all states)

–no-trunc Don’t truncate output

-q, --quiet Only display numeric IDs

-s, --size Display total file sizes

[root@localhost /]# docker ps//查看当前正在运行的容器

CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES

7d95b3df8674 686672a1d0cc “/bin/bash” 5 hours ago Up About an hour admiring_kowalevski

[root@localhost /]# docker ps -a//查看所有的容器信息

CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES

7d95b3df8674 686672a1d0cc “/bin/bash” 5 hours ago Up About an hour admiring_kowalevski

1b4ac575eda0 686672a1d0cc “/bin/bash” 23 hours ago Exited (137) About an hour ago elated_turing

通过docker start,docker stop来启动和停止容器:

[root@localhost /]# docker start --help

Usage: docker start [OPTIONS] CONTAINER [CONTAINER…]

Start one or more stopped containers

-a, --attach Attach STDOUT/STDERR and forward signals

–detach-keys Override the key sequence for detaching a container

–help Print usage

-i, --interactive Attach container’s STDIN

[root@localhost /]# docker stop --help

Usage: docker stop [OPTIONS] CONTAINER [CONTAINER…]

Stop a running container.

Sending SIGTERM and then SIGKILL after a grace period

–help Print usage

-t, --time=10 Seconds to wait for stop before killing it

[root@localhost /]# docker restart --help

Usage: docker restart [OPTIONS] CONTAINER [CONTAINER…]

Restart a container

–help Print usage

-t, --time=10 Seconds to wait for stop before killing the container

使用docker exec 可以进入到已经启动的容器中,低版本的docker可能不行。

[root@localhost Desktop]# docker exec -ti 7d95b3df8674 /bin/bash

[root@7d95b3df8674 /]#

容器的工作是建立在镜像的基础之上的,如果需要删除镜像的话,需要先删除使用该镜像的容器,然后才能删除镜像,否则删除镜像的时候,会有如下的类似的错误信息提示:Failed to remove image

(e7b): Error response from daemon: conflict: unable to delete e7b2de517efa (must be forced) - image is being used by stopped container 4fbc3cd00987,可以通过docker rm删除容器,docker rmi 删除镜像。

[root@localhost /]# docker rm --help

Usage: docker rm [OPTIONS] CONTAINER [CONTAINER…]

Remove one or more containers

-f, --force Force the removal of a running container (uses SIGKILL)

–help Print usage

-l, --link Remove the specified link

-v, --volumes Remove the volumes associated with the container

[root@localhost /]# docker rmi --help

Usage: docker rmi [OPTIONS] IMAGE [IMAGE…]

Remove one or more images

-f, --force Force removal of the image

–help Print usage

–no-prune Do not delete untagged parents

删除停止的容器

docker rm $(docker ps --all -q -f status=exited)

删除没有使用的镜像

docker rmi -f $(docker images | grep “” | awk “{print $3}”)

批量删除容器

docker ps -a | awk ‘{print $1}’ | xargs docker rm

批量删除镜像

docker images | awk ‘{print $3}’ | xargs docker rmi

持久化容器与镜像

1.通过容器生成新的镜像

运行中的镜像称为容器。你可以修改容器(比如删除一个文件),但这些修改不会影响到镜像。不过,你使用docker commit 命令可以把一个正在运行的容器变成一个新的镜像。

docker commit [repo:tag] 将一个container固化为一个新的image,后面的repo:tag可选。

2.持久化容器

docker export用于持久化容器。

[root@localhost /]# docker export --help

Usage: docker export [OPTIONS] CONTAINER

Export a container’s filesystem as a tar archive

–help Print usage

-o, --output Write to a file, instead of STDOUT

[root@localhost /]# docker export container.tar

[](()3.持久化镜像

======================================================================

docker save用于持久化镜像:

[root@localhost /]# docker save --help

Usage: docker save [OPTIONS] IMAGE [IMAGE…]

Save an image(s) to a tar archive (streamed to STDOUT by default)

–help Print usage

-o, --output Write to a file, instead of STDOUT

[root@localhost /]# docker save image.tar

[](()4.导入持久化镜像,容器:

============================================================================

使用docker import,docker load导入镜像容器:

[root@localhost /]# docker import --help

Usage: docker import [OPTIONS] file|URL|- [REPOSITORY[:TAG]]

Import the contents from a tarball to create a filesystem image

-c, --change=[] Apply Dockerfile instruction to the created image

–help Print usage

-m, --message Set commit message for imported image

[root@localhost /]# docker load --help

Usage: docker load [OPTIONS]

Load an image from a tar archive or STDIN

–help Print usage

-i, --input Read from a tar archive file, instead of STDIN

5.对镜像打tag

[root@localhost /]# docker images

REPOSITORY TAG IMAGE ID CREATED SIZE

docker.io/centos 7.2.1511 686672a1d0cc 5 weeks ago 194.6 MB

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值