Docker容器
一、Docker概述
1.Docker为什么出现?
Docker是基于Go语言开发的,开源项目。
一款产品的上线流程:(本地启应用)开发 - (发布到测试环境)测试 - (发布到生产环境)运维
开发 - 运维。
问题:开发在电脑上可以运行,版本更新,导致服务不可用,Linux环境配置十分的麻烦,每一个机器都要部署环境(集群Redis、ES、Hadoop),费时费力。对运维来说,考验极大。之前在服务器配置一个应用的环境Redis、mysql、jdk、ES、Hadoop,配置繁琐,不能跨平台。
思考:发布一个项目(jar+ (Redis mysql jdk es)),项目能不能带上环境安装打包。
Windows——》Linux
传统:开发jar,运维来做
现在:开发打包部署上线,一套流程做完
java – apk – 发布 (应用商店)–张三使用apk – 安装即可!
java – jar(环境)-- 打包项目带上环境(镜像)–(Docker仓库:商店)-- 下载我们发布的镜像 – 直接运行即可。
Docker给以上的问题,提出了解决方案,由此,Docker诞生了!
2.Docker下载网址
官网:https://www.docker.com/
文档地址:https://docs.docker.com/ Docker的文档是超级详细的
仓库地址:https://hub.docker.com
3.Docker与传统虚拟机技术的不同
1)传统的虚拟机:
虚拟出一套硬件,运行一个完整的操作系统,然后在这个系统上安装运行软件。
2)现在的容器:
容器内的应用直接运行在宿主机的内容,没有自己的内核和硬件,所以更轻便了。每个容器间是相互隔离,拥有自己的文件系统,互不影响。
4.Docker的优点
Devops(开发、运维)
1)应用更快速的交付和部署
传统:一堆帮助文档,安装程序。
Docker:打包镜像发布测试,一键运行。
2)更便捷的升级和扩缩容
使用了Docker之后,我们部署应用就和搭积木一样。
3)更简单的系统运维
在容器化之后,我们的开发,测试环境都是高度一致的。
4)更高效的资源利用
Docker是内核级别的虚拟化,可以在一个物理机上可以运行很多的容器实例!服务器的性能可以被压榨到极致。
5)应用更快速的交付和不属实
二、Docker安装
1.Docker的基本组成
1)镜像(image)
docker镜像就好比是一个模板,可以通过这个模板来创建容器服务,tomcat镜像 =》run=》tomcat01容器(提供服务器),通过这个镜像可以创建多个容器(最终服务运行或者项目运行就是在容器中的)。
2)容器(container)
docker利用容器技术,独立运行一个或者一个应用,通过镜像来创建的。
启动,停止,删除,基本命令!
目前就可以把这个容器理解为就是一个简易的Linux系统
3)仓库(register)
仓库就是存放镜像的地方!
仓库分为公有仓库和私有仓库!
阿里云…都有容器服务器(配置镜像加速)
2.配置阿里云镜像加速
// 以下代码分别执行
sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
"registry-mirrors": ["https://oz9mukim.mirror.aliyuncs.com"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker
3.Docker安装步骤
1.环境准备
需要会一点点的Linux的基础
2.CentOS7
3.我使用Xshell连接远程服务器操作
2.环境查看
系统内核 uname -r
系统版本 cat /etc/os-relase
3.帮助文档
1)卸载旧的版本
sudo yum remove docker \
docker-client \
docker-client-latest \
docker-common \
docker-latest \
docker-latest-logrotate \
docker-logrotate \
docker-engine
2)安装需要的安装包
sudo yum install -y yum-utils
3)设置镜像仓库
默认使用国外的镜像,下载速度比较慢
sudo yum-config-manager \
--add-repo \
https://download.docker.com/linux/centos/docker-ce.repo
阿里云docker镜像
yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
4)更新软件包索引
yum makecache fast
5)安装docker docker-ce社区版 ee企业版
sudo yum install docker-ce docker-ce-cli containerd.io
6)启动
sudo systemctl start docker
7)查看是否安装成功
sudo docker version
8)hello-world
sudo docker run hello-world
出现Hello from Docker!即表示启动成功
9)查看下载的hello-world镜像
sudo docker images
10)卸载依赖
sudo yum remove docker-ce docker-ce-cli containerd.io
11)删除资源
sudo rm -rf /var/lib/docker ==》docker默认的工作路径
sudo rm -rf /var/lib/containerd
4.Docker运行流畅图
1)Docker是什么工作的?
Docker是一个Client - Server结构的系统,Docker的守护进程运行在主机上,通过Socket从客户端访问!
DockerServer接收到Docker-Client的指令,就会执行这个命令!
2)Docker为什么比虚拟机快?
1.Docker有着比虚拟机更少的抽象层。
2.docker利用的是宿主机的内核,vm需要Guest OS。
所以说,新建一个容器的时候,docker不需要想虚拟机一样重新加载一个操作系统内核,避免引导,虚拟机是加载Guest OS,分钟级别的,而docker是利用宿主机的操作系统,省略了这个复杂的过程,秒级!
三、Docker命令
1.常用命令
1)帮助命令
docker version # 查看版本
docker info # 显示docker的系统信息,包括镜像和容器的数量
docker 命令 --help # 帮助命令
2)镜像命令
docker images # 查看所有本地的主机上的镜像
docker search # 搜索镜像
docker pull # 下载镜像
docker rmi # 删除镜像
3)容器命令
新建容器并启动
docker run [ 可选参数 ] image
列出所有运行的容器
docker ps 命令
退出容器
exit # 直接容器停止并退出
Ctrl + P + Q # 容器不停止退出
删除容器
docker rm 容器id # 删除指定
启动和停止容器的操作
docker start 容器id # 启动容器
docker restart 容器id # 重启容器
docker stop 容器id # 停止当前正在运行的容器
docker kill 容器id # 强制停止当前容器
常用其他命令
后台启动容器
docker run -d 镜像名 !
查看日志
docker logs -f -t --tail 容器,没有日志
查看容器中进程信息
查看镜像元数据
docker inspect 容器id
进入当前正在运行的容器
docker exec -it 容器id bashShell
或
docker attach 容器id
从容器内拷贝文件到主机上
docker 容器id : 容器内路径 目标主机
小结
attach Attach to a running container #当前shell下attach连接指定运行镜像
build Build an image from a Dockerfile #通过Dockerfile定制镜像
commit Create a new image from a containers changes #提交当前容器为新的镜像
cp Copy files/folders from a container to a HOSTDIR or to STDOUT #从容器中拷贝指定文件或者目录到宿主机中
create Create a new container #创建一个新的容器,同run 但不启动容器
diff Inspect changes on a containers filesystem #查看docker容器变化
events Get real time events from the server#从docker服务获取容器实时事件
exec Run a command in a running container#在已存在的容器上运行命令
export Export a containers filesystem as a tar archive #导出容器的内容流作为一个tar归档文件(对应import)
history Show the history of an image #展示一个镜像形成历史
images List images #列出系统当前镜像
import Import the contents from a tarball to create a filesystem image #从tar包中的内容创建一个新的文件系统映像(对应export)
info Display system-wide information #显示系统相关信息
inspect Return low-level information on a container or image #查看容器详细信息
kill Kill a running container #kill指定docker容器
load Load an image from a tar archive or STDIN #从一个tar包中加载一个镜像(对应save)
login Register or log in to a Docker registry#注册或者登陆一个docker源服务器
logout Log out from a Docker registry #从当前Docker registry退出
logs Fetch the logs of a container #输出当前容器日志信息
pause Pause all processes within a container#暂停容器
port List port mappings or a specific mapping for the CONTAINER #查看映射端口对应的容器内部源端口
ps List containers #列出容器列表
pull Pull an image or a repository from a registry #从docker镜像源服务器拉取指定镜像或者库镜像
push Push an image or a repository to a registry #推送指定镜像或者库镜像至docker源服务器
作业练习
Docker安装Nginx
1. 搜索镜像 search
2. 下载镜像 pull
3. 运行测试
端口暴露的概念
Docker安装Tomcat
部署ES+Kibana
作业:kibana连接es,思考网络如何才能连接过去!
可视化
测试
http://ip:8088
四、Docker镜像
五、容器数据卷
六、DockerFile
七、DockerFile
八、Docker网络原理
九、IDEA整合Docker
十、Docker Compose
十一、Docker Swarm
十二、CI/CD Jenkins
狂神说视频:
https://www.bilibili.com/video/BV1og4y1q7M4?p=5&spm_id_from=pageDriver