问题
- 安装及配置依赖软件:安装fastdfs步骤非常多,安装繁琐;
- 项目部署问题:项目上线时,需要在服务器上安装和配置项目运行环境(依赖包和配置),当换一台新的服务器,项目运行环境需要再重新装一遍
fastdfs + 全文检索 + Redis + ngixn + uWSGI + python3 (django等一系列的python包) + ...
解决:
1. vmware虚拟机 -> 安装依赖软件并配置 -> 导出ubuntu镜像
-> 新服务器:安装vmware并加载ubuntu镜像
2. 使用docker容器技术 (隔离环境)
docker容器 --> 安装依赖软件并配置 --> 导出docker镜像
--> 新服务器:安装docker并加载docker镜像 -> 根据镜像运行容器
docker是什么?
打包应用及其依赖包到容器中,从而可以将应用快速地部署到任意的Linux系统上。
- 隔离环境
- 性能开销低,启动速度快
Docker相关概念
Docker组件
一、Docker架构 (C/S)
Docker是一个客户端-服务器(C/S)架构程序,类似 redis
- 客户端: docker命令行工具
- 服务器: Docker守护进程(docker引擎)
二、docker镜像 (image):
- 压缩包文件,包含了应用程序及其运行依赖的软件和配置
- 生成镜像: 新镜像 = 现有镜像/官方镜像 + 个性化软件和配置
例: 新镜像 = ubuntu镜像 + fastdfs + nginx
一些镜像举例:
1. 系统级镜像: 如Ubuntu镜像,CentOS镜像等;
2. 工具栈镜像: 如Golang镜像,Flask镜像,Tomcat镜像等;
3. 服务级镜像: 如MySQL镜像,MongoDB镜像,RabbitMQ镜像等;
三、docker仓库 (Registry,注册中心): 保存docker镜像
- 公有仓库
- Docker Hub: Docker的官方仓库,最重要、最常用的 image 仓库。
- https://hub.docker.com/
- 私有仓库
- 是开发者或者企业自建的镜像存储库,用于内部开发和产品的发布
四、docker容器(container)
- 由镜像文件运行得到容器
- 每个容器相互隔离
- 类比
- 镜像: 类
- 容器: 对象
本文将介绍在ubuntu16.04系统下安装和升级docker、docker-compose、docker-machine。
docker:有两个版本:docker-ce(社区版)和docker-ee(企业版)。
笔者这里介绍安装或升级的是最新版docker-ce(社区版)。
参考官网地址:https://docs.docker.com/engine/installation/linux/docker-ce/ubuntu/#os-requirements
docker-compse:可运行和管理多个docker容器。
docker-machine:docker官方提供的docker管理工具。可管理多个docker主机,可搭建swarm集群。
1,卸载旧版本docker
全新安装时,无需执行该步骤
$ sudo apt-get remove docker docker-engine docker.io
2,更新系统软件
$ sudo apt-get update
3,安装依赖包
$ sudo apt-get install \
apt-transport-https \
ca-certificates \
curl \
software-properties-common
4,添加官方密钥
执行该命令时,如遇到长时间没有响应说明网络连接不到docker网站,需要使用代-理进行。
$ curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
显示OK,表示添加成功.
5,添加仓库
$ sudo add-apt-repository \
"deb [arch=amd64] https://download.docker.com/linux/ubuntu \
$(lsb_release -cs) \
stable"
6,再次更新软件
经实践,这一步不能够省略,我们需要再次把软件更新到最新,否则下一步有可能会报错。
$ sudo apt-get update
7,安装docker
如果想指定安装某一版本,可使用 sudo apt-get install docker-ce=
以下命令没有指定版本,默认就会安装最新版
$ sudo apt-get install docker-ce
8,查看docker版本
$ docker -v
显示“Docker version 17.09.0-ce, build afdb6d4”字样,表示安装成功。
9.docker的启动与停止
# 启动docker
sudo service docker start
# 停止docker
sudo service docker stop
# 重启docker
sudo service docker restart
1,下载docker-compose
$ sudo curl -L https://github.com/docker/compose/releases/download/1.17.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
2,授权
$ sudo chmod +x /usr/local/bin/docker-compose
3,查看版本信息
$ docker-compose --version
显示出版本信息,即安装成功。
三、docker-machine安装
说明:docker-machine的使用是要基于virtualBox的。如果没有安装安装过,请先安装virtualBox。
1,安装virtualBox
登录virtualBox官网:https://www.virtualbox.org/wiki/Linux_Downloads
找到"Ubuntu 16.04 ("Xenial") i386 | AMD64"字样,点击“AMD64”进行下载。
下载后,执行以下命令进行安装:
$ sudo dpkg -i virtualbox-5.2_5.2.0-118431_Ubuntu_xenial_amd64.deb
2,下载并安装docker-machine
$ curl -L https://github.com/docker/machine/releases/download/v0.13.0/docker-machine-`uname -s`-`uname -m` >/tmp/docker-machine &&
chmod +x /tmp/docker-machine &&
sudo cp /tmp/docker-machine /usr/local/bin/docker-machine
3,查看版本信息
$ docker-machine version
显示出版本信息,即安装成功。
# 一、列出镜像
sudo docker image ls
# 二、加载镜像
# 1.拉取官方的镜像 (Docker官方提供的镜像,都放在默认的组library中,可以省略)
sudo docker image pull library/hello-world
sudo docker image pull hello-world
# 2.加载本地镜像
sudo docker load -i ./ubuntu.tar
sudo docker load -i fastdfs_docker.tar
# 三、删除镜像 (没有创建容器的镜像才可以删)
sudo docker image rm 镜像名或镜像id
例: sudo docker image rm hello-world
一、创建容器(根据镜像运行容器)
sudo docker run [option] 镜像名:TAG [向启动容器中传入的命令] # 说明 :TAG 部分可以省略
# 示例1:创建交互式容器
sudo docker run -it --name=myubuntu ubuntu /bin/bash
# 示例2:创建守护式容器
sudo docker run -dit --name=myubuntu2 ubuntu
常用可选参数说明:
--name 为创建的容器命名
-i 表示以“交互模式”运行容器 --interactive
-t 表示容器启动后会进入其命令行。常与-i连用,加入这两个参数后,容器创建就能进入容器
-d Run container in background and print container ID --detach 解绑
守护式容器,后台运行,而不会自动进入容器(命令行);
如果只加-i -t 两个参数,创建后就会自动进入容器(命令行)
-v 目录映射关系,使用格式: 宿主机目录:容器中目录,可以使用多个-v做多个目录或文件映射 --volume
注意: 最好做目录映射,在宿主机上做修改,然后共享到容器上。
--network=host 表示将主机的网络环境映射到容器中,容器的网络与主机相同
-p 表示端口映射,前者是宿主机端口,后者是容器内的映射端口。可以使用多个-p 做多个端口映射
-e 为容器设置环境变量
二、查看容器
# 列出本机正在运行的容器
sudo docker container ls
# 列出本机所有容器,包括已经终止运行的
sudo docker container ls --all
三、启动和停止容器
# 启动一个已经停止的容器
sudo docker container start 容器名或容器id
# 停止一个已经在运行的容器
sudo docker container stop 容器名或容器id
# 杀掉一个已经在运行的容器
sudo docker container kill 容器名或容器id
四、删除容器:不能删除正在运行的容器
sudo docker container rm 容器名或容器id
五、进入已运行的容器(请参考下图)
sudo docker exec -it 容器名或容器id 进入后执行的第一个命令
sudo docker exec -it myubuntu2 /bin/bash
六、将容器保存为镜像
sudo docker commit 容器名 镜像名
七、镜像备份与迁移
# 我们可以通过save命令将镜像打包成文件,拷贝给别人使用
sudo docker save -o 保存的文件名 镜像名
sudo docker save -o ./ubuntu.tar ubuntu
# 在拿到镜像文件后,可以通过load方法,将镜像加载到docker中
sudo docker load -i ./ubuntu.tar
1 从容器拷贝文件到宿主机
拷贝方式为:
docker cp 容器名:容器中要拷贝的文件名及其路径 要拷贝到宿主机里面对应的路径
例如,将容器:
mycontainer
中路径:
/opt/testnew/
下的文件:
file.txt
拷贝到宿主机:
/opt/test/
路径下,在宿主机中执行命令如下:
docker cp mycontainer:/opt/testnew/file.txt /opt/test/
2 从宿主机拷贝文件到容器
拷贝方式为:
docker cp 宿主机中要拷贝的文件名及其路径 容器名:要拷贝到容器里面对应的路径
例如,将宿主机中路径:
/opt/test/
下的文件:
file.txt
拷贝到容器:
mycontainer
的:
/opt/testnew/
路径下,同样还是在宿主机中执行命令如下:
docker cp /opt/test/file.txt mycontainer:/opt/testnew/
注意:不管容器有没有启动,拷贝命令都会生效。