在掌握了docker的基本命令之后,我也是想着去用docker做一点实际的配套环境,就拿自己最常用的lnmp环境来做测试。配套环境运行的顺序依次是mysql->php->nginx,至于为什么,在下面会解释。
1.MySQL
之后服务运行的镜像如无特别的提示,都是从官方拉取的镜像,对于小企业以及个人开发者,官方的镜像更为安全,省心省力。
# 拉取镜像 $ docker pull mysql # 运行MySQL $ docker run MySQL --name mysql -d \ -p 3306:3306 \ -v /var/lib/mysql/:/var/lib/mysql/ \ -e MYSQL_ROOT_PASSWORD=ilovec \
下面依次讲解上面运行各个参数
2.PHP
拉取官方镜像php-fpm,根据自己需要的php版本去下载,但是官方的镜像有些php常用的包没有包含在内,因此我们需要使用dockerfile去重新构建一下,下面是在Dockerfile里面安装mysqli和pdo两个php扩展包。
FROM php:7.1-fpm # Install modules RUN docker-php-ext-install mysqli && docker-php-ext-enable mysqli RUN docker-php-ext-install pdo_mysql CMD ["php-fpm"]
运行php-fpm
docker run -d -p 9000:9000 \ --name php-fpm \ --link mysql \ -v /data/wwwroot/:/data/wwwroot/ \ php-fpm
注意参数当中的--link,这个参数在容器之间的连接十分有用,他会在当前容器的/etc/hosts里面添加一条域名解析,通过该域名可以连接到对应的容器,例如在上述的php-fpm里面,link到mysql,那么在php-fpm里面的php程序可以通过mysql字符串连接到刚刚运行的mysql容器,cat /etc/hosts就可以看到里面的解析记录了。
172.17.0.2 mysql b41d2569c06d
3.Nginx
通过以下命令运行nginx,由于nginx需要通过127.0.0.1:9000端口去连接php-fpm来解析php文件,所以需要通过link来连接php-fpm。
docker run -d -p 80:80 \ --name nginx \ --link php-fpm \ -v /data/wwwroot/:/data/wwwroot/ \ nginx
值得注意的是如果nginx解析文件的时候,如果请求的是静态文件,会直接返回该nginx容器里面的文件到客户端,如果请求的是php文件,他会把这个请求转发到php-fpm,然后php-fpm去本地去找php文件进行解析,也就是php-fpm容器本身的文件。
依次运行上面的3个服务的启动命令之后就可以搭建我们常见的lnmp了。但是每次运行服务都需要运行上面的命令显得有点麻烦,我们可以使用docker-compose命令去进行集中管理。
使用docker-compose
只需要创建一个lnmp目录,然后在lnmp目录下创建docker-compose.yml输入下面命令即可管理集成化的环境。
其实可以通过命令的名字就很容易知道各个指令的含义。
version: 由于docker-compose是一个发展中的工具,很有可能每个版本的指令都有所不同,因此需要在开头声明docker-compose指令的适用版本。
image: 指服务通过哪个镜像进行运行。
depends_on: 这个指明了软件的依赖与哪个软件,其实也是声明了软件运行的顺序。
version: '2' services: mysql: image: "mysql" ports: - "3306:3306" volumes: - /var/lib/mysql/:/var/lib/mysql/ environment: MYSQL_ROOT_PASSWORD: password php-fpm: image: "php-fpm" depends_on: - mysql links: - mysql ports: - "9000:9000" volumes: - /data/wwwroot/:/data/wwwroot/ nginx: image: "nginx" depends_on: - php-fpm links: - php-fpm volumes: - /data/wwwroot/:/data/wwwroot/ ports: - "80:80"
之后在这个lnmp目录下执行compose相关命令就可以控制。
# 运行docker-compose服务 $ docker-compose up -d # 停止服务 $ docker-compose stop # 删除该服务相关的容器 $ docker-compose rm # 运行已存在docker-compose的服务 $ docker-compose start
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
和LAMP不同的是LNMP中的N指的是是Nginx(类似于Apache的一种web服务软件)其他都一样。目前这种环境应用的也是非常之多。Nginx设计的初衷是提供一种快速高效多并发的web服务软件。在静态页面的处理上Nginx的确胜Apache一筹,然而在动态页面的处理上Nginx并不比Apache有多少优势。但是,目前还是有很多爱好者对Nginx比较热衷,随着Nginx的技术逐渐成熟,它在web
我想使用实现以下目标:拥有一个不断接收和写入数据的单例开放套接字,asyncrhon! 这意味着我必须打开一个不断从单个套接字读取的套接字,分派每个消息进行异步处理,并通过套接字异步返回响应。 如何实现这种异步模式? 特别是:如何使用序列化器/反序列化器?据我所知,序列化程序只在新的套接字连接上调用,所以在我的情况下,只在第一条消息的开头调用一次?
准备工作 安装软件 版本 功能 必要程度 Docker 1.12.1 Docker 是 CentOS7.0或其他系统 7.0 Docker的宿主机,本章的讲解都是在CentOS 7.0下进行的。Docker现已支持Windows系统,但考虑到绝大多数Docker容器还是跑在Linux环境下的,故而只讲解Linux环境下的使用。Windows下的安装使用大致类似,请读者自行研究。 是 Maven 3
我正在尝试如何在使用Eureka的Spring Boot应用程序上构建集成测试。说我有考试 我的代码路径中有该 api 调用: 这将NPE。发现客户端返回为空。如果我直接启动 Spring 启动应用程序并自己使用 API,代码工作正常。我在任何地方都没有特定的个人资料用法。我需要为发现客户端配置一些特殊的 wrt Eureka 以进行测试吗?
前文提到的Dockerfile 可以让用户管理一个单独的容器,那幺如果我要管理多个容器呢,例如:我需要管理一个Web应用的同时还要加上其后端的数据库服务容器呢?Compose就是这样的一个工具。让我们看下官网对Compose的定义: Compose 是一个用于定义和运行多容器的Docker应用的工具。使用Compose,你可以在一个配置文件(yaml格式)中配置你应用的服务,然后使用一个命令,即可
我有一个Web服务,每个版本将有多个版本和多个类。我想在启动时动态创建服务激活器,这样我就可以减少配置量,从而更容易维护。开发人员可以放入一个新类,SI会自动拾取它。 我编码了一个Application Listener: 稍后在路由器中,我有以下代码: 但当路由器尝试路由时,我会出现以下错误: 我该怎么做?我需要动态创建服务激活器,并在以后将消息路由到这些激活器。 没有办法在ServiceAct