Docker进阶之九:Dockerfile 及 通过Dockerfile搭建lnmp
一.Dockerfile指令
| 
 指令  | 
 描述  | 
 指令  | 
 描述  | 
| 
 FROM  | 
 构建的新镜像是基于哪个镜像 例如:FROM centos:6  | 
 COPY  | 
 拷贝文件或目录到镜像,用法同上例如:COPY ./start.sh /start.sh  | 
| 
 MAINTAINER  | 
 镜像维护者姓名或邮箱地址 例如:MAINTAINER fruit  | 
 ENTRYPOINT  | 
 ENTRYPOINT的格式和RUN指令格式一样,分为exec格式和shell格式。ENTRYPOINT的目的和CMD一样,都是在指定容器启动程序及参数。ENTRYPOINT在运行时 也可以替代,不过比CMD要略显繁琐,需要通过docker run的参数–entrypoint来指定。 当指定了ENTRYPOINT后,CMD的含义就发生了改变,不再是直接的运行其命令,而是将CMD的内容作为参数传给ENTRYPOINT指令。 运行容器时执行的Shell命令  | 
| 
 RUN  | 
 构建镜像时运行的Shell命令 RUN yum install httpd. (shell形式,该命令在shell中运行,默认情况下/bin/sh -c在Linux中运行)  | 
 VOLUME  | 
 指定容器挂载点到宿主机自动生成的目录或其他容器  | 
| 
 CMD  | 
 CMD的主要是为一个正运行的容器提供默认执行命令。 如果存在多个CMD指令,那么只有最后一个会被执行。如果在容器运行时指定了命令,则CMD指定的默认内容会被替代。 通常在最后,启动一个前台服务保证服务可持续运行 运行容器时执行的Shell命令 CMD ["/usr/sbin/sshd", "-D"] CMD /usr/sbin/sshd –D  | 
 USER  | 
 为RUN、CMD和ENTRYPOINT执行命令指定运行用户  | 
| 
 EXPOSE  | 
 声明容器运行的服务端口  | 
 WORKDIR  | 
 为RUN、CMD、ENTRYPOINT、COPY和ADD设置工作目录  | 
| 
 ENV  | 
 设置容器内环境变量  | 
 HEALTHCHECK  | 
 健康检查 CMD curl -f http://localhost/ || exit 1  | 
| 
 ADD  | 
 拷贝文件或目录到镜像,如果是URL或压缩包会自动下载或自动解压 ADD <src>... <dest> ADD html.tar.gz /var/www/html  | 
 ARG  | 
 在构建镜像时指定一些参数 例如: USER $user # docker build --build-arg user=fruit Dockerfile .  | 
二.Build镜像命令
-t, --tag list # 镜像名称
-f, --file string # 指定Dockerfile文件位置
示例:
  docker build .
  docker build -t shykes/myapp .
  docker build -t shykes/myapp -f /path/Dockerfile /path
##从网络中构建
docker build -t shykes/myapp http://www.example.com/Dockerfile.
三.构建PHP网站环境镜像(切记安装目录中存在php-5.6.31.tar.gz,php.ini)
FROM centos:7
MAINTAINER www.fruit.com
RUN yum install -y gcc gcc-c++ make gd-devel libxml2-devel libcurl-devel libjpeg-devel libpng-devel openssl-devel
ADD php-5.6.31.tar.gz /tmp/
RUN cd /tmp/php-5.6.31 && \
    ./configure --prefix=/usr/local/php \
    --with-config-file-path=/usr/local/php/etc \
    --with-mysql --with-mysqli \
    --with-openssl --with-zlib --with-curl --with-gd \
    --with-jpeg-dir --with-png-dir --with-iconv \
    --enable-fpm --enable-zip --enable-mbstring && \
    make -j 4 && \
    make install && \
    cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf && \
    sed -i "s/127.0.0.1/0.0.0.0/" /usr/local/php/etc/php-fpm.conf && \
    sed -i "21a \daemonize = no" /usr/local/php/etc/php-fpm.conf
COPY php.ini /usr/local/php/etc
RUN rm -rf /tmp/php-5.6.31* && yum clean all
WORKDIR /usr/local/php
EXPOSE 9000
CMD ["./sbin/php-fpm", "-c", "/usr/local/php/etc/php-fpm.conf"]
四.构建nginx环境镜像(切记下载依赖包)
----Dockerfile----
FROM centos:7
MAINTAINER www.xubl.com
RUN yum install -y gcc gcc-c++ make openssl-devel pcre-devel
ADD nginx-1.12.1.tar.gz /tmp
RUN cd /tmp/nginx-1.12.1 && \
    ./configure --prefix=/usr/local/nginx && \
    make -j 2 && \
    make install
