跟我一起学Docker

跟我一起学Docker

  1. 什么是docker
    docker就是实现轻量级的操作系统虚拟化的解决方案
    翻译过来就是:让项目部署变得更加简单

  2. docker的优势:
    上手快,部署快,启动快,可以快速的部署环境,缩短项目开发的生命周期

  3. docker与传统的虚拟机相比的优势
    传统的虚拟机是建立在电脑的操作系统之上,在此虚拟机上再次安装各种环境,比如在windows上安装ubantu然后在ubantu上配置各种服务
    docker不同,docker是基于liunx的容器技术,直接在docker中部署环境即可

  4. docker的四个重要的组成部分
    1.守护进程:docker是一个传统的C/S架构程序,客户端需要向守护进程发送请求(创建容器等命令),守护进程或者是服务器将完成工作并返回结果
    2.docker的镜像:镜像是docker的基石,docker需要基于镜像进行构建
    3.docker容器:容器中放的是应用程序,用于执行程序

docker镜像可以类比于java中的类,docker容器可以类比为Java中的对象
对象是类创建的,因此我们可以说docker容器是基于docker的镜像创建的
  1. Registry注册中心
    注册中心是用来保存各种docker镜像的
    docker镜像的注册中心

Docker常见命令

  1. 关于镜像的命令:
//查看镜像
docker images
//搜索镜像(例如tomcat镜像)
docker search tomcat
//垃取镜像(冒号后面加上镜像的版本)
docker pull tomcat:7
//删除镜像,按照镜像的id或者是名称来删除
docker rmi 镜像ID
//删除所有的镜像
docker rmi `docker images -q`
  1. 关于容器的命令
//查看正在运行的容器
docker ps
//查看所有的容器
docker ps -a
//查看最后一次运行的容器
docker ps -l
//查看停止的容器
docker ps -f status=exited

创建与启动容器:
创建容器常用的参数说明:

创建容器命令:docker run

-i:表示运行容器

-t:表示容器启动后会进入其命令行。加入这两个参数后,容器创建就能登录进去。即分配一个伪终端。

–name :为创建的容器命名。

-v:表示目录映射关系(前者是宿主机目录,后者是映射到宿主机上的目录),可以使用多个-v做多个目录或文件映射。注意:最好做目录映射,在宿主机上做修改,然后共享到容器上。

-d:在run后面加上-d参数,则会创建一个守护式容器在后台运行(这样创建容器后不会自动登录容器,如果只加-i -t两个参数,创建后就会自动进去容器)。

-p:表示端口映射,前者是宿主机端口,后者是容器内的映射端口。可以使用多个-p做多个端口映射
1>交互式方式创建容器,使用exit命令退出的时候容器不会自动关闭

docker run -it --name=容器名称 镜像名称:标签 /bin/bash

2>守护式方式创建容器,使用exit命令退出的时候容器不会自动关闭

docker run -di --name=容器名称 镜像名称:标签

登陆守护式容器

docker exec -it 容器名称 (或者容器ID)  /bin/bash

停止、启动、删除容器

docker stop 容器名
docker start 容器名
docker rm 容器名(需要先停掉容器)

文件拷贝
将文件拷贝到容器中:

docker cp 需要拷贝的文件或者是目录 容器名称:容器的目录

将容器中的文件拷贝出来

docker cp 容器名称:容器的目录 需要拷贝的文件或者是目录

docker中的目录挂载
在创建容器的时候将宿主机的目录与容器中的目录进行映射,然后我们就可以通过修改宿主机目录中的文件内容来影响容器中的文件,特别是修改一些配置文件的时候就比较方便了。如果容器中没有该目录,那么在容器创建的时候会新建该目录,在容器创建的时候加上-v命令就可以实现目录挂载
docker run -di -v 宿主机的文件目录:容器目录 --name=镜像的名字 镜像:标签
目录挂载的命令为

docker run -di -v /user/local/myhtml:/user/local/myhtml --name=mytomcat tomcat:7-jre7

查看容器的详细信息

docker inspect 容器名{容器Id}

查看容器的IP

docker inspect --format='{{.NetworkSettings.IPAddress}}' 容器名称(容器ID)

通过docker搭建一个mysql的环境
-p 代表端口映射,格式为 宿主机映射端口:容器运行端口
-e 代表添加环境变量 MYSQL_ROOT_PASSWORD 是root用户的登陆密码
连接宿主机的IP ,指定端口为33306

