你应该学会的docker使用技巧

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
检索分析服务 Elasticsearch 版,2核4GB开发者规格 1个月
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
简介: 这是之前在简书写的一篇旧文;没有读过的小伙伴可以读读。

1安装docker


  • 检查curl包是否安装?
which curl
  • 如果curl没有安装的话,则先更新apt源,并安装curl,如下:
apt-get update
apt-get install curl
apt-get update
wget -qO- https://get.docker.com/ | sh
  • 设置当前用户为docker用户组,便于解决每次执行docker命令时都需要输入密码。
# 添加一个新的docker用户组
groupadd docker
# 添加当前用户到docker用户组里,注意这里的xxoo为ubuntu server登录用户名
gpasswd -a xxoo docker
# 重启docker后台监护进程
service docker restart
# 重启之后,尝试一下,是否生效
docker version
#若还未生效,则系统重启,则生效
reboot
  • 启动docker服务,如下:
service docker start


2常见命令


  • 运行容器
docker run hello-world
  • 显示本地镜像
docker images
  • 获取镜像
docker pull ubuntu:12.04
  • 创建一个容器,并让其运行bash
docker run -t -i ubuntu:12.04 /bin/sh

 说明:-i:表示以“交互模式”运行容器 -t:表示容器启动后会进入其命令行。

  • 利用DocFile来创建镜像
mkdir sinatra
cd sinatra/
touch Dockerfile
vim Dockerfile
docker build -t="ouruser/sinatra:v2" .
  • 运行容器
docker start [stop| restart] xxx
  • 导出容器
docker ps -a
docker save -o ubuntu.tar.gz ubuntu:14.04  *(保存的是所有这个镜像的版本记录,包括一些历史数据.)*
docker export pid > ./ubuntu.tar.gz  *(导出的是容器当前所用的镜像内容)*
  • 导入容器
docker load < /tmp/mynewimage.tar *(docker save 的逆操作)*
cat ubuntu.tar | docker import - test/ubuntu:v1.0 *( export 的逆操作)*
  • 删除容器
docker stop xxx
docker rm xxx

  说明:docker 的文件是放在 /var/lib/docker/containers/ 中的。

  • 保存镜像
docker commit xxx abc

  说明:这里保存成一个名叫 abc 的镜像,镜像名称中只允许出现小写字母和数字。

  • 删除镜像
docker rmi abc
  • 获取镜像历史
docker history abc
docker images --tree  *(查看所有镜像的历史过程)*

 说明:只能对本地存在的 docker 镜像执行这个命令。

  • 杀死一个或多个指定容器进程
docker kill container

 说明:-s “KILL” 自定义发送至容器的信号。

  • 查看一个正在运行容器进程
docker top container

 说明:也支持 ps 命令参数。

  • 暂停某一容器的所有进程
docker pause container
  • 恢复某一容器的所有进程
docker unpause container
  • 标记本地镜像,将其归入某一仓库
docker tag image name

  说明:-f 覆盖已有标记。

  • 获取容器运行时的输出日志
docker logs container
  • docker attach
docker run -itd ubuntu:14.04 /bin/bash
docker attach 44fc0f0582d9

  说明:docker attach可以attach到一个已经运行的容器的stdin,然后进行命令执行的动作。但是需要注意的是,如果从这个stdin中exit,会导致容器的停止。

  • docker exec
docker exec -i name /bin/sh

   只用-i时,由于没有分配伪终端,看起来像pipe执行一样。但是执行结果、命令 返回值都可以正确获取。

docker exec -it name /bin/sh

  使用-it时,则和我们平常操作console界面类似。而且也不会像attach方式因为退出,导致整个容器退出。

docker exec -t name /bin/sh

   如果只使用-t参数,则可以看到一个console窗口,但是执行命令会发现由于没有获得stdin的输出,无法看到命令执行情况。

docker exec -d name /bin/sh a.sh

    在后台执行一个进程。可以看出,如果一个命令需要长时间进程,使用-d参数会很快返回。程序在后台运行。

  • 分层级显示一个镜像或容器的信息
docker inspect 465c60612e5c