RUN rm -rf /tmp/nginx-1.12.1* && yum clean all
COPY nginx.conf /usr/local/nginx/conf
WORKDIR /usr/local/nginx
EXPOSE 80
CMD ["./sbin/nginx", "-g", "daemon off;"]
----nginx.conf----
user  root;
worker_processes  auto;
error_log logs/error.log info;
pid logs/nginx.pid;
events {
    use epoll;
}
http {
include       mime.types;
    default_type  application/octet-stream;
log_format  main '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';
access_log logs/access.log main;
    sendfile        on;
    keepalive_timeout  65;
server {
        listen 80;
        server_name localhost;
        root html;
        index index.html index.php;
location ~ \.php$ {
            root html;
            fastcgi_pass lnmp_php:9000;
            fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
            include fastcgi_params;
        }
    }
}
# docker image build -t nginx:v1 -f Dockerfile .
五.部署lnmp
docker network create lnmp
2、创建PHP容器
# docker run -itd --name lnmp_php --net lnmp --mount type=bind,src=/app/wwwroot/,dst=/usr/local/nginx/html php:v1
3、创建Nginx容器
# docker run -itd --name lnmp_nginx --net lnmp -p 888:80 --mount type=bind,src=/app/wwwroot/,dst=/usr/local/nginx/html nginx:v1
4、创建MySQL容器(如果之前存在lnmp_mysql可不执行)
# docker run -itd --name lnmp_mysql --net lnmp -p 3306:3306 --mount src=mysql-vol,dst=/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7 --character-set-server=utf8
测试是否部署成功:
echo "<?php phpinfo();?>" > /app/wwwroot/index.php
http://192.168.2.73:888/
http://192.168.2.73:88/wordpress
六.构建JAVA网站环境镜像
FROM centos:7
MAINTAINER www.xubl.com
ADD jdk-8u45-linux-x64.tar.gz /usr/local
ENV JAVA_HOME /usr/local/jdk1.8.0_45
ADD apache-tomcat-8.0.46.tar.gz /usr/local
COPY server.xml /usr/local/apache-tomcat-8.0.46/conf
WORKDIR /usr/local/apache-tomcat-8.0.46
EXPOSE 8080
ENTRYPOINT ["./bin/catalina.sh", "run"]
创建容器:
mkdir -p /app/webapps/
docker
 run -itd --name=tomcat -p 8080:8080 --mount
type=bind,src=/app/webapps/,dst=/usr/local/apache-tomcat-8.0.46/webapps 
 tomcat:v1
mkdir -p /app/webapps/ROOT/
vim /app/webapps/ROOT/index.html
hello
http://192.168.2.73:8080/
七.书写Dockerfile总结
1.先创建一个基础系统镜像,然后exec进入到容器内,再把无问题的部署命令复制到dockerfile中
2.不经常修改的文件打包到镜像中,经常改变的配置文件可以用type=bind方式每次只要修改宿主机文件或者nfs文件即可.
备注:依赖包下载地址
tomcat 链接:https://pan.baidu.com/s/1jkC8VoGODK_1JaZKpcc8aw 密码:ndj2
nginx 链接:https://pan.baidu.com/s/1hCPMigLSCuoJpRzCa3bq7w 密码:4le2
pph 链接:https://pan.baidu.com/s/1sRv7azcx5rAnuk5zZZyPzA 密码:5ffk
Docker进阶之九:Dockerfile 及 通过Dockerfile搭建lnmp的更多相关文章
- docker创建nginx+php-fpm+mysql环境(一分钟搭建lnmp)
		
下载镜像 docker pull bitnami/php-fpm #下载php-fpm镜像 docker pull nginx #下载nginx镜像docker pull mysql:5.5.59 # ...
 - Docker快速搭建LNMP环境
		
一.使用Dockerfile制作镜像 前面的博客中已经介绍了如何基于容器制作镜像,此方法的原理是使用一个正在运行的容器,根据生产所需进行配置更改等操作后,使其满足生产环境,再将这个容器打包制作为镜像, ...
 - Docker进阶:容器卷、DockerFile、Docker网络原理
		
1.Docker镜像 1.1镜像是什么 镜像是一种轻量级.可执行的独立软件包,用来打包软件运行环境和机遇运行环境开发的软件. 包含一个软件的所有内容.蒋所有的应用和环境,直接打包为docker镜像,直 ...
 - Docker学习笔记之二,基于Dockerfile搭建JAVA Tomcat运行环境
		
