docker容器通过nginx+php搭建http/https站点

注意:php7需要安装mysql扩展,才能正常连接

准备阶段

# 创建目录:
# cert  		    存放证书文件的目录
# log  		      存放日志文件的目录
# nginx_conf  	存放nginx.conf配置文件的目录
# wwwroot		    存放网站文件的根目录

mkdir -p /www/cert /www/log /www/nginx_conf /www/wwwroot
# nginx.conf配置文件    配置http(跳转到https)/ https 访问 

[root@VM_1_62_centos /]# cat /www/nginx_conf/nginx.conf

worker_processes  2;
events {
    worker_connections  1024;
}
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  /var/log/nginx/access.log  main;
    sendfile        on;
    keepalive_timeout  65;
    root   /usr/share/nginx/html;
    index  index.html index.htm index.php;
    server {
        listen 80;
        server_name localhost;
        location / {
            # 跳转到https进行访问
            # rewrite  ^/(.*)  https://www.xxxxx.net/$1  permanent;
        }
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
        }
        location ~* .*\.(php|php5)?$ {
                    root /usr/share/nginx/html;
                    fastcgi_pass  192.158.0.2:9000;
                    fastcgi_index index.php;
                    include fastcgi.conf;
        }
    }
    server {
        listen 443;
        server_name localhost;
        ssl on;
        ###
        #    配置https域名访问证书
        ### 
        ssl_certificate   cert/1_www.xxxxx.net_bundle.crt;
        ssl_certificate_key  cert/2_www.xxxxx.net.key;
        ssl_session_timeout 5m;
        ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
        ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
        ssl_prefer_server_ciphers on;
        location / {
        }
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
        }
        location ~* .*\.(php|php5)?$ {
                    root /usr/share/nginx/html;
                    fastcgi_pass  192.158.0.2:9000;
                    fastcgi_index index.php;
                    include fastcgi.conf;
        }
    }
}

方式1:Dockerfile

1)编写Dockerfile文件,*****安装php连接mysql的扩展*****
[root@VM_1_62_centos ~]# vim Dockerfile
FROM php:7.2-fpm-alpine3.8
MAINTAINER "eric"
RUN /usr/local/bin/docker-php-ext-install pdo_mysql && /usr/local/bin/docker-php-ext-install mysqli

2)生成镜像 php-fpm-mysqli:v0.1-1 .
[root@VM_1_62_centos ~]# docker build -t php-fpm-mysqli:v0.1-1 .

3)配置网络network
docker network create --driver=bridge --subnet=192.158.0.0/16 root_nginx

4)启动php
docker run -d  --rm --name fpm \
--network root_nginx \
--ip 192.158.0.2 \
-v /www/wwwroot/:/usr/share/nginx/html/ \
php-fpm-mysqli:v0.1-1

5)启动nginx
docker run --name nginx -d --rm \
-v /www/wwwroot/:/usr/share/nginx/html/ \
-v /www/nginx_conf/nginx.conf:/etc/nginx/nginx.conf \
-v /www/cert/:/etc/nginx/cert/ \
-v /www/log/access.log:/var/log/nginx/access.log \
--network root_nginx  \
-p 80:80 -p 443:443 \
nginx:1.14.1-alpine

方式2:docker-compose

# 编写docker-compose.yml文件
[root@VM_1_62_centos ~]# cat /root/docker-compose.yml 
version: "3"
services:
  fpm:
   image: php:7.2-fpm-alpine3.8
   container_name: fpm
   volumes:
      - /www/wwwroot:/usr/share/nginx/html/
   networks:
      nginx:
       ipv4_address: 192.158.0.2

  nginx:
   image: nginx:1.14.1-alpine
   container_name: nginx
   ports:
      - 80:80
      - 443:443
   volumes:
      - /www/wwwroot/:/usr/share/nginx/html/
      - /www/nginx_conf/nginx.conf:/etc/nginx/nginx.conf
      - /www/cert/:/etc/nginx/cert/
      - /www/log/access.log:/var/log/nginx/access.log
   networks:
      nginx:
       ipv4_address: 192.158.0.3

networks:
  nginx:
     driver: bridge
     ipam:
       config: 
         - subnet: 192.158.0.0/16


[root@VM_1_62_centos ~]# docker-compose up -d

[root@VM_1_62_centos ~]# docker ps -a

[root@VM_1_62_centos ~]# docker-compose stop

[root@VM_1_62_centos ~]# docker-compose rm

测试php与mysql的联通性:

[root@VM_1_62_centos /]# cat /www/wwwroot/db.php
<?php
$conn = new mysqli("cdb-xxxxxx.bj.tencentcdb.com:10016", "wordpress", "woxxxxxxxxxxxxxx!#");
if ($conn->connect_error) {
die("connect error: " . $conn->connect_error);
}
echo "connect success!";
?>

注:如有错误,请指正,谢谢!

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

编辑于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏有困难要上,没有困难创造困难也要上!

Docker Error: Error creating cluster component: error while loading TLS Certificate in /var/lib/dock

36860
来自专栏哎_小羊

部署 Kubernetes 集群日志插件 Fluentd、Elasticsearch、Kibana

目录 Kubernetes 日志架构介绍 环境、软件准备 启动 Fluentd 启动 Elasticsearch 启动 Kibana 浏览器添加证书 RBAC...

2.9K90
来自专栏KaliArch

Linux系统检查脚本

对登录一个系统,快速查看其系统信息,检查系统各项指标及参数,编写系统快速检查脚本,输出系统信息到脚本运行的logs目录下。

16440
来自专栏Laoqi's Linux运维专列

Kubernetes 1.8.6 集群部署–Docker私有仓库(九)20180411更新

32440
来自专栏Netkiller

《Netkiller Virtualization 手札》Docker 卷管理

本文节选择《Netkiller Virtualization 手札》Docker 卷管理 1.5. 卷管理 1.5.1. 列出卷 docker volume l...

40290
来自专栏Rainbond开源「容器云平台」

IT苦工指南 | Kubernetes v1.8.x全手动安装

觉得Rainbond提供的既简洁、又易用、而且生产就绪的Kubernets体验不过瘾……

29550
来自专栏Kubernetes

Kubernetes DNS Service技术研究

本文主要是对kubernetes 1.2和1.3的DNS Service的内部实现分别进行研究,得出其内部实现框架和交互逻辑,并对它们的实现进行了比较。 Kub...

43290
来自专栏康怀帅的专栏

使用 Docker 安装 Gogs

使用 Docker Compose 安装 Gogs。 GitHub:https://github.com/khs1994-docker/ci docker-co...

75650
来自专栏云计算教程系列

在你的电脑上运行Kubernetes

Kubernetes 是编配平台的首选。在开发过程中,您不妨在个人电脑上运行 Kubernetes,以便在本地启动和调试应用程序。本文提供了两种在 Mac OS...

26120
来自专栏小狼的世界

Kubernetes中StatefulSet介绍

使用Kubernetes来调度无状态的应用非常简单,那Kubernetes如何来管理调度有状态的应用呢?Kubernetes中提供了一个StatefulSet控...

43340

扫码关注云+社区

领取腾讯云代金券