- 容器技术发展史
也是一种资源隔离的虚拟化技术
-
1979年 UNIX chroot 中提出的概念。chroot是UNIX中的系统调用,将一个进程及其子进程的根目录改变到文件系统中的一个新位置,让这些进程只能访问到这个新的位置,从而达到进程间的隔离的目的。
-
2000年 FreeBSD 开发了类似chroot的容器技术Jails,这是最早也是功能最多的容器技术。Jails翻译是监狱 沙箱更合适 ,其包含了文件系统、用户、网络、进程等的隔离。
-
2001年 Linux发布了自己的容器技术Linux VServer
-
2004年 Solaris发布了SolarisContainers
-
2005年推出OpenVZ 通过对linux内核进行补丁来提供虚拟化支持。
-
2007年 谷歌实现了Control Groups(Cgroups),能够限制和隔离一系列进程的资源使用(CPU、内存、磁盘IO、网络)
-
2008年基于Cgroups和LinuxNamespaces推出了第一个最完善的linux容器LXC ,Linux Containers
-
2013年 DotCloud(后更名Docker)推出到现在为止最流行的容器Docker,其理念·一次构建、随处运行·,起步阶段使用LXC,而后利用自己的libcontainer库(与谷歌合作的)将其替换下来,包含一套高效的分层式容器镜像模型,一套全局以及本地容器注册表,一个精简化RESTApi和一套命令行界面等
-
2014年 CoreOS推出一个类似Docker的容器Rocket,其安全性比Docker更严格
-
2016年 微软在window上提供对容器的支持
-
目前 容器技术趋于成熟,并且迎来了容器元时代,由此衍生出多种容器云的平台管理技术 如k8s(容器编排平台)最为出众,这些细粒度的容器集群管理技术为微服务不断的发展奠定了基石
-
容器与虚拟机的区别
-
容器是一个应用层的抽象,将代码与其依赖打包在一起的,多个容器可以在同一台机器上运行,共享操作系统内核但各种作为独立的进程在用户空间中运行。与虚拟机相比,容器占用的空间更少,瞬间即可完成启动。
-
虚拟机则是物理硬件层的抽象,用于将一台服务器变成多台服务器,允许多个VM在一台机器上运行,每个VM都包含一套操作系统,一个或多个应用,必要的二进制文件和库资源,因此占用大量空间,启动时间也很缓慢。
-
结合使2者的优势,可以为应用的部署和管理提供更好的灵活性
-
3个核心概念
-
镜像
-
一个特殊的分层式文件系统,不包含任何动态数据,创建后内容不会被改变
-
容器
-
镜像运行时的实体:容器的实质是进程,容器的进程运行运行于属于自己的命名空间中,容器存储层的生命周期与容器一样,容器消亡,容器存储层随之消亡,因此任何保存于容器存储层的信息都会随容器删除而丢失。容器不应向其存储层写入任何数据,应该使用数据卷(Volume)或绑定宿主机目标,这这些位置进行读写会跳过容器存储层,性能与稳定性较高。对应容器存储层应该保持无状态化。数据卷的生命周期独立于容器。
-
镜像仓库
-
集中存放镜像文件的地方:一个Docker Registry中可以包含多个仓库(Repostory),每个仓库可以包含多个标签(Tag),每个标签对应一个镜像。通常 一个仓库会包含一个软件的不同版本的镜像,而标签就常用于对应软件的不同版本
-
公用Docker Registry (Docker Hub)和 私有Docker Registry
-
2个版本
-
社区版CE
-
企业版EE
-
安全性高
-
核心优势
-
隔离应用
-
整合资源
-
搭建轻量级私有PaaS环境
-
简化代码流水线助力敏捷开发
-
环境一致性
安装运行
-
Windows10
-
Docke for windows
-
64位专业版
-
支持CPU SLAT功能
-
至少4G RAM
-
BIOS中启用虚拟化
-
启用Hyper-V
-
测试安装
-
docker -v
-
setting中配置共享驱动器设置
-
docker run hello-world
-
Linux
-
使用Hyper-V快速安装Ubuntu
-
安装Hyper-v
-
安装Ubuntu
-
开启SSH服务
-
SSH远程登录
-
安装Docker
-
使用存储库安装
-
使用脚本安装
-
测试使用,不要用于生产环境
-
个人桌面乌班图,生产环境CentOS
-
CentOS
-
Hyper-V搭建
-
VMWare搭建
-
配置网卡
-
安装Docker
-
CentOS默认已安装SSH了
-
学习阶段使用:curl -fsSL https://get.docker.com -o get-docker.sh sh get-docker.sh
基础命令
-
配置管理命名
-
登录命令
-
docker login 【option】【server】
-
-p 密码
-
-u 用户名
-
-stdin 从stdin获取密码
-
server指定仓库地址
-
磁盘占用分析
-
docker system df 【option】
-
–format 格式化输出
-
-v 显示磁盘空间使用详情
-
镜像命令
-
拉取镜像
-
docker image pull 【option】 NAME[:TAG|@DIGEST]
-
-a 从仓库获取所有镜像
-
-disable-content-trust 默认值true 跳过镜像校验
-
-platform 设置镜像所属平台,如果有多个镜像服务
-
列出本地镜像
-
docker image ls 【option】[respostory:TAG]
-
-a 显示所有镜像
-
-digests 显示摘要
-
-f 根据提供的条件过滤输出
-
-format 格式化输出
-
-no-trunc 不要截断输出
-
-q 仅显示数字ID
-
docker images
-
筛选镜像
-
docker images -f
-
格式化输出镜像信息
-
docker images --format
-
查看镜像详情
-
docker image inspect 【image】
-
删除镜像
-
docker image rm 【option】
-
-f 强制删除当前镜像
-
–no-prune 不删除未标记的父级
-
批量删除镜像
-
docker rmi $(docker images -f “dangling=true” -q)
-
清理未使用的镜像
-
docker system prune 【option】
-
-a 删除所有未使用的镜像
-
–filter 提供过滤条件,支持多个
-
-f 强制清理 无需提示
-
–volumes 清理数据卷
-
镜像构建
-
Dockerfile
-
docker image build 【option】
-
–rm 成功构建后删除中间容器
-
-f 指定Dockerfile的名称与路径默认当前路径/Dockerfile
-
-t 以“name:tag”格式命名
-
docker build --rm -f “Dockerfile” -t dingtalk.net:latest
-
镜像历史信息(构建层级)
-
docker image history 【option】
-
-format 格式化输出
-
-H 以人类可读的格式打印大小与日期
-
–no-trunc 不要截断输出
-
修改镜像的名称与标签
-
docker tag SOURCE_IMAGE[:TAG] TARGET_IMAGE[:TAG]
-
镜像推送
-
docker image pull 【option】
-
如果命名空间不一致 则需要docker tag 命名修改名称与标签
-
容器命令
-
docker run 【option】 image
-
docker ps 【option】
-
-f 过滤条件
-
-a 显示所有容器
-
–format 格式化输出
-
- l 显示最新创建的
-
-s 显示大小
-
docker ps --filter
-
如果有多个过滤条件 写多个即可
-
docker ps --format
-
通过配置占位符 进行格式化输出
-
删除容器
-
docker rm 【option】 container
-
-f 强制删除正在执行的容器
-
-l 删除指定容器之间的基础连接
-
-v 删除与容器关联的数据卷
-
删除所有已停止的容器
-
docker rm $(docker ps -a q)
-
docker rm $(docker ps -a q) -f
-
仓库管理命令
-
调试命令
-
辅助工具
-
Kitematic (dockerUI界面管理)
为了做好运维面试路上的助攻手,特整理了上百道 【运维技术栈面试题集锦】 ,让你面试不慌心不跳,高薪offer怀里抱!
这次整理的面试题,小到shell、MySQL,大到K8s等云原生技术栈,不仅适合运维新人入行面试需要,还适用于想提升进阶跳槽加薪的运维朋友。
本份面试集锦涵盖了
- 174 道运维工程师面试题
- 128道k8s面试题
- 108道shell脚本面试题
- 200道Linux面试题
- 51道docker面试题
- 35道Jenkis面试题
- 78道MongoDB面试题
- 17道ansible面试题
- 60道dubbo面试题
- 53道kafka面试
- 18道mysql面试题
- 40道nginx面试题
- 77道redis面试题
- 28道zookeeper
总计 1000+ 道面试题, 内容 又全含金量又高
- 174道运维工程师面试题
1、什么是运维?
2、在工作中,运维人员经常需要跟运营人员打交道,请问运营人员是做什么工作的?
3、现在给你三百台服务器,你怎么对他们进行管理?
4、简述raid0 raid1raid5二种工作模式的工作原理及特点
5、LVS、Nginx、HAproxy有什么区别?工作中你怎么选择?
6、Squid、Varinsh和Nginx有什么区别,工作中你怎么选择?
7、Tomcat和Resin有什么区别,工作中你怎么选择?
8、什么是中间件?什么是jdk?
9、讲述一下Tomcat8005、8009、8080三个端口的含义?
10、什么叫CDN?
11、什么叫网站灰度发布?
12、简述DNS进行域名解析的过程?
13、RabbitMQ是什么东西?
14、讲一下Keepalived的工作原理?
15、讲述一下LVS三种模式的工作过程?
16、mysql的innodb如何定位锁问题,mysql如何减少主从复制延迟?
面试题**
1、什么是运维?
2、在工作中,运维人员经常需要跟运营人员打交道,请问运营人员是做什么工作的?
3、现在给你三百台服务器,你怎么对他们进行管理?
4、简述raid0 raid1raid5二种工作模式的工作原理及特点
5、LVS、Nginx、HAproxy有什么区别?工作中你怎么选择?
6、Squid、Varinsh和Nginx有什么区别,工作中你怎么选择?
7、Tomcat和Resin有什么区别,工作中你怎么选择?
8、什么是中间件?什么是jdk?
9、讲述一下Tomcat8005、8009、8080三个端口的含义?
10、什么叫CDN?
11、什么叫网站灰度发布?
12、简述DNS进行域名解析的过程?
13、RabbitMQ是什么东西?
14、讲一下Keepalived的工作原理?
15、讲述一下LVS三种模式的工作过程?
16、mysql的innodb如何定位锁问题,mysql如何减少主从复制延迟?
17、如何重置mysql root密码?