前言 在第一篇文字中,我们完全人工方式,一个命令一个命令输入,实现一个 java tomcat运行环境,虽然也初见成效,但很累人.如果依靠依靠脚本构建一个Tomcat容器实例,一个命令可以搞定,何乐而 ...
 - Docker入门系列之三:如何将dockerfile制作好的镜像发布到Docker hub上
		
这个系列的前两篇文章,我们已经把我们的应用成功地在Docker里通过nginx运行了起来,并且用dockerfile里制作好了一个镜像. Docker入门系列之一:在一个Docker容器里运行指定的w ...
 - 面试官:你说你精通 Docker,那你来详细说说 Dockerfile 吧
		
接上一篇:30分钟快速上手Docker,看这篇就对了! 一. 带着问题学Dockerfile 1.疑问 我们都知道从远程仓库可以pull一个tomcat等镜像下来,然后docker run启动容器,然 ...
 - 掌握了Docker Layer Caching才敢自称精通Dockerfile
		
长话短说: 本次原创将向您展示在Docker中使用Layer Cache以加快镜像构建. 这个话题的初衷在于:应用程序打包过程是很慢的(下载并安装框架&第三方依赖包.生成assets),这在D ...
 - Docker:四、Docker进阶 Windows Docker IIS 部署
		
前面的三篇docker 文档大家看的肯定不过瘾,自己可能也已经上手一试了...不知道有没有发现问题... 哈哈... 我来说说我遇到的问题哦 一.windows docker 镜像越来越大 默认的do ...
 - 测试工程师Docker进阶
		
学习整理来源 B站 狂神说Java https://space.bilibili.com/95256449/ 四.docker镜像 1.镜像是什么 镜像是一种轻量级.可执行的独立软件包,用来打包软件运 ...
 
随机推荐
- bzoj 2588 树上主席树
			
主席树上树,对于每个节点,继承其父亲的,最后跑f[x]+f[y]-f[lca]-f[fa[lca]] 去重竟然要减一,我竟然不知道?? #include<cstdio> #include& ...
 - BZOJ3252: 攻略 可并堆
			
网上有很多人说用dfs序+线段树做...其实stl的堆可以...可并堆可以...很多奇奇怪怪的东西都能做... 可并堆比较好想...也比较好写... 分析: 首先,这是一个网络流做不了的题...数据太 ...
 - Java基础系列--基础排序算法
			
原创作品,可以转载,但是请标注出处地址:https://www.cnblogs.com/V1haoge/p/9082138.html 一.概述 基础排序算法包括:桶排序.冒泡排序.选择排序.插入排序等 ...
 - 华盛顿邮报:FBI 屡次夸大了“手机加密威胁”的数字
			
<华盛顿邮报>周二报道称,美国联邦调查局(FBI)严重夸大了由加密手机所造成的问题.以去年为例,该机构调查人员声称被大约 7800 部涉嫌犯罪活动的加密设备挡在了门外,而准确的数字应该在 ...
 - 经典Hash函数的实现
			
Hash函数是指把一个大范围映射到一个小范围.把大范围映射到一个小范围的目的往往是为了节省空间,使得数据容易保存. 除此以外,Hash函数往往应用于查找上.所以,在考虑使用Hash函数之前,需要明白它 ...
 - go语言调度器源代码情景分析之二:CPU寄存器
			
本文是<go调度器源代码情景分析>系列 第一章 预备知识的第1小节. 寄存器是CPU内部的存储单元,用于存放从内存读取而来的数据(包括指令)和CPU运算的中间结果,之所以要使用寄存器来临时 ...
 - 『OGG 02』Win7 配置 Oracle GoldenGate Adapter Java 踩坑指南
			
上一文章 <__Win7 配置OGG(Oracle GoldenGate).docx>定下了 两个目标: 目标1: 给安装的Oracle_11g 创建 两个用户 admin 和 root ...
 - clang如何获得程序控制流图
			
在低版本的clag中,可以直接clang -cc1 -analyze -cfg-dump 1.c来获得程序控制流图,但较高版本后就不行了 另外clang -cc1默认仅限当前目录,所以会出现fata ...
 - Elasticsearch最佳实践之分片使用优化
			
本文由云+社区发表 作者:老生姜 一.遇到的问题 与大多数分布式系统一样,Elasticsearch按照一定的Hash规则把用户数据切分成多个分片,然后打散到不同机器进行存储,从而实现大规模数据的分布 ...
 - maven 依赖中scope标签的配置范围详解
			
在创建Maven项目时,需要在pom.xml 文件中添加相应的依赖,其中有一个scope标签,该标签是设置该依赖范围 (maven项目包含三种classpath{编译classpath,测试class ...