目录

1.Docker概念:

1.Docker解决的问题:

2.DokcerHub:

2.安装Docker:

3.Docker架构

4.docker命令:

1.操作进程命令:

2.查看帮助:

3.操作镜像命令:

4.操作容器命令:

5.操作数据卷:

5.Docker 应用部署

1.部署MySQL

2.部署Tomcat

3.部署Nginx

4.部署Redis


1.Docker概念:

  1. Docker是一个开源的应用容器引擎
  2. 诞生于2013年初,基于Go语言实现,dotCloud公司出品(后改名为Docker Inc)
  3. Docker可以让开发者打包他们的应用以及依赖包到一个轻量级,可移植的容器中,然后发布到任何流行的Linux机器上
  4. 可以将程序及其依赖、运行环境一起打包为一个镜像,可以迁移到任意Linux操作系统
  5. 容器时完全使用沙箱机制,相互隔离
  6. 容器性能开销极低
  7. Docker从17.03版本之后分为CE(社区版)和EE(企业版)
  8. 总结:
    docker是一种容器技术,解决软件跨环境迁移的问题

1.Docker解决的问题:

  • Docker如何解决依赖的兼容问题:
  • 将应用的Libs(函数库)、Deps(依赖)、配置与应用一起打包
  • 将每个应用放到一个隔离容器去运行,避免互相干扰
  • 操作系统结构:
  • Docker如何解决不同系统环境的问题:
  • Docker将用户程序与所需要调用的系统(比如Ubuntu)函数库一起打包
  • Docker运行到不同操作系统时,直接基于打包的库函数,借助于操作系统的Linux内核来运行
  • Docker如何解决大型项目依赖关系复杂,不同组件依赖的兼容性问题?
  • Docker允许开发中将应用、依赖、函数库、配置一起打包,形成可移植镜像
  • Docker应用运行在容器中,使用沙箱机制,相互隔离
  • Docker如何解决开发、测试、生产环境有差异的问题
  • Docker镜像中包含完整运行环境,包括系统函数库,仅依赖系统的Linux内核,因此可以在任意Linux操作系统上运行

2.DokcerHub:

  • DockerHub是一个Docker镜像的托管平台。这样的平台称为Docker Registry

2.安装Docker:

  • 如果之前安装过旧版本的Docker,可以使用下面命令卸载: yum remove docker \                 docker-client \                 docker-client-latest \                 docker-common \                 docker-latest \                 docker-latest-logrotate \                 docker-logrotate \                 docker-selinux \                 docker-engine-selinux \                 docker-engine \                 docker-ce
  • 首先需要大家虚拟机联网,安装yum工具 yum install -y yum-utils \           device-mapper-persistent-data \           lvm2 --skip-broken
  • 然后更新本地镜像源: # 设置docker镜像源 yum-config-manager \    --add-repo \   https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo     sed -i 's/download.docker.com/mirrors.aliyun.com\/docker-ce/g' /etc/yum.repos.d/docker-ce.repo yum makecache fast
  • 然后输入命令: yum install -y docker-ce

3.Docker架构

  • Docker是一个CS架构的程序,由两部分组成:
  • 服务端(server):Docker守护进程,负责处理Docker指令,管理镜像,容器等
  • 客户端(client):通过命令或RestAPI向Docker服务端发送指令。可以在本地或远程向服务端发送指令
  • 描述:
  • 镜像(image):Docker将应用程序及其所需的依赖,函数库,环境,配置等文件打包在一起,称为镜像。
  • 容器(Container)
  • 镜像中的应用程序运行后形成的进程就是容器,只是Docker会给容器做隔离,对外不可见
  • 镜像(image)和容器(Container)的关系,就像是面向对象程序设计中的类和对象一样,镜像是静态的定义,容器是镜像文件运行时的实体。容器可以被创建,启动,停止,删除,暂停。
  • 仓库:仓库可看成一个代码控制中心,用来保存镜像

4.docker命令:

1.操作进程命令:

命令

说明

systemctl start docker

启动docker服务

