Awesome Open Source
Awesome Open Source

LNMP Docker - 在国内快速构建LNMP容器环境

3分钟构建开发、测试、生产L(Alpine Linux ) + N(Nginx) + M(MariaDB) + P(PHP) Docker 容器应用环境,升级信息参考

Docker

主要特性

  • 基于PHP 7.1版本,构建干净、轻量级PHP依赖环境。
  • 基于Alpine Linux 最小化Linux环境加速构建镜像。 使用 阿里巴巴开源镜像站 在国内3分钟完成整个镜像构建。
  • 内置PHP Composer,支持PHP CLI/FPM两种运行模式。PHP CLI 适用于命令行、后台PHP服务。PHP FPM基于CLI基础镜像,独立安装FPM模块。Nginx容器与PHP-FPM采用Socket方式连接,提供PHP Web应用环境。
  • 提供PHP CLI模式独立运行模式参考:call-websocktphp-superviosrcall-websockt 是基于workman 的PHP Socket服务。php-supervior 实现基于Supervisor的队列服务。
  • 可独立配置容器运行时环境参数,支持容器运行日志、数据与宿主机分离,方便调试与维护。
  • 支持Nginx虚拟站点、SSL证书服务。配置参考Nginx中certconf.d目录文件。
  • 支持多个虚拟站点内部程序互通。
  • 使用Docker Compose 编排容器,支持在开发、测试、生产环境中快速完成服务器搭建任务。

安装Docker与Docker Compose

本项目基于CentOS 7构建,安装Docker环境参考官网。国内环境,推荐使用阿里云Docker Hub加速器服务。

$ sudo mkdir -p /etc/docker
$ sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://muehonsf.mirror.aliyuncs.com"]
}
EOF
$ sudo systemctl daemon-reload
$ sudo systemctl restart docker

推荐Github官网安装Docker Compose。

$ curl -L https://github.com/docker/compose/releases/download/1.13.0/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose

$ chmod +x /usr/local/bin/docker-compose

安装LNMP Docker

  1. 克隆Git仓库。需要提前安装好Git。

    $ git clone https://github.com/bravist/lnmp-docker && cd lnmp-docker
    
  2. 配置.env环境参数,一般无需修改默认参数。配置PHP_FPM_DOMAIN 支持Nginx容器虚拟主机互通,配置SUPERVISOR_DOMAIN 支持Supervisor容器项目互通。参考这里了解容器多个项目内部通信机制。

# 生成.env文件
$ cp .env.example .env
  1. [*] 配置定时任务容器环境参数。默认无定时任务,可以参考php-crond/crontabs/default.example开启定时任务。
   $ cd php-crond/crontabs/
   $ cp default.example default
  1. [*] 配置Supervisor后台进程处理任务。默认无后台进程处理,参考php-supervisor/supervisor/default.conf.example 配置多进程任务。

    $ cd php-supervisor/supervisor
    $ cp default.conf.example default.conf
    
  2. 配置Nginx虚拟站点。参考nginx/conf.d 目录下配置,复制一份新的站点配置文件,修改域名与主机目录。

    $ cd nginx/conf.d
    $ cp default.conf a.com.conf
    $ vi a.com.conf
    
    server {
        listen  80;
    
        server_name  a.com;
        root   /usr/share/nginx/html/a.com;
        index  index.html index.htm index.php;
    
        #access_log  /var/log/nginx/log/host.access.log  main;
    
        location / {
            try_files $uri $uri/ /index.php$is_args$query_string;
        }
    
        error_page  404              /404.html;
    
        # redirect server error pages to the static page /50x.html
    
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   /usr/share/nginx/html;
        }
    
        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
        location ~ \.php$ {
            fastcgi_split_path_info ^(.+\.php)(/.+)$;
            fastcgi_pass unix:/var/run/php-fpm.sock;
            fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
            fastcgi_param SCRIPT_NAME $fastcgi_script_name;
            fastcgi_index index.php;
            include fastcgi_params;
        }
    
        location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
        {
            expires      30d;
        }
    
        location ~ .*\.(js|css)?$
        {
            expires      2h;
        }
    
        location ~ /.well-known {
            allow all;
        }
    
        location ~ /\.
        {
            deny all;
        }
    
        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
        location ~ /\.ht {
            deny  all;
        }
    }
    
    

    要在本地主机上访问a.com,需要在hosts文件中添加域名指向。

  3. 使用Docker Compose 快速启动容器。

    $ docker-compose build && docker-compose up -d
    

其他说明

项目源码通过tianon/true 镜像挂载了主机当前项目文件目录: www,推荐在改目录下新建不同子目录,然后在Nginx配置虚拟站点指向到该目录。

项目提供一份在PHP CLI模式中运行PHP应用的参考call-websocket。可以运行Workman这样的WebSocket的应用。在安装的过程中,可以忽略在lnmp-call-websocket 容器错误。

在安装过程中,如遇到问题,可以直接提交ISSUE反馈问题。为减少疑惑,提供一下命令做帮助。

# 查看所有运行和者退出的容器
$ docker ps -a

# 删除停止的容器
$ docker rm -f contianer_name ...

# 快速停止与删除容器组
$ docker-compose down 

# 删除本地docker镜像
$ docker rmi -f image_name ....

# 清除所有已经停止运行的容器
$ docker container prune

所有的容器基于Alpine Linux ,默认使用sh shell,进入容器时使用该命令:docker exec -it container_name sh

$ docker exec -it lnmp-nginx sh

安装 ctop 工具可以帮助查看容器在主机的使用情况。

 $ ctop
 ctop - 15:36:35 CST      10 containers

   NAME                        CID                         CPU                         MEM                         NET RX/TX                   IO R/W                      PIDS
 ◉  lnmp-mariadb                bd3cecff945e                             0%                     179M / 7.64G        90K / 276K                  27M / 0B                    0
 ◉  lnmp-nginx                  f4452c868dcc                             0%                      8M / 7.64G         14M / 5M                    5M / 0B                     0
 ◉  lnmp-php-fpm                a68c55c28995                             0%                      72M / 7.64G        1M / 13M                    20M / 0B                    0
 ◉  lnmp-php-supervisor         15182399966b                             1%                     1.8G / 7.64G        92M / 145M                  26M / 0B                    0
 ◉  lnmp-redis                  279b2f995b2a                             0%                      8M / 7.64G         62M / 16M                   2M / 0B                     0
 ◉  lnmp-www                    09c684094c18                              -                           -             -                           -                           -  

Get A Weekly Email With Trending Projects For These Topics
No Spam. Unsubscribe easily at any time.
docker (2,802
laravel (1,597
dockerfile (850
https (213
lnmp (16

Find Open Source By Browsing 7,000 Topics Across 59 Categories