docker基础入门和docker compose实战

Docker运维部署

docker官网:https://www.docker.com/
文档:https://docs.docker.com/ Docker的文档是超级详细的!
仓库:https://hub.docker.com/


  • Docker
  • Docker安装与配置
  • Docker镜像容器操作
  • Docker容器数据卷
  • Dockerfile
  • Docker-compose

Docker

镜像(image):

docker镜像就好比是一个目标,可以通过这个目标来创建容器服务,tomcat镜像==>run==>容器(提供服务器),通过这个镜像可以创建多个容器(最终服务运行或者项目运行就是在容器中的)。

容器(container):

Docker利用容器技术,独立运行一个或者一组应用,通过镜像来创建的.
启动,停止,删除,基本命令
目前就可以把这个容器理解为就是一个简易的 Linux系统。

仓库(repository):

仓库就是存放镜像的地方!
仓库分为公有仓库和私有仓库。(很类似git)
Docker Hub是国外的。
阿里云…都有容器服务器(配置镜像加速!)

Docker安装与配置

安装Docker

要求
1.Linux要求内核3.0以上
2.CentOS 7

 - 卸载旧版本docker
	yum remove docker \
        docker-client \
        docker-client-latest \
        docker-common \
        docker-latest \
        docker-latest-logrotate \
        docker-logrotate \
        docker-engine
        
 - 下载需要的安装包
     yum install -y yum-utils
	
 - 设置镜像的仓库 (复制注意后面的符号)
    yum-config-manager \
    --add-repo \
    https://download.docker.com/linux/centos/docker-ce.repo
    #上述方法默认是从国外的,不推荐

    #推荐使用国内的
    yum-config-manager \
    --add-repo \
    https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
	
 - 更新yum软件包索引
	yum makecache fast
	
 - 安装docker相关内容
 	yum install docker-ce docker-ce-cli containerd.io
 	
 - 启动docker
	systemctl start docker
	
 - 查看是否安装成功
 	docker version
 	
 - 运行hello-world
	docker run hello-world
	
 - 查看下载的镜像
	docker images
	
 - 卸载docker
	yum remove docker-ce docker-ce-cli containerd.io
	rm -rf /var/lib/docker

配置阿里云镜像加速

  • 登录阿里云找到容器服务
  • 找到镜像加速地址
  • 配置使用
    1.创建一个目录
	mkdir -p /etc/docker
	
	2.编写配置文件
	tee /etc/docker/daemon.json <<-'EOF'
	{
	  "registry-mirrors": ["https://t2wwyxhb.mirror.aliyuncs.com"]
	}
	EOF
	
	3.重启服务
	systemctl daemon-reload
	systemctl restart docker

Docker镜像容器操作

帮助命令

    docker version    #显示docker的版本信息。
    docker info       #显示docker的系统信息,包括镜像和容器的数量
    docker 命令 --help #帮助命令

镜像命令

docker images #查看所有本地主机上的镜像 可以使用docker image ls代替

docker search #搜索镜像

docker pull #下载镜像
docker pull 镜像名[:tag],如果不写tag,默认就是lates

docker rmi #删除镜像
docker rmi -f 镜像id  #删除指定id的镜像
docker rmi -f $(docker images -aq) #删除全部的镜像

docker images #查看所有本地的主机上的镜像
# 解释
#REPOSITORY			# 镜像的仓库源
#TAG				# 镜像的标签(版本)		---lastest 表示最新版本
#IMAGE ID			# 镜像的id
#CREATED			# 镜像的创建时间
#SIZE				# 镜像的大小

# 可选项
Options:
  -a, --all         Show all images (default hides intermediate images) #列出所有镜像
  -q, --quiet       Only show numeric IDs # 只显示镜像的id
  
# docker images -a  #列出所有镜像详细信息
# docker images -aq #列出所有镜像的id

容器命令

docker run 镜像id #新建容器并启动

