在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
Docker特点 1)上手快 用户只需要几分钟,就可以把自己的程序“Docker 化”。Docker 依赖于“写时复制” (copy-on-write)模型,使修改应用程序也非常迅速,可以说达到“随心所致,代码即改” 的境界。 随后,就可以创建容器来运行应用程序了。大多数 Docker 容器只需要不到 1 秒中即可 启动。由于去除了管理程序的开销,Docker 容器拥有很高的性能,同时同一台宿主机中也 可以运行更多的容器,使用户尽可能的充分利用系统资源。 2)职责的逻辑分类 使用 Docker,开发人员只需要关心容器中运行的应用程序,而运维人员只需要关心如 何管理容器。Docker 设计的目的就是要加强开发人员写代码的开发环境与应用程序要部署 的生产环境一致性。从而降低那种“开发时一切正常,肯定是运维的问题(测试环境都是正 常的,上线后出了问题就归结为肯定是运维的问题)” 3)快速高效的开发生命周期 Docker 的目标之一就是缩短代码从开发、测试到部署、上线运行的周期,让你的应用 程序具备可移植性,易于构建,并易于协作。(通俗一点说,Docker 就像一个盒子,里面 可以装很多物件,如果需要这些物件的可以直接将该大盒子拿走,而不需要从该盒子中一件 件的取。) 4)鼓励使用面向服务的架构 Docker 还鼓励面向服务的体系结构和微服务架构。Docker 推荐单个容器只运行一个应 用程序或进程,这样就形成了一个分布式的应用程序模型,在这种模型下,应用程序或者服 务都可以表示为一系列内部互联的容器,从而使分布式部署应用程序,扩展或调试应用程序 都变得非常简单,同时也提高了程序的内省性。(当然,可以在一个容器中运行多个应用程 序) 使用Docker做什么 容器提供了隔离性,容器可以为各种测试提供很好的沙盒环境。并且,容器本 身就具有“标准性”的特征,非常适合为服务创建构建块。Docker 的一些应用场景如下:
安装与操作 1. 在Ubuntu中安装Docker 更新ubuntu的apt源索引 sudo apt-get update 安装包允许apt通过HTTPS使用仓库 sudo apt-get install \ apt-transport-https \ ca-certificates \ curl \ software-properties-common 添加Docker官方GPG key curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add - 设置Docker稳定版仓库 sudo add-apt-repository \ "deb [arch=amd64] https://download.docker.com/linux/ubuntu \ $(lsb_release -cs) \ stable" 添加仓库后,更新apt源索引 sudo apt-get update 安装最新版Docker CE(社区版) sudo apt-get install docker-ce 检查Docker CE是否安装正确 sudo docker run hello-world 出现如下信息,表示安装成功 为了避免每次命令都输入sudo,可以设置用户权限,注意执行后须注销重新登录 sudo usermod -a -G docker $USER 2. 启动与停止 安装完成Docker后,默认已经启动了docker服务,如需手动控制docker服务的启停,可执行如下命令 # 启动docker sudo service docker start # 停止docker sudo service docker stop # 重启docker sudo service docker restart 3. Docker镜像操作 1. 列出镜像 docker image ls 2. 拉取镜像 要想获取某个镜像,我们可以使用pull命令,从仓库中拉取镜像到本地,如 docker image pull library/hello-world 由于 Docker 官方提供的 image 文件,都放在library组里面,所以它的是默认组,可以省略。因此,上面的命令可以写成下面这样。 docker image pull hello-world 3. 删除镜像 docker image rm 镜像名或镜像id 4. Docker 容器操作 创建容器 docker run [option] 镜像名 [向启动容器中传入的命令] 常用可选参数说明:
交互式容器 例如,创建一个交互式容器,并命名为myubuntu docker run -it --name=myubuntu ubuntu /bin/bash 在容器中可以随意执行linux命令,就是一个ubuntu的环境,当执行exit命令退出时,该容器也随之停止。 守护式容器 创建一个守护式容器:如果对于一个需要长期运行的容器来说,我们可以创建一个守护式容器。在容器内部exit退出时,容器也不会停止。 docker run -dit --name=myubuntu2 ubuntu 进入已运行的容器 docker exec -it 容器名或容器id 进入后执行的第一个命令 如 docker exec -it myubuntu2 /bin/bash 查看容器 # 列出本机正在运行的容器 docker container ls # 列出本机所有容器,包括已经终止运行的 docker container ls --all 停止与启动容器 # 停止一个已经在运行的容器 docker container stop 容器名或容器id # 启动一个已经停止的容器 docker container start 容器名或容器id # kill掉一个已经在运行的容器 docker container kill 容器名或容器id 删除容器 docker container rm 容器名或容器id 5. 将容器保存为镜像 我们可以通过如下命令将容器保存为镜像 docker commit 容器名 镜像名 6. 镜像备份与迁移 我们可以通过save命令将镜像打包成文件,拷贝给别人使用 docker save -o 保存的文件名 镜像名 如 docker save -o ./ubuntu.tar ubuntu 在拿到镜像文件后,可以通过load方法,将镜像加载到本地 docker load -i ./ubuntu.tar 使用Docker安装FastDFS 1. 获取镜像 可以利用已有的FastDFS Docker镜像来运行FastDFS。 获取镜像可以通过下载 docker image pull delron/fastdfs 加载好镜像后,就可以开启运行FastDFS的tracker和storage了。 2. 运行tracker 执行如下命令开启tracker 服务 docker run -dti --network=host --name tracker -v /var/fdfs/tracker:/var/fdfs delron/fastdfs tracker 我们将fastDFS tracker运行目录映射到本机的 /var/fdfs/tracker目录中。 执行如下命令查看tracker是否运行起来 docker container ls 如果想停止tracker服务,可以执行如下命令 docker container stop tracker 停止后,重新运行tracker,可以执行如下命令 docker container start tracker 3. 运行storage 执行如下命令开启storage服务 docker run -dti --network=host --name storage -e TRACKER_SERVER=10.211.55.5:22122 -v /var/fdfs/storage:/var/fdfs delron/fastdfs storage
执行如下命令查看storage是否运行起来 docker container ls 如果想停止storage服务,可以执行如下命令 docker container stop storage 停止后,重新运行storage,可以执行如下命令 docker container start storage 注意:如果无法重新运行,可以删除/var/fdfs/storage/data目录下的fdfs_storaged.pid 文件,然后重新运行storage。 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持极客世界。 |
请发表评论