systemctl stop docker

停止docker服务

systemctl restart docker

重启docker服务

systemctl status docker

查看docker服务状态

systemctl enable docker

开机启动docker服务

systemctl disable docker

关闭开机启动docker服务

2.查看帮助:

命令

说明

docker --help

查看docker所有帮助

docker [命令] --help

查看docker相关命令的帮助

3.操作镜像命令:

  • 查看镜像: docker images        # 查看本地的镜像文件 docker images -q     # 查看本地的镜像文件的id
  • 搜索镜像: docker search 镜像名称
  • 拉取镜像: docker pull 镜像名称            # 不写版本号:(下载最新的) docker pull 镜像名称:版本号     # 写版本号: (docker官方搜索寻找版本号)
  • 删除镜像: docker rmi 镜像id                 # 通过image id删除 docker rmi 镜像名称:版本号         # 通过镜像名+版本号删除 docker rmi $(docker images -q)    # 删除所有的镜像

4.操作容器命令:

  • 查看容器: docker ps          # 查看正在运行的容器 docker ps -a       # 查看所有状态的容器 docker ps -aq      # 查看所有容器的id
  • 创建容器:

参数

说明

i

表示容器运行

t

表示给容器分配伪终端

it

表示容器创建后自动进入容器中,退出容器自动关闭

d

表示容器后台创建;需要命令进入容器;退出不会自动关闭容器

id

创建的容器一般称为交互式容器;id创建的容器一般称为守护式容器

/bin/bash

为定义的进入容器的初始化指令;

-p 80:80

将容器的 80端口映射到宿主机的 80 端口

$PWD

为显示当前目录位置

docker run -it --name=容器名称 镜像名:版本号 /bin/bash           # 创建容器+伪终端 docker run -id --name==容器名称 镜像名:版本号 /bin/bash         # 创建容器+后台创建 docker run ... -v 宿主机目录(数据卷名):容器内目录 镜像名称:7     # 创建容器+伪终端+挂载目录

  • 进入容器:

参数

说明

i

表示一直运行(除非关闭客户端)

t

表示给容器分配伪终端

docker exec -it 容器名 定义的指令

  • 退出容器: exit
  • 启动容器: docker start 容器名称 docker update --restart always 容器ID   # 如果容器已经创建,可以通过以下方式更新重启策略(开机自启容器)
  • 停止容器: docker stop 容器名称
  • 删除容器: docker rm 容器名称           # 根据容器名称删除容器 docker rm 容器id            # 根据id删除容器 docker rm 容器名称:版本号    # 根据名称+(版本号)删除容器 docker rm -f 容器名称       # 强制删除容器 docker rm docker ps -aq   # 删除所有容器
  • 查看容器信息: docker inspect 容器名称
  • 查看容器日志: docker logs 容器名         # 根据容器名查看日志 docker logs -f 容器名      # 根据容器名查看日志+跟踪日志

5.操作数据卷:

  • 创建数据卷: #自动创建在/var/lib/docker/volumes目录下 docker volume create 数据卷名
  • 查看数据卷: docker volume ls                  # 查看所有的数据卷名称 docker volume inspect 数据卷名称   # 查看指定数据卷的位置
  • 删除数据卷 docker volume prune            # 删除所有未使用的数据卷 docker volume rm 数据卷名称     # 删除指定的数据卷

5.Docker 应用部署

1.部署MySQL

  1. 搜索mysql镜像

docker search mysql


  1. 拉取mysql镜像

docker pull mysql:5.6


  1. 创建容器,设置端口映射、目录映射
# 在/root目录下创建mysql目录用于存储mysql数据信息
mkdir ~/mysql
cd ~/mysql
 