3常见容器安装


  • mysql
docker search mysql
docker pull mysql
docker run --name xmysql-db -e MYSQL_ROOT_PASSWORD=root -d -p 3306:3306 -v /data/mysql_data/:/var/lib/mysql mysql
  • mongodb
docker pull mongo
docker run --name xmongo-db -p 27018:27017 -v /data/my_mongo_data:/data/db -d mongo
  • jenkins
docker pull jenkins
chown 1000 /data/jenkins_data/
docker run --name xjenkins -d -p 9000:8080 -p 50000:50000 -v /data/jenkins_data:/var/jenkins_home -e JAVA_OPTS=-Duser.timezone=Asia/Shanghai --env JAVA_OPTS="-Xmx512m -XX:PermSize=256m -XX:MaxPermSize=1024m" -d jenkins
  • elasticsearch
docker pull elasticsearch
docker run --name xelastic-search -d -p 9200:9200 -p 9300:9300 -v /data/esdata:/usr/share/elasticsearch/data elasticsearch
  • tomcat
docker pull tomcat
docker run --name xtomcat -d -v /data/tomcat/webapps/:/usr/local/tomcat/webapps/ -p 8080:8080 -p 9001:9000 tomcat:8
  • dockerui
docker run -d -p 9000:9000 --privileged -v /var/run/docker.sock:/var/run/docker.sock dockerui/dockerui
  • webgoat
docker pull webgoat/webgoat-7.1
docker run --name xwebgoat -d -p 8080:8080 webgoat/webgoat-7.1
相关实践学习
使用阿里云Elasticsearch体验信息检索加速
通过创建登录阿里云Elasticsearch集群,使用DataWorks将MySQL数据同步至Elasticsearch,体验多条件检索效果,简单展示数据同步和信息检索加速的过程和操作。
ElasticSearch 入门精讲
ElasticSearch是一个开源的、基于Lucene的、分布式、高扩展、高实时的搜索与数据分析引擎。根据DB-Engines的排名显示,Elasticsearch是最受欢迎的企业搜索引擎,其次是Apache Solr(也是基于Lucene)。 ElasticSearch的实现原理主要分为以下几个步骤: 用户将数据提交到Elastic Search 数据库中 通过分词控制器去将对应的语句分词,将其权重和分词结果一并存入数据 当用户搜索数据时候,再根据权重将结果排名、打分 将返回结果呈现给用户 Elasticsearch可以用于搜索各种文档。它提供可扩展的搜索,具有接近实时的搜索,并支持多租户。
相关文章
|
3月前
|
物联网 数据处理 持续交付
Docker适合哪些场景
【10月更文挑战第18天】Docker适合哪些场景
|
7月前
|
存储 API 持续交付
Docker介绍(一)
Docker是开源的应用容器引擎,让开发者打包应用及依赖到可移植容器中,可在任何环境一致运行。它提供快速启动、高效资源利用、轻松迁移和维护,适用于开发、测试和生产。Docker由客户端、守护进程、REST API组成,支持镜像存储在仓库如Docker Hub。容器是隔离的执行环境,能在同一主机上互不影响地运行多个容器。
|
7月前
|
Linux 应用服务中间件 nginx
|
8月前
|
JavaScript Linux Docker
【Docker】什么是Docker?
【4月更文挑战第20天】【Docker】什么是Docker?
|
8月前
|
运维 监控 开发者
什么是docker
Docker
61 0
|
8月前
|
存储 运维 Linux
|
Linux 测试技术 API
【Docker】Docker最近这么火,它到底是什么
【Docker】Docker最近这么火,它到底是什么
|
Linux 虚拟化 开发者
|
安全 Linux Docker
认识 Docker 的世界
Docker 简介:Docker 是一种运行于 Linux 和 Windows 上的软件,用于创建、管理和编排容器。 Docker 是在 GitHub 上开发的 Moby 开源项目的一部分。 Docker 公司,位于旧金山,是整个 Moby 开源项目的维护者。Docker 公司还提供商业版和社区版。Docker运行时与编排引擎:Docker 引擎是用于运行和...
260 1
认识 Docker 的世界