Docker on CentOS for beginners
[comment]: # Docker on CentOS for beginners
Introduction
The article will introduce Docker on CentOS.
Key concepts
Docker
Docker is the world's leading software containerization platform.
Docker is using union file systems which is a layered file system.
When docker run a container, every image consists of a serials of read-only layers,
and the container provides a read-write layer, and Docker combines these layers into one image,
and forms a single coherent file system on the host OS.
Q: What is the relationship between the docker host OS and the container base image OS?
A: The container's kernel is going to be the one from ubuntu, but nothing more.
Docker for Windows and Docker for Mac
Docker only support applications on Linux.
Docker cannot run on Windows and Mac directly. Docker will create a VM via Virtual Box, and run command in the VM.
Docker engine
Docker engine is a light weight Docker, is used to create Docker images and run Docker containers.
Docker daemon and Docker client
Docker uses a client-server architecture. The Docker client talks to the Docker daemon, which does the heavy lifting of building, running, and distributing your Docker containers.
Docker registries
Docker has a good ecological environment, there are some registries that store images and other materials on the Internet.
Docker Hub is a public registry and stores images.
images
An image is a file and is a read-only template, Docker can use it to create containers.
Docker images can be built from 2 ways.
- Build it from Dockfile
- Build it from a container.
containers
Docker containers are similar to a directory. A Docker container holds everything that is needed for an application to run. Each container is created from a Docker image. Docker containers can be run, started, stopped, moved, and deleted. Each container is an isolated and secure application platform. Docker containers are the run component of Docker.
Dockerfile
Dockerfile files can be used to create images by Docker.
Dockerfiles are files whose names are 'Dockerfile'. A Dockerfile is a scripts to create an image.
In general, a Docker file is based on another image. For example: a image inheritance chain is:
spark : hadoop : centos : scratch.
Base images like 'centos' are images that are from the scratch image which is an explicitly empty image from the official Docker.
We can consider 'scratch' is a reversed word by Docker. (You cannot pull, push an image named as 'scratch'.)
In fact, base images are not always OS images. like hello-world image, its Dockerfile is
FROM scratch
COPY hello /
CMD ["/hello"]
Why Docker is better than VMs
- Performance
It is said that the performance of running applications in Docker is same as running them on native machine.
Meanwhile, VMs performance is slower twice times than native machines.
Installation & configuration the Docker repository file
Method 1: Run the Docker installation scripts
curl -fsSL https://get.docker.com/ | sh
Method 2: From scripts
- Install Docker
$ sudo yum install docker
or light weight docker
$ sudo yum install docker-engine
- Create Docker repository file
The configuration can help Docker to pull images from a registry.
sudo tee /etc/yum.repos.d/docker.repo <<-'EOF'
[dockerrepo]
name=Docker Repository
baseurl=https://yum.dockerproject.org/repo/main/centos/7/
enabled=1
gpgcheck=1
gpgkey=https://yum.dockerproject.org/gpg
EOF
Configuration Docker service
# configure load the Docker service at boot
sudo chkconfig docker on
# start Docker
sudo service docker start
# create a Docker group
sudo groupadd docker
# alow non-root user to run Docker
sudo usermod -aG docker $(whoami)
Verify Docker is installed
docker run hello-world
docker version
docker info
Docker key commands
Docker help
docker --help
docker [command] --help
Search an image
You may go to Docker Hub, search an image you want to use.
or
# search images related to 'spark'
docker search spark
Output;
INDEX NAME DESCRIPTION STARS OFFICIAL AUTOMATED
docker.io docker.io/sequenceiq/spark An easy way to try Spark 287 [OK]
docker.io docker.io/gettyimages/spark A debian:jessie based Spark container 27 [OK]
docker.io docker.io/singularities/spark An Apache Spark development Docker image 12 [OK]
docker.io docker.io/shopkeep/spark Docker container with Spark, Scala, SBT, a... 7 [OK]
Pull an image
# pull the image named 'sequenceiq/spark'
docker pull sequenceiq/spark
List local images
docker images
Output:
REPOSITORY TAG IMAGE ID CREATED SIZE
docker.io/hello-world latest c54a2cc56cbb 8 weeks ago 1.848 kB
docker.io/shopkeep/spark latest 4be7b9be182e 12 months ago 1.693 GB
Create a container
# create a container from image name
docker create -t -i shopkeep/spark
# Or create a container from image id
docker create -t -i c54
Output:
5bb2d0aaa227154920733fb9f13e1571fe40254dd1b3373b617550cdde71e57e
List local containers
# Show all containers
docker ps -a
Output:
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
5bb2d0aaa227 shopkeep/spark "/bin/bash" 15 minutes ago Created insane_kowalevski
# Show running containers
sudo docker ps
Run a container
docker start -a -i 5bb
Output:
root@5bb2d0aaa227:/opt/spark#
Note: Docker is smart enough to match partial container id 5bb with the container id 5bb2d0aaa227...
Enter a running container with the existing TTY
# in most cases, the running container was started with a command 'docker start 5bb'
docker attach 5bb
Enter a running container with new TTY
docker exec -ti 5bb bash
Exit from a running container
root@5bb2d0aaa227:/opt/spark# exit
NOTE: the exit command from the last TTY will stop the container.
Stop a container
docker stop 5bb
Save a container as an image
docker commit 5bb my/image1
Output:
sha256:5cf350490e9e8b7495acb753f4041e34788e4881300b28ffc958db06d45fb4b3
Save an image to a tar archive
docker save my/image1 > ~/my_image1.tar
Load an image from a tar archive
docker load -i ~/my_image1.tar
Docker images/containers locations
- /var/lib/docker
- C:\Users[user name].docker
References
- Docker website
- Docker Overview
- Docker installation
- How is Docker different from a normal virtual machine?
- What is the relationship between the docker host OS and the container base image OS?
Docker on CentOS for beginners的更多相关文章
- Docker安装CentOS
系统环境: 腾讯云公共镜像 CoreOS 7.1 X64 #docker 下载centos镜像docker pull centos #下载centos所有的镜像docker pull ...
- 关于Docker官方CentOS镜像无法启动mysqld的总结
很多童鞋反映,在Docker官方CentOS镜像中安装了Mysql server后,无法正常启动. 无法正常启动表现为两种情况: 1> 初始完数据库后,mysqld启动报错 2> syst ...
- docker on centos
docker最好在centos7上安装,centos6.5上似乎麻烦不少 这里直接在centos7上安装,要提前装一下epel的repo yum install docker 安装就行 chkconf ...
- docker~在centos容器中安装新程序
上一篇我们使用了阿里加速器安装了centos镜像,然后创建了一个新容器,运行了这个镜像,这一讲我们来为这个镜像添加一些应用程序,然后再保存容器,push容器到仓储,大家就可以直接pull我生产的容器了 ...
- 使用docker搭建centos虚拟机
网上有很多安装linux的,这里不记录; windows安装docker 转自:https://www.cnblogs.com/samwu/p/10360943.html(windows是家庭版的) ...
- docker安装centos后没有ifconfig命令解决办法
使用docker pull centos命令下载下来的centos镜像是centos7的最小安装包,里面并没有携带ifconfig命令,导致我想查看容器内的ip时不知道该怎么办 yum provide ...
- 使用Docker搭建CentOS 7 + Apache 2.4+ PHP7
从Docker Hub上Pull最新的CentOS 7镜像并新建容器 # sudo docker pull centos docker run -p 8082:80 --name centos_c - ...
- docker打包centos增加中文支持
docker打包centos增加中文支持 前言 使用的某个包的返回值,在本机测试时返回结果是中文,结果打包到docker后返回结果变英文了:猜测是系统语言的问题,进入docker测试了一下,发现果然是 ...
- docker pull centos慢问题的解决方案
1.现象 如果直接docker pull centos 两个小时才down下来8M,很慢 2.解决 [root@localhost network-scripts]# cd /etc/docker [ ...
随机推荐
- Spring源码追踪2——xml解析入口
解析xml节点入口 org.springframework.beans.factory.xml.DefaultBeanDefinitionDocumentReader.doRegisterBeanDe ...
- csv大文件分割以及添加表头
注:这里说的大文件也不是太大,只有60多M而已(70多万条数据),相对比较大而已. 为了减轻编辑的工作,某种情况下网站上可能用会到csv格式的文件进行数据导入,但一般网站除了有上传文件大小限制以外,还 ...
- Could not find acceptable representation
引起的原因: 由于设置了@ResponseBody,要把对象转换成json格式,缺少转换依赖的jar包,故此错. 解决办法: <dependency> <groupId> ...
- Using HiveServer2 - Authentication
To configure Hive for use with HiveServer2, include the following configuration properties in the .. ...
- `cocos2dx非完整` 日志模块 增量更新
在上一篇文章中,说到了"流程"的由来,以及我对流程的使用. 这一片就是对流程的应用.前一篇文章中说到了三条流程 check_log_measure, check_env_measu ...
- MongoDB 安装记录
之前使用一直没记录,防再次掉坑,记录下 echo 开始 D: cd D:\Program Files\MongoDB\Server\3.2\bin mongod --install --service ...
- C# 解析百度天气数据,Rss解析百度新闻以及根据IP获取所在城市
百度天气 接口地址:http://api.map.baidu.com/telematics/v3/weather?location=上海&output=json&ak=hXWAgbsC ...
- Tips9: Destroy( )函数中的 延迟摧毁 功能
你知道Object.Destroy()函数吗?在脚本中用来摧毁一个游戏物体或组件,可是你知道他能在执行后延迟一段时间后才摧毁物体吗,其实很简单: using UnityEngine; public c ...
- django 快速实现session的操作
说明: 从这一篇开始就不再完整的介绍django项目的创建过程了,因为前面几篇博客中都详细的介绍了这个创建过程,套路都是一样的,熟悉了这个套路,后面要做的是一些细节技术点的学习和练习. 上一节讲到了d ...
- 基于 Markdown 的开源的 Node.js 知识库平台
Raneto 是一个免费,开源的 Node.js 知识库平台,基于静态 Markdown 文件实现. Raneto 可以被称为静态网站生成器,因为它并不需要数据库支持.所有的内容都存储在 Markdo ...