docker run -id \
-p 3307:3306 \
--name=c_mysql \
-v $PWD/conf:/etc/mysql/conf.d \       
-v $PWD/logs:/logs \
-v $PWD/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 \
mysql:5.6


  • 参数说明:
  • -p 3307:3306:将容器的 3306 端口映射到宿主机的 3307 端口。
  • $PWD:为显示当前目录位置
  • -v $PWD/conf:/etc/mysql/conf.d:将主机当前目录下的 conf/my.cnf 挂载到容器的 /etc/mysql/my.cnf。配置目录
  • -v $PWD/logs:/logs:将主机当前目录下的 logs 目录挂载到容器的 /logs。日志目录
  • -v $PWD/data:/var/lib/mysql :将主机当前目录下的data目录挂载到容器的 /var/lib/mysql 。数据目录
  • -e MYSQL_ROOT_PASSWORD=123456:初始化 root 用户的密码。

# MYSQL8.0以后的版本需要需改加密规则 GRANT ALL ON *.* TO 'root'@'%';      # 授权 flush privileges;       # 刷新权限 ALTER USER 'root'@'localhost' IDENTIFIED BY 'password' PASSWORD EXPIRE NEVER;      # 更改加密规则 ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';      # 更新root用户密码 flush privileges;      # 刷新权限 docker restart [容器名]


  1. 进入容器,操作mysql
docker exec –it c_mysql /bin/bash


  1. 使用外部机器连接容器中的mysql(密码:123456

2.部署Tomcat

  1. 搜索tomcat镜像
docker search tomcat


  1. 拉取tomcat镜像
docker pull tomcat


  1. 创建容器,设置端口映射、目录映射
# 在/root目录下创建tomcat目录用于存储tomcat数据信息
mkdir ~/tomcat
cd ~/tomcat
 
docker run -id --name=c_tomcat \
-p 8080:8080 \
-v $PWD:/usr/local/tomcat/webapps \
tomcat


  • 参数说明:
  • -p 8080:8080:将容器的8080端口映射到主机的8080端口
    -v $PWD:/usr/local/tomcat/webapps:将主机中当前目录挂载到容器的webapps

3.部署Nginx

  1. 搜索nginx镜像
docker search nginx


  1. 拉取nginx镜像
docker pull nginx


  1. 创建容器,设置端口映射、目录映射
# 在/root目录下创建nginx目录用于存储nginx数据信息
mkdir ~/nginx
cd ~/nginx
mkdir conf
cd conf
# 在~/nginx/conf/下创建nginx.conf文件,粘贴下面内容
vim nginx.conf


user  nginx;
worker_processes  1;

error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log  /var/log/nginx/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    keepalive_timeout  65;

    #gzip  on;

    include /etc/nginx/conf.d/*.conf;
    
    server {
        listen        80;   # 监听端口
        server_name        localhost;  # 服务器名称
        location / {
            root        html;
            index        index.html
            proxy_pass        http://39.107.110.18:3000;  # 反向代理,将请求转发
        }
    }
}


返回上层目录


cd ..
 
 
docker run -id --name=c_nginx \
-p 80:80 \
-v $PWD/conf/nginx.conf:/etc/nginx/nginx.conf \
-v $PWD/logs:/var/log/nginx \
-v $PWD/html:/usr/share/nginx/html \
nginx


  • 参数说明:
  • -p 80:80:将容器的 80端口映射到宿主机的 80 端口。
  • -v $PWD/conf/nginx.conf:/etc/nginx/nginx.conf:将主机当前目录下的 /conf/nginx.conf 挂载到容器的 :/etc/nginx/nginx.conf。配置目录
  • -v $PWD/logs:/var/log/nginx:将主机当前目录下的 logs 目录挂载到容器的/var/log/nginx。日志目录

4.部署Redis

  1. 搜索redis镜像
docker search redis


  1. 拉取redis镜像
docker pull redis:5.0


  1. 上传redis.conf配置文件

链接:https://pan.baidu.com/s/1hNZk4aXzlShhMFYcqLyKIQ 提取码:abcd


  1. 创建容器,设置端口映射
docker run -id --name=c_redis -p 6379:6379 -v $PWD/data:/data -v $PWD/redis.conf:/etc/redis/redis.conf redis:6.2.4


  1. 进入redis容器
docker exec -it c_redis /bin/bash


  1. 启动redis客户端:
redis-cli