版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
Docker技术与实践Docker技术与实践1第一部分Docker介绍及原理第一部分Docker介绍及原理2什么是Docker?Docker是一个构建在LXC之上,基于进程容器的轻量级VM解决方案,实现了一种应用程序级别的资源隔离及配额。Docker起源于PaaS提供商dotCloud基于go语言开发,遵从Apache2.0开源协议。什么是Docker?Docker是一个构建在LXC之3认识DockerNamespaces(IBM)Cgroups(Google)LXCtoolsTheLinuxKernelGitSELinux(RedHat)SolarisZonesBSDJails+++Docker如何和Linux内核打交道?Docker平台工具、守护进程Image镜像,包括应用及系统的只读数据包Container容器,虚拟机的运行实例Registry仓库登记,管理镜像文件DockerhubDocker官方公有仓库Docker专业术语认识DockerNamespaces(IBM)Docker4DockerVSVMDockerVSVM5Docker的原理pid-进程net-网络ipc-消息mnt-文件系统uts-分时user-用户Namespace资源隔离LinuxKernelrootnamespaceinitpid=1initpid=2bashpid=3bashpid=4Xnamespaceinitpid=1bashpid=2Docker的原理pid-进程Namespace资源隔6Docker文件系统Docker镜像位于bootfs之上每一层镜像的下面一层称为其父镜像(父子关系)第一层镜像为BaseImage容器在最顶层其下的所有层都为readonlyDocker将readonly的FS层称作"image"DockerAUFS特性Docker文件系统Docker镜像位于bootfs之上Do7第二部分Docker基本操作第二部分Docker基本操作8Docker三大核心容器Container镜像images仓库RepositoriesdockerHub(publicregistry)Docker-registry(privateregistry)Docker三大核心容器镜像仓库dockerHubDock9Docker操作-仓库dockersearchcentos6dockerpullcentos:latestdockerpushyorko/mysql:v2dockerlogin仓库相关命令Docker操作-仓库dockersearchcent10Docker操作-镜像dockerimagesdockerrmicentos:latestdockerbuild-t="yorko/mysql:v1".dockerexport<CONTAINERID>>/home/export.tarcat/home/export.tar|dockerimport-yorko-1-export:latestdockersaveyorko-1>/home/save.tardockerload</home/save.tar镜像相关命令Docker操作-镜像dockerimages镜像相关命11Docker操作-容器dockerrun-d--dns-p8080:80-p2022:22-v/data:/data–v/etc/httpd/conf:/etc/httpd/conf-v/etc/httpd/conf.d:/etc/httpd/conf.d–v/etc/localtime:/etc/localtime:ro--namewebserver1webserver:v3/usr/sbin/apache2-DFOREGROUNDdockerstart/stop/restart/attach/killwebserver1容器运行相关命令Docker操作-容器dockerrun-d--dn12Docker操作-DockerfileFROMubuntu/14.04MAINTAINERguol##installsshRUNapt-getinstallopenssh-server-y##configsshRUNmkdir/var/run/sshdRUNuseradd–s/bin/bash–m–d/home/guolguolRUNecho‘guol:123456’|chpasswdENVRUNNABLE_USER_DIR/home/guolEXPOSE22CMD["/usr/sbin/sshd-D"]Dockerfile介绍Docker操作-DockerfileFROMubuntu13Docker操作-APIimportdockerc=docker.Client(base_url='tcp://2:2375',version='1.14',timeout=10)c.create_container(image="yorko/webserver:v1",stdin_open=True,tty=True,command="/usr/bin/supervisord-c/etc/supervisord.conf",volumes=['/data'],ports=[80,22],name="webserver")importdockerc=docker.Client(base_url='tcp://2:2375',version='1.14',timeout=10)r=c.start(container='webserver',binds={'/data':{'bind':'/data','ro':False}},port_bindings={80:80,22:2022},lxc_conf=None,
publish_all_ports=True,links=None,privileged=False,
dns=None,dns_search=None,volumes_from=None,network_mode=None,
restart_policy=None,cap_add=None,cap_drop=None)Pydocker
api操作Docker操作-APIimportdockerimpor14第三部分Docker实践案例第三部分Docker实践案例15待解决的问题1、如何实现自动发现?2、如何支持多台主宿机?3、容器服务的高可用如何保障?5、如何实现资源最大化利用?4、如何保证容器服务负载均衡?待解决的问题1、如何实现自动发现?2、如何支持多台主宿机?316案例架构说明HTTPrequestHaproxy(M)Haproxy(S)Confdhaproxy.cfgEtcdmasterEtcdslaveServer_1Container_1Apponport23842Container_2Apponport23843DockerServer_2Container_1Apponport14512Container_2Apponport14513DockerREST-APIHaproxy.cfg[Shell]DockerrunCurletcdsetEtcdConfd架构流程案例架构说明HTTPrequestHaproxy(M)Ha17应用场景:1.对应用进行自动打包和部署2.创建轻量、私有的PAAS环境3.自动化测试和持续整合与部署4.部署和扩展Web应用、数据库和后端服务最后:A.DockerVSVMB.微服务架构容器镜像仓库应用场景:1.对应用进行自动打包和部署2.创建轻量、私有的P18为更好满足学习和使用需求,课件在下载后可以自由编辑,请根据实际情况进行调整Inordertobettermeettheneedsoflearningandusing,thecoursewareisfreelyeditedafterdownloading为更好满足学习和使用需求,课件在下载后可以自由编辑,请根据实19Docker技术与实践Docker技术与实践20第一部分Docker介绍及原理第一部分Docker介绍及原理21什么是Docker?Docker是一个构建在LXC之上,基于进程容器的轻量级VM解决方案,实现了一种应用程序级别的资源隔离及配额。Docker起源于PaaS提供商dotCloud基于go语言开发,遵从Apache2.0开源协议。什么是Docker?Docker是一个构建在LXC之22认识DockerNamespaces(IBM)Cgroups(Google)LXCtoolsTheLinuxKernelGitSELinux(RedHat)SolarisZonesBSDJails+++Docker如何和Linux内核打交道?Docker平台工具、守护进程Image镜像,包括应用及系统的只读数据包Container容器,虚拟机的运行实例Registry仓库登记,管理镜像文件DockerhubDocker官方公有仓库Docker专业术语认识DockerNamespaces(IBM)Docker23DockerVSVMDockerVSVM24Docker的原理pid-进程net-网络ipc-消息mnt-文件系统uts-分时user-用户Namespace资源隔离LinuxKernelrootnamespaceinitpid=1initpid=2bashpid=3bashpid=4Xnamespaceinitpid=1bashpid=2Docker的原理pid-进程Namespace资源隔25Docker文件系统Docker镜像位于bootfs之上每一层镜像的下面一层称为其父镜像(父子关系)第一层镜像为BaseImage容器在最顶层其下的所有层都为readonlyDocker将readonly的FS层称作"image"DockerAUFS特性Docker文件系统Docker镜像位于bootfs之上Do26第二部分Docker基本操作第二部分Docker基本操作27Docker三大核心容器Container镜像images仓库RepositoriesdockerHub(publicregistry)Docker-registry(privateregistry)Docker三大核心容器镜像仓库dockerHubDock28Docker操作-仓库dockersearchcentos6dockerpullcentos:latestdockerpushyorko/mysql:v2dockerlogin仓库相关命令Docker操作-仓库dockersearchcent29Docker操作-镜像dockerimagesdockerrmicentos:latestdockerbuild-t="yorko/mysql:v1".dockerexport<CONTAINERID>>/home/export.tarcat/home/export.tar|dockerimport-yorko-1-export:latestdockersaveyorko-1>/home/save.tardockerload</home/save.tar镜像相关命令Docker操作-镜像dockerimages镜像相关命30Docker操作-容器dockerrun-d--dns-p8080:80-p2022:22-v/data:/data–v/etc/httpd/conf:/etc/httpd/conf-v/etc/httpd/conf.d:/etc/httpd/conf.d–v/etc/localtime:/etc/localtime:ro--namewebserver1webserver:v3/usr/sbin/apache2-DFOREGROUNDdockerstart/stop/restart/attach/killwebserver1容器运行相关命令Docker操作-容器dockerrun-d--dn31Docker操作-DockerfileFROMubuntu/14.04MAINTAINERguol##installsshRUNapt-getinstallopenssh-server-y##configsshRUNmkdir/var/run/sshdRUNuseradd–s/bin/bash–m–d/home/guolguolRUNecho‘guol:123456’|chpasswdENVRUNNABLE_USER_DIR/home/guolEXPOSE22CMD["/usr/sbin/sshd-D"]Dockerfile介绍Docker操作-DockerfileFROMubuntu32Docker操作-APIimportdockerc=docker.Client(base_url='tcp://2:2375',version='1.14',timeout=10)c.create_container(image="yorko/webserver:v1",stdin_open=True,tty=True,command="/usr/bin/supervisord-c/etc/supervisord.conf",volumes=['/data'],ports=[80,22],name="webserver")importdockerc=docker.Client(base_url='tcp://2:2375',version='1.14',timeout=10)r=c.start(container='webserver',binds={'/data':{'bind':'/data','ro':False}},port_bindings={80:80,22:2022},lxc_conf=None,
publish_all_ports=True,links=None,privileged=False,
dns=None,dns_search=None,volumes_from=None,network_mode=None,
restart_policy=None,cap_add=None,cap_drop=None)Pydocker
api操作Docker操作-APIimportdockerimpor33第三部分Docker实践案例第三部分Docker实践案例34待解决的问题1、如何实现自动发现?2
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 缺血中风患者日常生活指导方案
- 医院屋面防水技术方案
- 《变化的量》(学案)2023-2024学年数学 六年级下册
- 艺术展览垫资协议书
- 冷链物流运输合同注意事项
- (2024版)副食购销合同范本(甲乙双方)
- 跨国企业文化融合方案
- 2024年医药产品研发与临床试验合同
- 2024年别墅区旅游开发与合作合同
- 2024年全球电商框架:货物买卖合同指南
- 中石油克拉玛依石化有限责任公司招聘笔试题库2024
- 上海市市辖区(2024年-2025年小学四年级语文)部编版期末考试(下学期)试卷及答案
- 上海市高行中学2024-2025学年高二上学期9月质量检测数学试卷
- 【期中考后反思】《反躬自省,砥砺奋进》-2022-2023学年初中主题班会课件
- 2019新教材人教版生物必修1教材课后习题答案
- 保险的免责协议书模板
- 2024年中国白酒行业数字化转型研究报告-36氪-202409
- 《学校主人公:3 校园广播站》教学设计-2024-2025学年五年级上册综合实践活动沪科黔科版
- 胸外科快速康复护理课件
- 外伤急救包扎技术说课课件
- 清淡的晚餐(课件)六年级上册劳动北京版
评论
0/150
提交评论