docker ps 列出所有运行的容器 docker container list

docker rm 容器id #删除指定容器

docker start 容器id	#启动容器
docker restart 容器id	#重启容器
docker stop 容器id	#停止当前正在运行的容器
docker kill 容器id	#强制停止当前容器

新建容器并启动

docker run [可选参数] image | docker container run [可选参数] image 
#参书说明
--name="Name"		#容器名字 tomcat01 tomcat02 用来区分容器
-d					#后台方式运行
-it 				#使用交互方式运行,进入容器查看内容
-p					#指定容器的端口 -p 8080(宿主机):8080(容器)
		-p ip:主机端口:容器端口
		-p 主机端口:容器端口(常用)
		-p 容器端口
		容器端口
-P(大写) 				随机指定端口

列出所有运行的容器

docker ps 命令  	   #列出当前正在运行的容器
  -a, --all     	 #列出当前正在运行的容器 + 带出历史运行过的容器
  -n=?, --last int   #列出最近创建的?个容器?为1则只列出最近创建的一个容器
  -q, --quiet        #只列出容器的编号

退出容器

exit 		#容器直接退出
ctrl +P +Q  #容器不停止退出 	---注意:这个很有用的操作

删除容器

docker rm 容器id   #删除指定容器,不能删除正运行的容器,若强制删除 rm -rf
docker rm -f $(docker ps -aq)  	 #删除所有的容器
docker ps -a -q|xargs docker rm  #删除所有的容器

启动和停止容器的操作

docker start 容器id	#启动容器
docker restart 容器id	#重启容器
docker stop 容器id	#停止当前正在运行的容器
docker kill 容器id	#强制停止当前容器

常用其他命令

后台启动命令
docker run -d 镜像名

查看日志
docker logs --help
#模拟日志
docker run -d centos /bin/sh -c "while true;do echo 6666;sleep 1;done"  

#显示日志
    -tf		#显示日志信息(一直更新)
    --tail number #需要显示日志条数
docker logs -t --tail n 容器id #查看n行日志
docker logs -ft 容器id #跟着日志

查看容器中进程信息
docker top 容器id

查看镜像的元数据
docker inspect 容器id

进入当前正在运行的容器
docker exec -it 容器id bashshell
# 方式二
docker attach 容器id
#docker exec #进入当前容器后开启一个新的终端,可以在里面操作(常用)
#docker attach # 进入容器正在执行的终端

从容器内拷贝到主机上
docker cp 容器id:容器内路径  主机目的路径

docker run -it --rm 镜像名 一般是用来测试,用完就删除

commit镜像
docker commit 提交容器成为一个新的副本
# 命令和git原理类似
docker commit -m="描述信息" -a="作者" 容器id 目标镜像名:[版本TAG]
docker commit -a="kuangshen" -m="add webapps app" 容器id tomcat02:1.0

小结:
此处输入图片的描述

容器数据卷

将应用和环境打包成一个镜像!
数据?如果数据都在容器中,那么我们容器删除,数据就会丢失!需求:数据可以持久化
MySQL,容器删除了,删库跑路!需求:MySQL数据可以存储在本地!
容器之间可以有一个数据共享技术!Docker容器中产生的数据,同步到本地!
这就是卷技术!目录的挂载,将我们容器内的目录,挂载到Linux上面!

此处输入图片的描述

三种挂载: 匿名挂载、具名挂载、指定路径挂载

-v 容器内路径 #匿名挂载
-v 卷名:容器内路径 #具名挂载
-v /宿主机路径:容器内路径 #指定路径挂载 docker volume ls 是查看不到的

docker run -it -v 主机目录:容器内目录  -p 主机端口:容器内端口

例:
# 获取mysql镜像
[root@iz2zeak7sgj6i7hrb2g862z home]# docker pull mysql:5.7