docker run -di --name=mysql_docker -p 33306:3306 -e MYSQL_ROOT_PASSWORD=123456 mysql

通过docker搭建一个tomcat的环境
-p端口映射
-v实现目录挂载,将war包拷贝到webapps下,访问程序

docker run -di --name=myTomcat -p 9000:8080 -v /usr/local/webapps:/usr/local/tomcat/webapps tomcat:7-jre7 

通过docker部署nginx
可以将静态原型部署在nginx上面
将静态原型的文件夹命名为html,使用cp命令将该文件夹拷贝到/nginx/usr/share/nginx/html下

docker -run -di --name=mynginx -p 80:80 nginx

通过docker搭建redis环境

docker -run --name=myredis -p 6379:6379 redis

容器保存为镜像

docker commit 容器名 镜像名称

镜像备份
docker save -o 保存的文件名 原镜像名称
o 指 output

docker save -o tomcat.tar mytomcat

镜像的恢复
docker load -i 保存的镜像名
i 指 input

docker load -i mytomcat.tar

DockerFile

什么是DockerFile
Dockerfile是由一系列命令和参数构成的脚本,这些命令应用于基础镜像并最终创建一个新的镜像。

1、对于开发人员:可以为开发团队提供一个完全一致的开发环境;
2、对于测试人员:可以直接拿开发时所构建的镜像或者通过Dockerfile文件构建一个新的镜像开始工作了;
3、对于运维人员:在部署时,可以实现应用的无缝移植。
DockerFile常见的构建命令

命令 作用
FROM 镜像名称:版本号 定义了基础镜像启动的构件流程
MAINTAINER 名字 声明镜像的创建者
WORKDIR 目录名称 设置工作目录
RUN commond 指定运行的目录,可以写多个
ADD 宿主机文件 容器目录 将宿主机的文件复制到容器内,如果是一个压缩文件,将会在复制后自动解压
ENV key value 设置环境变量,可以写多条
COPY 宿主机文件 容器目录 和ADD相似,但是如果有压缩文件并不能解压

使用DockerFile脚本创建镜像
步骤:

  1. 创建目录
mkdir –p /usr/local/dockerjdk8
  1. 下载jdk-8u171-linux-x64.tar.gz并上传到服务器(虚拟机)中的/usr/local/dockerjdk8目录
  2. 创建文件,文件名必须为Dockerfile
vi Dockerfile
#依赖镜像名称和ID
FROM centos:7
#指定镜像创建者信息
MAINTAINER ITCAST
#切换工作目录
WORKDIR /usr
RUN mkdir  /usr/local/java
#ADD 是相对路径jar,把java添加到容器中
ADD jdk-8u171-linux-x64.tar.gz /usr/local/java/

#配置java环境变量
ENV JAVA_HOME /usr/local/java/jdk1.8.0_171
ENV JRE_HOME $JAVA_HOME/jre
ENV CLASSPATH $JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar:$JRE_HOME/lib:$CLASSPATH
ENV PATH $JAVA_HOME/bin:$PATH
  1. 执行命令构建镜像,注意后边的空格和点不能省略
docker build -t='jdk1.8' .

5.查看镜像是否完成

docker inages

创建docker的私有仓库

  1. 拉取私有仓库镜像
docker pull registry
  1. 启动私有仓库的容器
docker run -di --name=registry -p 5000:5000 registry
  1. 打开浏览器 输入地址http://localhost:5000/v2/_catalog看到{"repositories":[]} 表示私有仓库搭建成功并且内容为空
  2. 设置让docker信任私有仓库,修改daemon.json
vi /etc/docker/daemon.json

添加一下内容并保存退出

{"insecure-registries":["宿主机的ip:5000"]} 

5.重启docker服务

systemctl restart docker

镜像上传至私有仓库

  1. 标记此镜像为私有仓库的镜像
docker tag jdk1.8 宿主机IP地址:5000/jdk1.8

2.重新启动docker私服容器

docker start registry

3.上传标记的镜像

docker push 宿主机的IP:5000/jdk1.8

从docker私服中拉取镜像

1.本地中安装docker
2.设置docker中的daemon.json文件,将私服的docker地址添加至本地的docker中

vi /etc/docker/daemon.json
//添加以下内容
{"registry-mirrors":["docker私服的IP地址:5000"]} 

3.拉取镜像

docker pull docker私服的IP地址:5000/jdk1.8

猜你喜欢

转载自blog.csdn.net/weixin_43794897/article/details/84558699