😉😉 欢迎加入我们的学习交流群呀!
✅✅1:这是孙哥suns给大家的福利!
✨✨2:我们免费分享Netty、Dubbo、k8s、Mybatis、Spring、Security、Docker、Grpc、消息中间件、Rpc、SpringCloud等等很多应用和源码级别高质量视频和笔记资料,你想学的我们这里都有!
🥭🥭3:QQ群:583783824 📚📚 工作VX:BigTreeJava 拉你进VX群,免费领取!
💞💞4:以上内容,进群免费领取呦~ 💞💞💞💞
一:Docker官方网站
官方文档地址:https://www.docker.com/get-started
中文参考手册:https://docker_practice.gitee.io/zh-cn/
二:什么是Docker
docker是一个容器技术,他是一个容器解决方案,帮助开发人员以及开发团队构建和发布应用。
Docker容器可以将我们的应用程序和应用程序所需要的环境进行整体打包,对于应用来讲不存在环境差异。本地能跑,线上肯定也能跑。
Docker是一个容器技术,他是一个应用容器技术,里边安装的就是我们的应用。他就是用来保证我们的应用环境高度一致。
Docker 使用 Google公司推出的 Go 语言 进行开发实现,基于 Linux 内核的 cgroup, namespace,以及 OverlayFS类的 Union FS等技术,对进程进行封装隔离,属于操作系统层面的虚拟化技术。由于隔离的进程独立于宿主和其它的隔离的进程,因此也称其容器。
容器:可以理解为新起来了一个docker实例就是新起来了一个Linux操作系统。一个linux上安装多个Docker镜像就仿佛是一个linux上安装了多个windows每个windows上跑个QQ。
三:为什么是Docker
1:在开发的时候,在本机测试环境可以跑,生产环境跑不起来
这里我们拿iava web应用程序举例,我们一个ava Web应用程序涉及很多东西,比如idk、tomcat、mysql等软件环境。当这些其中某一项版本不一致的时候,可能就会导致应用程序跑不起来这种情况。Docker则将程序以及使用软件环境直接打包在一起,无论在那个机器上保证了环境一致。
应用程序+Tomcat+Mysql+Es+Redis等等环境应用统统打包。高度保证一致。
示意图:
优势1:一致的运行环境,更轻松的迁移
2:服务器自己的程序挂了,结果发现是别人程序出了问题把内存吃完了,自己程序因为内存不够就挂了
这种也是一种比较常见的情况,如果你的程序重要性不是特别高的话,公司基本上不可能让你的程序独享一台服务器的,这时候你的服务器就会跟公司其他人的程序共享一台服务器,所以不可避免地就会受到其他程序的干扰,导致自己的程序出现问题。Docker就很好解决了环境隔离的问题,别人程序不会影响到自己的程序
docker是进程级别的容器,容器与容器之间是进程级别的隔离,进程之间互不影响,一个应用程序最多把自己容器内的资源吃尽,不能占用其他容器的资源。
优势2:对进程进行封装隔离,容器与容器之间互不影响,更高效的利用系统资源
公司要弄一个活动,可能会有大量的流量进来,公司需要再多部署几十台服务器在没有Docker的情况下,要在几天内部署几十台服务器,这对运维来说是一件非常折磨人的事,而且每台服务器的环境还不一定一样,就会出现各种问题,最后部署地头皮发麻。用Docker的话,我只需要将程序打包到镜像,你要多少台服务,我就给力跑多少容器,极大地提高了部署效率优势3:通过镜像复制N多个环境一致容器