分布式环境搭建之 docker篇

1. 什么是docker

在Docker之前,我们肯定要先了解Docker是什么。官网的介绍是“Docker is the world’s leading software container platform.”官方给Docker的定位是一个应用容器平台。至于为什么要做这个Docker,官网上还有这么一句话"Docker is an open platform for developers and sysadmins to build, ship, and run distributed applications, whether on laptops, data center VMs, or the cloud."这句话用一句非常简单的话去概括就是"Build once,Run anyWhere".这一点跟Java很像。那么它这样做是要解决现实中什么问题,我列举几个情况。

1. 合作开发的时候,在本机可以跑,别人的电脑跑不起来

这里我们拿java Web应用程序举例,我们一个java Web应用程序涉及很多东西,比如jdk、tomcat、spring等等。当这些其中某一项版本不一致的时候,可能就会导致应用程序跑不起来这种情况。Docker则将程序直接打包成镜像,直接运行在容器中即可。

2. 服务器自己的程序挂了,结果发现是别人程序出了问题把内存吃完了,自己程序因为内存不够就挂了

这种也是一种比较常见的情况,如果你的程序重要性不是特别高的话,公司基本上不可能让你的程序独享一台服务器的,这时候你的服务器就会跟公司其他人的程序共享一台服务器,所以不可避免地就会受到其他程序的干扰,导致自己的程序出现问题。Docker就很好解决了环境隔离的问题,别人程序不会影响到自己的程序。

3. 公司要弄一个活动,可能会有大量的流量进来,公司需要再多部署几十台服务器

在没有Docker的情况下,要在几天内部署几十台服务器,这对运维来说是一件非常折磨人的事,而且每台服务器的环境还不一定一样,就会出现各种问题,最后部署地头皮发麻。用Docker的话,我只需要将程序打包到镜像,你要多少台服务,我就给力跑多少容器,极大地提高了部署效率。

2. docker常用命令

// 从Docker Hub上拉取镜像
docker pull chaimm/tomcat1.1
// docker pull是从从Docker Hub上拉取镜像的命令
// 后面的chaimm/tomcat是镜像的名称,:1.1是镜像的版本号。

// 创建容器
docker run --name zrz -p 8082:8080 -v /usr/web/gaoxi-log:/opt/tomcat/gaoxi-log chaimm/tomcat:1.1
 //  --name:指定容器的名字
 //  -p:指定容器的端口映射 -p 8082:8080 表示将容器的8080端口映射到宿  主机的8082端口上
 // -v:指定容器数据卷的映射 xxx:yyy 表示将容器yyy目录映射到宿主机的xxx目录上,从而访问宿主机的xxx目录就相当于访问容器的yyy目录。
 // chaimm/tomcat:1.1:表示容器所对应的镜像。

// 查看容器
docker ps -A

// 启动容器
docker start id号

// 关闭容器
docker stop id/name

// 重启容器
docker restart id号

// 进入容器
sudo docker exec -it id号 /bin/bash

你可能感兴趣的:(分布式环境搭建之 docker篇)