# 运行容器,需要做数据挂载 #安装启动mysql,需要配置密码的,这是要注意点!
# 参考官网hub 
docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag

#启动我们得
-d 后台运行
-p 端口映射
-v 卷挂载
-e 环境配置
-- name 容器名字
docker run -d -p 3310:3306 -v /home/mysql/conf:/etc/mysql/conf.d -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql03 mysql:5.7

# 启动成功之后,我们在本地使用sqlyog来测试一下
# sqlyog-连接到服务器的3306--和容器内的3306映射 

# 在本地测试创建一个数据库,查看一下我们映射的路径是否ok!

Dockerfile

Dockerfile 就是用来构建docker镜像的构建文件!命令脚本!
通过这个脚本可以生成镜像,镜像是一层一层的,脚本是一个个的命令,每个命令都是一层!

  • 编写一个dockerfile文件

规则
1、每个保留关键字(指令)都是必须是大写字母
2、执行从上到下顺序
3、#表示注释
4、每一个指令都会创建提交一个新的镜像曾,并提交!

# 创建一个dockerfile文件,名字可以随便 建议Dockerfile
# 文件中的内容: 指令(大写) + 参数
$ vim dockerfile1
    FROM centos 					# 当前这个镜像是以centos为基础的
    VOLUME ["volume01","volume02"] 	# 挂载卷的卷目录列表(多个目录)
    CMD echo "-----end-----"		# 输出一下用于测试
    CMD /bin/bash					# 默认走bash控制台

# 这里的每个命令,就是镜像的一层!
# 构建出这个镜像 
-f dockerfile1 			# f代表file,指这个当前文件的地址(这里是当前目录下的dockerfile1)
-t caoshipeng/centos 	# t就代表target,指目标目录(注意caoshipeng镜像名前不能加斜杠‘/’)
. 						# 表示生成在当前目录下
  • docker build 构建称为一个镜像
$ docker build -f dockerfile1 -t caoshipeng/centos .
Sending build context to Docker daemon   2.56kB
Step 1/4 : FROM centos
latest: Pulling from library/centos
8a29a15cefae: Already exists 
Digest: sha256:fe8d824220415eed5477b63addf40fb06c3b049404242b31982106ac204f6700
Status: Downloaded newer image for centos:latest
 ---> 470671670cac
Step 2/4 : VOLUME ["volume01","volume02"] 			# 卷名列表
 ---> Running in c18eefc2c233
Removing intermediate container c18eefc2c233
 ---> 623ae1d40fb8
Step 3/4 : CMD echo "-----end-----"					# 输出 脚本命令
 ---> Running in 70e403669f3c
Removing intermediate container 70e403669f3c
 ---> 0eba1989c4e6
Step 4/4 : CMD /bin/bash
 ---> Running in 4342feb3a05b
Removing intermediate container 4342feb3a05b
 ---> f4a6b0d4d948
Successfully built f4a6b0d4d948
Successfully tagged caoshipeng/centos:latest

# 查看自己构建的镜像
$ docker images
REPOSITORY          TAG          IMAGE ID            CREATED              SIZE
caoshipeng/centos   latest       f4a6b0d4d948        About a minute ago   237MB
  • docker run运行镜像
    运行自己的镜像 略…

  • docker push发布镜像(DockerHub 、阿里云仓库)

1、地址 https://hub.docker.com/
2、确定这个账号可以登录
3、登录

$ docker login --help
Usage:  docker login [OPTIONS] [SERVER]

Options:
  -p, --password string   Password
      --password-stdin    Take the password from stdin
  -u, --username string   Username

$ docker login -u 你的用户名 -p 你的密码

# push不上去,因为如果没有前缀的话默认是push到 官方的library
# 解决方法:
# 第一种 build的时候添加你的dockerhub用户名,然后在push就可以放到自己的仓库了
$ docker build -t kuangshen/mytomcat:0.1 .

