Docker容器学习梳理--基础环境安装

本文涉及的产品
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
容器镜像服务 ACR,镜像仓库100个 不限时长
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
简介:

以下是centos系统安装docker的操作记录

1)第一种方法:采用系统自带的docker安装,但是这一般都不是最新版的docker
安装epel源
[root@docker-server ~]# wget http://dl.fedoraproject.org/pub/epel/epel-release-latest-6.noarch.rpm
[root@docker-server ~]# rpm -ivh epel-release-latest-6.noarch.rpm
[root@docker-server ~]# rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-EPEL-6
[root@docker-server ~]# sed -i 's/^#baseurl/baseurl/g' /etc/yum.repos.d/epel.repo
[root@docker-server ~]# sed -i 's/^mirrorlist/#mirrorlist/g' /etc/yum.repos.d/epel.repo

安装docker-io
[root@docker-server ~]# yum install docker-io -y

修改docker镜像和容器存储路径
[root@docker-server ~]# vim /etc/sysconfig/docker 
------------ 
other_args="--graph=/docker"                                 //配置这一行
------------

启动docker
[root@docker-server ~]# service docker start 
[root@docker-server ~]# chkconfig docker on
[root@docker-server ~]# ps -ef|grep docker
root 36263 1 7 19:35 pts/0 00:00:00 /usr/bin/docker -d --graph=/docker
root 36413 34216 0 19:35 pts/0 00:00:00 grep --color docker

[root@docker-server ~]# ls /docker/
containers devicemapper graph init linkgraph.db repositories-devicemapper tmp trust volumes

获取官方centos或ubuntu镜像。
这里需要特别说明下:通过实测发现,现在在centos6下的docker获取镜像失败,在centos7下的docker获取镜像可以。
所以一般建议在centos7下部署docker环境,然后docker获取centos6的容器镜像(centos7容器镜像有不少坑)
[root@docker-server ~]# docker pull centos
[root@docker-server ~]# docker pull ubuntu
[root@docker-server ~]# docker images            //查看本地镜像

运行一个docker容器
容器是在镜像的基础上来运行的,一旦容器启动了,我们就可以登录到容器中,安装自己所需的软件或应用程序。(/bin/bash命令语句必须要放在镜像名的后面)
[root@docker-server ~]# docker run -i -t centos /bin/bash 
[root@docker-server ~]# docker run -i -t ubuntu /bin/bash

[root@docker-server ~]# docker -v                       //版本不是最新版的
Docker version 1.7.1, build 786b29d/1.7.1

上面是centos6系统下做法。如果是centos7的话,直接yum install docker即可安装

2)第二种方法:安装Docker官方的最新发行版(推荐在centos7下采用这种方法安装最新版本的docker)
[root@docker-server ~]# cat /etc/redhat-release 
CentOS Linux release 7.2.1511 (Core) 
[root@docker-server ~]# curl -sSL https://get.daocloud.io/docker | sh 
[root@docker-server ~]# systemctl enable docker  
[root@docker-server ~]# systemctl start docker

[root@docker-server ~]# systemctl stop docker          //关闭 
[root@docker-server ~]# systemctl restart docker      //重启

安装过程结束后,可执行下面命令验证安装的状态。
如果看到输出 active (running) 就表示安装成功。
[root@docker-server ~]# systemctl status docker

查看docker版本
[root@docker-server ~]# docker -v                 //最新版本
Docker version 1.12.5, build 7392c3b

1
2
3
4
5
6
7
开机启动,systemctl  enable  docker.service          (docker.service改为docker也可以)
启动,systemctl start /stop/restart/status  docker.service
启动,systemctl start docker.service
帮助,docker --help
概要信息,docker info
镜像查看,docker images
容器查看,即进程查看,docker  ps  -a

获取官方centos或ubuntu镜像
[root@docker-server ~]# docker pull centos
Using default tag: latest
latest: Pulling from library/centos
45a2e645736c: Pull complete 
Digest: sha256:c577af3197aacedf79c5a204cd7f493c8e07ffbce7f88f7600bf19c688c38799
Status: Downloaded newer image for centos:latest

[root@docker-server ~]# docker images            //查看镜像
REPOSITORY TAG IMAGE ID CREATED SIZE
centos latest 67591570dd29 2 weeks ago 191.8 MB

