制作基础镜像

注意:需要在CentOS6下操作

准备工作

yum -y install febootstrap

下载ISO镜像文件到服务器

mkdir /mnt/centos6/

mount -o loopCentOS-6.8-x86_64-bin-DVD1.iso /mnt/centos6/

安装基础包

febootstrap -i bash -i yum -i iputils -iiproute -i openssh-server  -i gcc -ilibgcc centos6 centos68file:///mnt/centos6/

(-i 安装package, centos6 操作系统版本,centos68安装目录,最后是源地址,必须是http://、ftp://、file://、https://、"")

配置

cd centos68/

vim etc/resolv.conf

; generated by /sbin/dhclient-script
nameserver 114.114.114.114
nameserver 8.8.8.8

cp -rf /root/.bash_profile /root/.bashrcroot/

vim root/.bashrc

# .bashrc

# User specific aliases and functions
alias rm='rm -i'
alias cp='cp -i'
alias mv='mv -i'
alias ll='ls -l' # Source global definitions
if [ -f /etc/bashrc ]; then
./etc/bashrc
fi

chroot ./

yum upgrade -y

如果不需要使用sshd服务,下面不需要配置

生成sshd的key:service sshd restart

配置sshd

etc/ssh/sshd_conf修改

UseDNS no

cat etc/pam.d/sshd

#%PAM-1.0
auth required pam_sepermit.so
auth include password-auth
account required pam_nologin.so
account include password-auth
password include password-auth
# pam_selinux.so close should be the firstsession rule
#session required pam_selinux.so close
#session required pam_loginuid.so
# pam_selinux.so open should only befollowed by sessions to be executed in the user context
#session required pam_selinux.so openenv_params
session optional pam_keyinit.so forcerevoke
session include password-auth

yum clean all

exit

删除不要的目录:rm -rf dev/ index.txt media/ mnt/proc/ selinux/ srv/ sys/ boot/

更改时区为中国cp /usr/share/zoneinfo/Asia/Shanghaietc/localtime

echo > root/.viminfo

echo > root/.bash_history

压缩打包成tar.gz格式

tar --numeric-owner -zcvf /opt/centos6.tar.gz/

需要注意的是,文件打包支持的类型只有(.tar,.tar.gz, .tgz, .bzip, .tar.xz, or .txz)这几种。

导入到docker

注意:在docker机器上执行

dockerimport centos6.tar.gz centos6

编写Dockerfile

注意:在docker机器上执行

cd dockerfile/nginx

注意:下面的env、cgroup的影响范围仅限于在dockerfile中

from centos6:20170620
maintainer lykops
env PATH/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/bin:/sbin/
env PWD /root/
add nginx.repo /etc/yum.repos.d/
run yum install nginx -y
run echo /usr/sbin/nginx >>/etc/rc.local
run echo 'sleep 50000000000000000' >>/etc/rc.local
cmd sh /etc/rc.local

命令不应该立即退出,否则造成容器关闭

生成image

docker build -t centos6:nginx .

docker create centos6:nginx

dockerfile基础知识

概念

Dockerfile来解决自动化部署的问题

Dockfile是一种被Docker程序解释的脚本,由一条一条的指令组成,每条指令对应Linux的一条命令。Docker程序将这些Dockerfile指令翻译真正的Linux命令。Dockerfile有自己书写格式和支持的命令,Docker程序解决这些命令间的依赖关系,类似于Makefile。Docker程序将读取Dockerfile,根据指令生成定制的image。

Dockerfile的指令是忽略大小写的,建议使用大写,使用 # 作为注释,每一行只支持一条指令,每条指令可以携带多个参数。

Dockerfile的指令根据作用可以分为两种,构建指令和设置指令。构建指令用于构建image,其指定的操作不会在运行image的容器上执行;设置指令用于设置image的属性,其指定的操作将在运行image的容器中执行。

基本命令

1、FROM

构建指令,指定基础image,后续的指令都依赖于该指令指定的image。

FROM <image>【:<tag>】

2、MAINTAINER

构建指令,用于将image的制作者相关的信息写入到image中。

MAINTAINER<name>

3、RUN

构建指令,RUN可以运行任何被基础image支持的命令。

RUN <command>

RUN ["executable", "param1", "param2" ... ]

4、CMD

设置指令,用于container启动时指定的操作。该操作可以是执行自定义脚本,也可以是执行系统命令。该指令只能在文件中存在一次,如果有多个,则只执行最后一条。

CMD ["executable","param1","param2"]

CMD command param1 param2

当Dockerfile指定了ENTRYPOINT,那么使用下面的格式:

CMD ["param1","param2"]

ENTRYPOINT指定的是一个可执行的脚本或者程序的路径,该指定的脚本或者程序将会以param1和param2作为参数执行。所以如果CMD指令使用上面的形式,那么Dockerfile中必须要有配套的ENTRYPOINT。

5、ENTRYPOINT

设置指令,指定容器启动时执行的命令,可以多次设置,但只有最后一个有效。

ENTRYPOINT["executable", "param1", "param2"]

ENTRYPOINTcommand param1 param2

该指令的使用分为两种情况,一种是独自使用,另一种和CMD指令配合使用。

当独自使用时,CMD指令和ENTRYPOINT会互相覆盖,只有最后一个CMD或者ENTRYPOINT有效。

CMD指令配合使用来指定ENTRYPOINT的默认参数,这时CMD指令不是一个完整的可执行命令,仅仅是参数部分;ENTRYPOINT指令只能使用JSON方式指定执行命令,而不能指定参数。

FROM ubuntu

CMD ["-l"]

ENTRYPOINT ["/usr/bin/ls"]

6、USER

设置指令,设置启动容器的用户,默认是root用户。

USER daemon

7、EXPOSE

设置指令,该指令会将容器中的端口映射成宿主机器中的某个端口。当你需要访问容器时,可以不是用容器的IP地址而是使用宿主机器的IP地址和映射后的端口。要完成整个操作需要两个步骤,首先在Dockerfile使用EXPOSE设置需要映射的容器端口,然后在运行容器时指定-p选项加上EXPOSE设置的端口,这样EXPOSE设置的端口号会映射成宿主机器中的一个端口号。端口映射是docker比较重要的一个功能,原因在于每次运行容器时,容器的IP地址随机生成的。

8、ENV

构建指令,在image中设置一个环境变量。

ENV <key><value>

设置了后,后续的RUN命令都可以使用,container启动后,可以通过docker inspect查看这个环境变量,也可以通过在docker run --env key=value时设置或修改环境变量。

假如你安装了JAVA程序,需要设置JAVA_HOME,那么可以在Dockerfile中这样写:

ENV JAVA_HOME /path/to/java/dirent

9、ADD

构建指令,所有拷贝到容器中的文件和文件夹权限为0755,uid和gid为0;如果是一个目录,会将该目录下的所有文件添加到容器中,不包括目录;如果文件是可识别的压缩格式,则docker会自动解压;如果<src>是文件且<dest>中不使用斜杠结束,则会将<dest>视为文件,<src>的内容会写入<dest>;如果<src>是文件且<dest>中使用斜杠结束,则会<src>文件拷贝到<dest>目录下。

10、VOLUME

设置指令。

VOLUME ["<mountpoint>"]

11、WORKDIR(切换目录)

设置指令,可以多次切换(相当于cd命令),对RUN,CMD,ENTRYPOINT生效。

WORKDIR /path/to/workdir

[置顶] docker--基础镜像和dockerfile的更多相关文章

  1. linux 创建docker基础镜像

    通过Dockerfile创建镜像时,一般都是基于 Docker Hub 提供的官方镜像.以下分别介绍在ubuntu16和centos7 两个系统上创建个人私有基础镜像的方法.  一.ubuntu16创 ...

  2. 庐山真面目之九微服务架构 NetCore 基于 Docker 基础镜像和挂载文件部署

    庐山真面目之九微服务架构 NetCore 基于 Docker 基础镜像和挂载文件部署 一.简介      我们在上一篇文章<庐山真面目之八微服务架构 NetCore 基于 Dockerfile ...

  3. 中标麒麟龙芯平台--docker基础镜像制作

    Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从Apache2.0协议开源.Docker 的出现为开发人员和运维人员带来了极大的便利.Docker在X86下常见的发行版Linux如Ub ...

  4. [置顶] Docker学习总结(1)——Docker实战之入门以及Dockerfile(一)

    一.Docker是什么? 首先Docker是软件工业上的集装箱技术 回顾,在没有集装箱出现以前,传统运输行业中,会存在这些问题: 在运输过程中,货物损坏 装卸.运输货物,效率低下 运输手续繁多及运输环 ...

  5. 从零开始构建docker基础镜像

    段子 今年基本已经结束了,我问了很多朋友今年挣钱了没?大多朋友都有挣,而且挣得五花八门:有挣个屁的,有挣个锤子的,有挣个毛的,更有甚者挣个妹的,奢侈之极!最恐怖的是挣个鬼的!有的还可以,挣个球,下午我 ...

  6. Docker 基础 : 镜像

    目录 获取镜像 查看镜像信息 搜索镜像 删除镜像 创建镜像 导出和导入镜像 上传镜像 总结 镜像是 Docker 的三大核心概念之一.Docker 运行容器前需要本地存在对应的镜像,如果本地没有对应的 ...

  7. 测试环境docker化(一)—基于ndp部署模式的docker基础镜像制作

    本文来自网易云社区 作者:孙婷婷 背景 我所在测试项目组目前的测试环境只有一套,在项目版本迭代过程中,开发或产品偶尔会在测试环境进行数据校验,QA人数在不断增加,各个人员在负责不同模块工作时也会产生脏 ...

  8. [置顶] Docker学习总结(5)——超实用Docker入门学习教程

    Docker是什么 Docker是一种容器技术,它可以将应用和环境等进行打包,形成一个独立的,类似于iOS的APP形式的"应用",这个应用可以直接被分发到任意一个支持Docker的 ...

  9. 『现学现忘』Docker基础 — 34、DockerFile文件详解

    目录 1.DockerFile文件说明 2.Dockerfile构建过程解析 (1)Docker容器构建三步骤 (2)Dockerfile文件的基本结构 (3)Dockerfile注意事项 (4)Do ...

随机推荐

  1. perf 的事件

    perf的事件包括: 硬件事件:branch-instrctions / branch-miss / bus-cycles / cache-miss / cache-reference / cycle ...

  2. 火焰图还有perf

    http://www.brendangregg.com/flamegraphs.html zhangyichun大神的systemtap脚本: https://github.com/openresty ...

  3. 【Luogu】P3760异或和(权值树状数组)

    题目链接 再次声明以后我见到位运算一定第一时间想把它拆成每一位算 本题就是有个前缀和sum[],然后让你求每一位有多少对i,j满足sum[i]-sum[j]在那一位上是1 考虑怎样才能减出1来 如果s ...

  4. CentOS7 安装 webgoat 7.1 简介

    CentOS7 安装 webgoat 7.1 简介 webgoat 所需文件准备: 操作系统版本:CentOS 7.3 1: 在Linux上安装Openjdk >= 1.8 2: 上传文件至 L ...

  5. 【HDU 2594 Simpsons' Hidden Talents】

    Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submission( ...

  6. [解决方案]未能找到路径“~\bin\roslyn\csc.exe”的一部分

    我的WebApi项目使用Nuget加载了一些包以后出现了这样的问题,本地可以访问,但发布到线上后,出现这样的报错 这个问题出现的原因是Nuget的时候,多加载了一些项目可能不需要的依赖库所导致的. 解 ...

  7. Download RPM packages from a YUM repo without installing

    This how-to will explain how to download rpm packages from a yum repository without installing them. ...

  8. angularjs的service

    1.首先我们创建一个模块 var module = angular.module( "my.new.module", [] ); 2.然后写具体的service 可以看到它是一个很 ...

  9. [网络流24题] COGS 运输问题1

    11. 运输问题1 ★★☆   输入文件:maxflowa.in   输出文件:maxflowa.out   简单对比时间限制:1 s   内存限制:128 MB [问题描述]     一个工厂每天生 ...

  10. classes could not be found: - android.support.v7.internal.app.WindowDecorActionBar问题的解决方法

    转载至----http://my.oschina.net/u/2425146/blog/546649?fromerr=aDYrFDVx.仅作个人收藏使用,有转载的朋友请连续原作者,谢谢 刚刚进入stu ...