1.什么是Docker
Docker 最初是 dotCloud 公司创始人 Solomon Hykes 在法国期间发起的一个公司内部项目,使用go语言开发的项目,基于 Linux 内核的 cgroup,namespace,以及 AUFS 类的 Union FS 等技术,对进程进行封装隔离,属于 操作系统层面的虚拟化技术。
2.使用docker的优势
1.更高效的利用系统资源
由于容器不需要进行硬件虚拟以及运行完整操作系统等额外开销,Docker 对系统资源的利用率更高。无论是应用执行速度、内存损耗或者文件存储速度,都要比传统虚拟机技术更高效。因此,相比虚拟机技术,一个相同配置的主机,往往可以运行更多数量的应用。
2.更快速的启动时间
传统的虚拟机技术启动应用服务往往需要数分钟,而 Docker 容器应用,由于直接运行于宿主内核,无需启动完整的操作系统,因此可以做到秒级、甚至毫秒级的启动时间。大大的节约了开发、测试、部署的时间。
3.轻松的迁移
Docker 可以在很多平台上运行,ubuntu,centos,windows等 不用担心运行环境的变化导致应用无法正常运行的情况。
4.持续交付和部署
使用 Docker 可以通过定制应用镜像来实现持续集成、持续交付、部署。开发人员可以通过 Dockerfile来进行镜像构建,并结合 持续集成(Continuous Integration) 系统进行集成测试,而运维人员则可以直接在生产环境中快速部署该镜像,甚至结合 持续部署(Continuous Delivery/Deployment) 系统进行自动部署。
5.与传统虚拟机对比
特性 | 容器 | 虚拟机 |
启动 | 秒 | 分 |
硬盘使用 | M | G |
性能 | 接近原生 | 弱于原生 |
系统支持量 | 单机支持上千个容器 | 一般几十个应用 |
3.docker核心概念
docker仓库(Registry):用来保存各种打包好的软件镜像 https://harbor.assistfc.com/harbor/projects 公共:https://hub.docker.com/
docker镜像(Images):软件打包好的镜像;放在docker仓库中;
docker容器(Container):镜像启动后的实例称为一个容器;容器是独立运行的一个或一组
4.docker安装与使用
1.安装
基于ubuntu系统的安装
apt-get update && apt-get install docker.io
完成后 可通过 docker --version 查看版本
2.基本命令使用
##列出本地images docker images
##含中间映像层 docker images -a
##下载Redis官方最新镜像,相当于:docker pull redis:latest docker pull redis
##下载仓库所有Redis镜像 docker pull -a redis
##下载私人仓库镜像 docker pull bitnami/redis
##单个镜像删除,相当于:docker rmi redis:latest docker rmi redis
##强制删除(针对基于镜像有运行的容器进程) docker rmi -f redis
##多个镜像删除,不同镜像间以空格间隔 docker rmi -f redis tomcat nginx
##删除本地全部镜像 docker rmi -f $(docker images -q)
##(1)编写dockerfile cd /docker/dockerfile vim mycentos
##(2)构建docker镜像 docker build -f /docker/dockerfile/mycentos -t mycentos:1.
查看日志
docker logs -f -t --tail=20 redis
容器的进入与退出
##使用run方式在创建时进入 docker run -it centos /bin/bash
##关闭容器并退出 exit
##仅退出容器,不关闭 快捷键:Ctrl + P + Q
##在 centos 容器中打开新的交互模式终端,可以启动新进程,参数:-i 即使没有附加也保持STDIN 打开;-t 分配一个伪终端 docker exec -i -t centos /bin/bash
##以交互模式在容器中执行命令,结果返回到当前终端屏幕 docker exec -i -t centos ls -l /tmp
##以分离模式在容器中执行命令,程序后台运行,结果不会反馈到当前终端 docker exec -d centos touch cache.txt
查看容器
##查看正在运行的容器
docker ps
##查看正在运行的容器的ID
docker ps -q
##查看正在运行+历史运行过的容器
docker ps -a
##显示运行容器总文件大小
docker ps -s
容器的停止与删除
##停止一个运行中的容器 docker stop redis
##杀掉一个运行中的容器 docker kill redis
##删除一个已停止的容器 docker rm redis
##删除一个运行中的容器 docker rm -f redis
##删除多个容器 docker rm -f $(docker ps -a -q) docker ps -a -q | xargs docker rm
## -l 移除容器间的网络连接,连接名为 db docker rm -l db
## -v 删除容器,并删除容器挂载的数据卷 docker rm -v redis
docker容器镜像制作
后端
FROM openjdk:8-jdk-alpine
MAINTAINER wade.qu <wade.qu@fosun.com
ENV LANG=en_US.UTF-8
VOLUME /opt
RUN apk update upgrade \
&& apk add --no-cache procps unzip curl bash tzdata \
&& ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime \
&& echo "Asia/Shanghai" > /etc/timezone
ADD target/sentinel-dashboard.jar /opt/sentinel-dashboard.jar
EXPOSE 8080
ENTRYPOINT [ "sh", "-c", "java $JAVA_OPTS -server -Djava.security.egd=file:/dev/./urandom -jar /opt/sentinel-dashboard.jar" ]
前端
FROM harbor.assistfc.com/base/nginx:stable
MAINTAINER wade.qu "wade.qu@fosun.com"
WORKDIR /opt
RUN ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
RUN echo 'Asia/Shanghai' >/etc/timezone
RUN rm -f /etc/nginx/conf.d/default.conf
ADD efssc.conf /etc/nginx/conf.d
ADD dist /opt/dist/
参数化构建
FROM harbor.assistfc.com/base/efssc-openjdk-1.8:1.0.0
MAINTAINER wade.qu <wade.qu@fosun.com
ENV LANG=en_US.UTF-8
ENV JAVA_OPTS="-javaagent:/opt/agent/skywalking-agent.jar"
ARG appname
ARG jarname
ENV appname ${appname}
VOLUME /opt
ADD ${jarname} /opt/${appname}.jar
COPY agent /opt/agent
EXPOSE 8080
ENTRYPOINT ["sh", "-c", "java ${JAVA_OPTS} -server -Djava.security.egd=file:/dev/./urandom -jar /opt/${appname}.jar"]
构建
docker build --build-arg appname=${appname} --build-arg jarname=${jarname} -t ${harborrepo}/${dev}/${appname}:${tagname} -f ${apptype}Dockerfile .
docker基本介绍完毕 后续可使用k8s相关操作