# 第二种 使用docker tag #然后再次push
$ docker tag 容器id kuangshen/mytomcat:1.0 #然后再次push
$ docker push kuangshen/mytomcat:1.0

发布到 阿里云镜像服务上
看官网 很详细https://cr.console.aliyun.com/repository/

docker tag [ImageId] registry.cn-shenzhen.aliyuncs.com/dsadxzc/cheng:[镜像版本号]
docker login --username=zchengx registry.cn-shenzhen.aliyuncs.com

# 修改id 和 版本
docker tag a5ef1f32aaae registry.cn-shenzhen.aliyuncs.com/dsadxzc/cheng:1.0
# 修改版本
docker push registry.cn-shenzhen.aliyuncs.com/dsadxzc/cheng:[镜像版本号]

此处输入图片的描述

DockerFile的指令

FROM				# from:基础镜像,一切从这里开始构建
MAINTAINER			# maintainer:镜像是谁写的, 姓名+邮箱
RUN					# run:镜像构建的时候需要运行的命令
ADD					# add:步骤,tomcat镜像,这个tomcat压缩包!添加内容 添加同目录
WORKDIR				# workdir:镜像的工作目录
VOLUME				# volume:挂载的目录
EXPOSE				# expose:保留端口配置
CMD					# cmd:指定这个容器启动的时候要运行的命令,只有最后一个会生效,可被替代
ENTRYPOINT			# entrypoint:指定这个容器启动的时候要运行的命令,可以追加命令
ONBUILD				# onbuild:当构建一个被继承DockerFile这个时候就会运行onbuild的指令,触发指令
COPY				# copy:类似ADD,将我们文件拷贝到镜像中
ENV					# env:构建的时候设置环境变量!

此处输入图片的描述
此处输入图片的描述

DockerCompose

Docker Compose是一个用来定义和运行复杂应用的Docker工具。一个使用Docker容器的应用,通常由多个容器组成。使用Docker Compose不再需要使用shell脚本来启动容器。 
Compose 通过一个配置文件来管理多个Docker容器,在配置文件中,所有的容器通过services来定义,然后使用docker-compose脚本来启动,停止和重启应用,和应用中的服务以及所有依赖服务的容器,非常适合组合使用多个容器进行开发的场景。

下载地址: curl -L https://get.daocloud.io/docker/compose/releases/download/1.25.1/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
添加操作权限:chmod +x /usr/local/bin/docker-compose
查看:docker-compose --version
安装pip: sudo pip install docker-compose

DockerCompose指令

version   指定本 yml 依从的 compose 哪个版本制定的

build
    	  指定为构建镜像上下文路径
    		context:上下文路径。
    		dockerfile:指定构建镜像的 Dockerfile 文件名。
    		args:添加构建参数,这是只能在构建过程中访问的环境变量。
    		labels:设置构建镜像的标签。
    		target:多层构建,可以指定构建哪一层。
    		
command         覆盖容器启动的默认命令。

container_name  指定自定义容器名称,而不是生成的默认名称。

environment     添加环境变量。

expose          暴露端口,但不映射到宿主机,只被连接的服务访问。

image           指定容器运行的镜像。

restart
		no:是默认的重启策略,在任何情况下都不会重启容器。
		always:容器总是重新启动。
		on-failure:在容器非正常退出时(退出状态非0),才会重启容器。
        unless-stopped:在容器退出时总是重启容器,但是不考虑在Docker守护进程启动时就已经停止了的容器

DockerCompose命令

	docker-compose up //启动yml文件定义的 container
	docker-compose up -d //后台运行
	docker-compose up --help //查看up帮助
	docker-compose -f docker-compose.yml up //-f 指定yml文件
	docker-compose stop //停止
	docker-compose start 
	docker-compose ls  //查看
	docker-compose down //停止删除
	docker-compose ps
	docker-compose images
	docker-compose exec {service_name} {bash}

实付 9.90元
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值