上面在centos7下安装的docker,如果在获取centos容器镜像的时候不指定版本,那么下载下来的容器镜像默认也是centos7版本;
但是可以在获取镜像的时候指定版本,比如:
[root@linux-node2 ~]# docker pull centos:centos6
centos6: Pulling from library/centos
32c4f4fef1c6: Pull complete 
Digest: sha256:1092df198d3da4faccc0660941b763ce5adf133b0ec71701b760d6f173c1f47b
Status: Downloaded newer image for centos:centos6
[root@linux-node2 ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
centos latest 67591570dd29 2 weeks ago 191.8 MB
centos centos6 8315978ceaaa 8 weeks ago 194.6 MB
daocloud.io/daocloud/daocloud-toolset latest 1ab33797d8a1 8 months ago 150.2 MB

还可以如下获取镜像
docker pull ubuntu
docker pull ubuntu:14.04
docker pull ubuntu:latest
docker pull centos:latest
docker pull centos:7.1
docker pull centos:6.5
docker pull centos:6.8
docker pull centos:6
docker pull centos:7

启动容器,并且进入到centos容器的bash命令。
启动时的现象:其实相当于启动了一个虚拟机;
[root@linux-node2 ~]# docker run -i -t centos /bin/bash 
[root@fd81256d3c96 /]# echo "welcome to docker"
welcome to docker
[root@8f65f826ad80 /]# cat /etc/redhat-release 
CentOS Linux release 7.3.1611 (Core)

通过docker ps命令可以列出当前所有正在运行的container
[root@linux-node2 ~]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
fd81256d3c96 centos "/bin/bash" About a minute ago Up About a minute focused_bose

下面命令将会停止上面启动的实例,这样就会自动强制退出容器
[root@linux-node2 ~]# docker stop fd81256d3c96
fd81256d3c96
[root@linux-node2 ~]# docker ps 
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES

其他:
docker ps -l //列出最近一次启动的,且正在运行的container
docker ps -a //列出所有的container

docker run -p 80:8080 <image> <cmd> //映射容器的8080端口到宿主机的80端口
docker rm `docker ps -a -q` //删除所有容器
docker rm $CONTAINER_ID //删除容器id为CONTAINER_ID的容器
docker images //查看本地镜像
docker attach $CONTAINER_ID //启动一个已存在的docker实例
docker stop $CONTAINER_ID //停止docker实例(或者直接退出容器登陆;不然这个命令执行后也会强制退出容器的登陆)
docker logs $CONTAINER_ID //查看docker实例运行日志,确保正常运行
docker inspect $CONTAINER_ID //查看container的实例属性,比如ip等等

------------------------------------------------------------------------------------------------------------------------
如下:举例说明在docker下部署nginx
宿主机上执行下面命令:启动容器,进入centos容器的/bin/bash命令,并且会映射container的8080端口到宿主机的8888端口
/home/wangshibo/docker为要挂载的宿主机本地目录(如果提前不创建,也会自动生成的);
/home/mycontainer为docker映射路径,即在容器里的路径。这个和上面挂载宿主机的文件夹里内容一样!(下面是基于centos镜像创建的容器)
[root@linux-node2 ~]# docker run -t -i -v /home/wangshibo/docker:/home/mycontainer:rw -p 8888:8080 centos /bin/bash

1
2
3
4
5
6
docker命令包含以下三个部分:
docker run <相关参数> <镜像 ID> <初始命令>
其中,相关参数包括:
-i:表示以“交互模式”运行容器
-t:表示容器启动后会进入其命令行
- v :表示需要将本地哪个目录挂载到容器中,格式:- v  <宿主机目录>:<容器目录>

[root@8f65f826ad80 /]# yum install -y wget lsof vim

添加CentOS 7 Nginx yum资源库,然后安装nginx
[root@8f65f826ad80 /]# rpm -Uvh http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm
[root@8f65f826ad80 /]# yum install -y nginx

[root@8f65f826ad80 conf.d]# pwd 
/etc/nginx/conf.d
[root@8f65f826ad80 conf.d]# cat test.conf 
server {
listen 8080;
server_name localhost;
location / {
root /var/www/html;
index index.html;
}
}

[root@8f65f826ad80 conf.d]# mkdir -p /var/www/html
[root@8f65f826ad80 conf.d]# cat /var/www/html/test.html
this is nginx page of docker!!

启动/关闭/重启nginx:systemctl start/stop/restart nginx.service
开机启动nginx:systemctl enable nginx.service
网站文件存放默认目录:/usr/share/nginx/html
网站默认站点配置:/etc/nginx/conf.d/default.conf
自定义Nginx站点配置文件存放目录:/etc/nginx/conf.d/
Nginx全局配置:/etc/nginx/nginx.conf

启动nginx,有如下报错
[root@8f65f826ad80 conf.d]# systemctl start nginx.service
Failed to get D-Bus connection: Operation not permitted
--------------------------------------------------------------------------------------------------------------------
这是centos7容器里面出现的一个BUG!
即centos7镜像创建的容器里面安装服务后,不能用systemctl/service启动服务,centos6的容器里没有这个坑!
可以通过使用其他的方式启动或者换用centos6的镜像来避免这个错误。

解决方案如下:
原因是dbus-daemon没能启动。其实systemctl并不是不可以使用,可以将你的CMD或者entrypoint设置为/usr/sbin/init即可。
这样就会自动将dbus等服务启动起来。即采用 /usr/sbin/init自动启动dbus daemon

下面这个命令会一直在执行中,不能停止这个命令
[root@linux-node2 ~]# docker run --privileged -t -i -v /home/wangshibo/docker:/home/mycontainer:rw -p 8888:8080 centos /sbin/init

保证上面的命令执行后,可以查到它的容器ID(这个ID就是nginx所在容器的ID)
[root@linux-node2 ~]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
eaf66f1e43ab centos "/sbin/init" 16 seconds ago Up 15 seconds 0.0.0.0:8888->8080/tcp hungry_khorana

接着在另一个终端窗口下执行下面命苦:即通过上面容器ID进入到它的/bin/bash命令下
[root@linux-node2 ~]# docker exec -it eaf66f1e43ab /bin/bash
[root@eaf66f1e43ab /]#
然后就接着安装nginx的操作了(从上面的yum install -y wget lsof vim开始重新操作)
--------------------------------------------------------------------------------------------------------------------

如上解决后,再次启动nginx
[root@eaf66f1e43ab /]# systemctl start nginx.service
[root@eaf66f1e43ab /]# ps -ef|grep nginx
root 229 1 0 09:43 ? 00:00:00 nginx: master process /usr/sbin/nginx -c /etc/nginx/nginx.conf
nginx 230 229 0 09:43 ? 00:00:00 nginx: worker process
root 233 87 0 09:43 ? 00:00:00 grep --color=auto nginx
[root@eaf66f1e43ab /]# lsof -i:8080
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
nginx 229 root 7u IPv4 60407703 0t0 TCP *:webcache (LISTEN)
nginx 230 nginx 7u IPv4 60407703 0t0 TCP *:webcache (LISTEN)

记得在宿主机的防火墙上开启8888端口:
[root@linux-node2 home]# vim /etc/sysconfig/iptables
.......
-A INPUT -p tcp -m state --state NEW -m tcp --dport 8888 -j ACCEPT
[root@linux-node2 home]# systemctl restart iptables.service

验证访问(宿主机ip假设为110.117.88.99)

检查下容器创建时映射目录和挂载目录情况:
[root@eaf66f1e43ab ~]# ll /home/mycontainer/       
total 0
[root@eaf66f1e43ab ~]# echo "123456" > /home/mycontainer/test
[root@eaf66f1e43ab ~]# cat /home/mycontainer/test            //容器里面的情况
123456

[root@linux-node2 ~]# cat /home/wangshibo/docker/test      //容器外挂载到宿主机目录下的情况
123456

可以将这个docker主机添加到DaoCloud云平台里面管理

-------------------------------------------------------------------------------------------------------------------------------------

[下载DaoCloud里面的镜像]可以通过DaoCloud云平台-->镜像仓库-->发现镜像,找到对应镜像的地址。最后可以根据这个镜像地址下载到docker服务器上,如下:

然后找到对应镜像的镜像地址:

然后就可以在服务器上进行镜像下载了:

-------------------------------------------------------------------------------------------------------------------------------------

以下是Ubuntu 12.04以上系统安装docker环境的操作记录

安装方法一
ubuntu14.04以上的版本都是自带docker安装包的,所以可以直接安装,但一般也不是最先版本。
[ubuntu@localhost:~]$ sudo apt-get update
[ubuntu@localhost:~]$ sudo apt-get install docker.io

安装方法二
安装 Docker 官方的最新发行版
[ubuntu@localhost:~]$ curl -sSL https://get.daocloud.io/docker | sh

安装过程结束后,可执行下面命令验证安装结果。如果看到输出 docker start/running 就表示安装成功。
[ubuntu@localhost:~]$ sudo service docker status

--------------或者使用下面的安装,也是最新版的docker--------------------
[ubuntu@localhost:~]$ sudo apt-get update
[ubuntu@localhost:~]$ curl -s https://get.docker.io/ubuntu/ | sudo sh 
这个方法启动docker若出现下面错误;
FATA[0000] Error loading docker apparmor profile: fork/exec /sbin/apparmor_parser: no such file or directory ()
别担心,请安装apparmor软件即可
[ubuntu@localhost:~]$ sudo apt-get install apparmor

***************当你发现自己的才华撑不起野心时,就请安静下来学习吧***************
分类:  Docker

本文转自散尽浮华博客园博客,原文链接:http://www.cnblogs.com/kevingrace/p/6234600.html ,如需转载请自行联系原作者
相关实践学习
Docker镜像管理快速入门
本教程将介绍如何使用Docker构建镜像,并通过阿里云镜像服务分发到ECS服务器,运行该镜像。
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。 &nbsp; &nbsp; 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
1天前
|
监控 数据可视化 Linux
使用Portainer图形化工具轻松管理远程Docker环境并实现远程访问
使用Portainer图形化工具轻松管理远程Docker环境并实现远程访问
|
7天前
|
边缘计算 物联网 开发者
什么是容器Docker?
什么是容器?容器,也叫Docker,是一个开源的容器化平台,用于开发、测试和部署应用程序。通过将软件打包为标准化的单元(容器),使得应用程序可以在任何地方一致地运行,不论是在开发者的本地机器上,还是在云计算平台上。Docker容器包含了应用程序运行所需的一切,包括代码、运行时、系统工具、系统库等,从而解决了“在我这里可以正常工作,但在服务器上不行”的问题。
30 1
|
10天前
|
安全 关系型数据库 开发者
Docker Compose凭借其简单易用的特性,已经成为开发者在构建和管理多容器应用时不可或缺的工具。
Docker Compose是容器编排利器,简化多容器应用管理。通过YAML文件定义服务、网络和卷,一键启动应用环境。核心概念包括服务(组件集合)、网络(灵活通信)、卷(数据持久化)。实战中,编写docker-compose.yml,如设置Nginx和Postgres服务,用`docker-compose up -d`启动。高级特性涉及依赖、环境变量、健康检查和数据持久化。最佳实践涵盖环境隔离、CI/CD、资源管理和安全措施。案例分析展示如何构建微服务应用栈,实现一键部署。Docker Compose助力开发者高效驾驭复杂容器场景。
29 1
|
11天前
|
存储 监控 安全
Docker Compose:轻松实现容器编排的利器
【7月更文挑战第2天】 1. **基础与概念**:服务(多容器实例)、网络(灵活通信)、卷(数据持久化)和配置(安全管理)。 2. **实战指南**:安装Compose,编写`docker-compose.yml`文件,启动应用,并介绍依赖、环境变量、健康检查和数据持久化。 3. **最佳实践**:环境隔离、CI/CD集成、资源管理、日志监控、安全策略及案例分析,展示完整应用栈搭建。
30 1
|
2天前
|
Java 应用服务中间件 持续交付
Java面试题:简述Docker等容器化技术的原理及其在Java应用部署中的作用。
Java面试题:简述Docker等容器化技术的原理及其在Java应用部署中的作用。
9 0
|
7天前
|
Linux Docker 容器
Docker02--搭建Linux环境,配置Docker,docker images无法访问,因为docker没有启动,阿里云镜像加速器免费的
Docker02--搭建Linux环境,配置Docker,docker images无法访问,因为docker没有启动,阿里云镜像加速器免费的
|
10天前
|
缓存 Linux 开发工具
docker的centos容器使用yum报错
docker的centos容器使用yum报错
45 0
|
15天前
|
Java API Docker
使用Spring Boot和Docker进行容器化部署
使用Spring Boot和Docker进行容器化部署
|
15天前
|
运维 Serverless 文件存储
函数计算产品使用问题之在利用Docker镜像部署应用时,容器内的应用如何能访问函数计算配置的NAS挂载
函数计算产品作为一种事件驱动的全托管计算服务,让用户能够专注于业务逻辑的编写,而无需关心底层服务器的管理与运维。你可以有效地利用函数计算产品来支撑各类应用场景,从简单的数据处理到复杂的业务逻辑,实现快速、高效、低成本的云上部署与运维。以下是一些关于使用函数计算产品的合集和要点,帮助你更好地理解和应用这一服务。
|
弹性计算 应用服务中间件 Linux
基于ECS快速搭建Docker环境
本教程介绍如何快速搭建Docker环境,并使用Docker部署一个Nginx服务。
基于ECS快速搭建Docker环境