docker部署lnmp集群

LNMP的网段为:
172.16.10.0/24

服务容器与各个ip:
nginx 172.16.10.10
mysql 172.16.10.20
php 172.16.10.30**

导入一下镜像包:
mysql5.7
php.7.2-fpm.tar
wordpress.tar
nginx.tar

将导入的镜像包导成docker可用的镜像:
docker load < nginx.tar && docker load < wordpress.tar && docker load < mysql-5.7.tar && docker load < nginx.tar && docker load < php.7.2-fpm.tar

宿主机创建两个目录:
分别是:
网站的访问主目录:mkdir /wwwroot
配置文件目录: mkdir /docker

nginx准备工作:
nginx配置文件:/etc/nginx/conf.d
nginx主目录:/usr/share/nginx/html

先运行一个nginx容器,将容器里的nginx主目录和配置文件导出来:
docker run -itd --name test nginx:latest

docker cp test:/etc/nginx /docker

docker cp test:/usr/share/nginx/html /wwwroot

查看80端口,不可被占用:
netstat -anpt | grep 80

准备工作已经完成,接下来开始部署各个服务:

1)创建一个自定义网络:
docker network create -d bridge --subnet 172.16.10.0/24 --gateway 172.16.10.1 lnmp

2)运行nginx:
docker run -itd --name nginx -v /docker/nginx:/etc/nginx -v /wwwroot/html:/usr/share/nginx/html -p 80:80 --network lnmp --ip 172.16.10.10 nginx

更改nginx访问界面:
cd /wwwroot/html
cat index.html
Hello lnmp

访问本机验证:
curl 127.0.0.1
Hello lnmp

浏览器访问出下面就成功:

3)运行mysql:
运行一个mysql容器,并为它创建密码为123.com:
docker run --name mysql -e MYSQL_ROOT_PASSWORD=123.com -d -p 3306:3306 --network lnmp --ip 172.16.10.20 mysql:5.7

登录mysql验证:
先下载一个mysql
[[email protected] ~]# yum -y install mysql

访问验证:
[[email protected] ~]# mysql -u root -p123.com -h 127.0.0.1 -P 3306

随便新建一个库做验证:
MySQL [(none)]> create database name;

再查看有没有刚创建的库:
MySQL [(none)]> show databases;

4)运行php容器:

运行一个php容器
[[email protected] ~]# docker run -itd --name phpfpm -p 9000:9000 -v /wwwroot/html:/usr/share/nginx/html --network lnmp --ip 172.16.10.30 php:7.2-fpm

添加php测试界面:
[[email protected] html]# pwd
/wwwroot/html
[[email protected] html]# vim test.php

<?php
phpinfo();
?>
浏览器访问:出现下面界面就成功

5)修改nginx配置文件,nginx和php连接
[[email protected] conf.d]# pwd
/docker/nginx/conf.d

[[email protected] conf.d]# vim default.conf

10行:添加index.php解析

? index index.html index.htm index.php;

30行:打开模块(去掉#并添加)并更改相信息:

location ~ .php$ {
root /usr/share/nginx/html;
fastcgi_pass 172.16.10.30:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}

重启nginx服务:

[[email protected] conf.d]# docker restart nginx
nginx

关闭防火墙:

[[email protected] conf.d]# systemctl stop firewalld
[[email protected] conf.d]# systemctl disable firewalld

重启docker:

[[email protected] conf.d]# systemctl daemon-reload
[[email protected] conf.d]# systemctl restart docker

重启所有容器:

[[email protected] conf.d]# docker ps -a -q | xargs docker start

接下来是php和mysql的连接,在这里我们使用一个phpMyAdmin的数据库管理工具。

下载导入phpMyAdmin-4.9.1-all-languages

导入需要的包:
[[email protected] html]# pwd
/wwwroot/html

[[email protected] html]# ls
50x.html phpMyAdmin-4.9.1-all-languages.zip
index.html test.php

解压:

[[email protected] html]# unzip phpMyAdmin-4.9.1-all-languages.zip

[[email protected] html]# ls
50x.html phpMyAdmin-4.9.1-all-languages test.php
index.html phpMyAdmin-4.9.1-all-languages.zip

名字太长不好记,待会要在nginx配置文件更改,重命名一下:

[[email protected] html]# mv phpMyAdmin-4.9.1-all-languages phpmyadmin

[[email protected] html]# ls
50x.html phpmyadmin test.php
index.html phpMyAdmin-4.9.1-all-languages.zip

//更改nginx配置文件:

[[email protected] html]# cd /docker/nginx/conf.d/
[[email protected] conf.d]# vim default.conf

27行添加:

   location /phpmyadmin {
            root   /usr/share/nginx/html;
            index   index.html index.htm index.php;    }

41行添加:

location ~ /phpmyadmin/(?<after_ali>(.*).(php|php5)?$) {
root /usr/share/nginx/html;
fastcgi_pass 172.16.10.30:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params;
}

重启nginx:

[[email protected] conf.d]# docker restart nginx
nginx

浏览器访问
本机ip/phpmyadmin/index.php

报红框属于正常现象,不要惊慌,接下来就解决它

需要我们对php镜像做出更改,添加php和mysql连接的模块

写一个Dockerfile:
[[email protected] ~]# vim Dockerfile

FROM php:7.2-fpm
RUN apt-get update && apt-get install -y \
libfreetype6-dev \
libjpeg62-turbo-dev \
libpng-dev \
&& docker-php-ext-install -j$(nproc) iconv \
&& docker-php-ext-configure gd --with-freetype-dir=/usr/include/ --with-jpeg-dir=/usr/include/ \
&& docker-php-ext-install -j$(nproc) gd \
&& docker-php-ext-install mysqli pdo pdo_mysql

执行一下:这条命令加载时间有点长,请耐心等待!!!

[[email protected] ~]# docker build -t phpmysql .

查看是否有新创建的镜像:

[[email protected] ~]# docker images

[[email protected] ~]# docker stop phpfpm

我的是这个:

phpmysql latest 6e65aee3bd4d 9 minutes ago 422MB

关闭原先的php镜像:

[[email protected] ~]# docker stop phpfpm
phpfpm

删除之前的php容器

[[email protected] ~]# docker rm phpfpm
phpfpm

使用新创建的php镜像创建新的php容器

[[email protected] ~]# docker run -itd --name phpfpm -p 9000:9000 -v /wwwroot/html:/usr/share/nginx/html --network lnmp --ip 172.16.10.30 phpmysql

//修改phpmyadmin的配置文件,指定连接的数据库的ip

[[email protected] phpmyadmin]# pwd
/wwwroot/html/phpmyadmin

改名:

[[email protected] phpmyadmin]# cp config.sample.inc.php config.inc.php

编辑:

[[email protected] phpmyadmin]# vim config.inc.php

31行:改为mysql数据库的ip

$cfg[‘Servers‘][$i][‘host‘] = ‘172.16.10.20‘;

重启php容器:

[[email protected] phpmyadmin]# docker restart phpfpm
phpfpm

浏览器访问:本机ip/phpmyadmin/index.php
出现以下界面成功

用户:root 密码:123.com

登录成功会看到之前创建的数据库:

到这就lnmp部署完成!!!!

原文地址:https://blog.51cto.com/13997536/2460364

时间: 2024-10-10 02:36:03

docker部署lnmp集群的相关文章

使用Docker部署RabbitMQ集群

概述 本文重点介绍的Docker的使用,以及如何部署RabbitMQ集群,最基础的Docker安装,本文不做过多的描述,读者可以自行度娘. Windows10上Docker的安装 因为本人用的是Windows系统,所有推荐一个不错的安装文章,详见:https://blog.csdn.net/xiaoping0915/article/details/75094857 注意:设置阿里云Docker Hub加速,配置Registry mirrors地址"https://j0andt2p.mirror.

Docker部署Hadoop集群

一.主机规划 3台主机:1个master.2个slaver/worker ip地址使用docker默认的分配地址: master: 主机名: hadoop2.ip地址: 172.17.0.2 slaver1: 主机名: hadoop3.ip地址: 172.17.0.3 主机名: hadoop4.ip地址: 172.17.0.4 二.软件安装 1.在docker中安装centos镜像,并启动centos容器,安装ssh.--详见"docker上安装centos镜像"一文. 2.通过ssh

Ubuntu 16.04下使用docker部署ceph集群

ceph集群docker部署 通过docker可以快速部署小规模Ceph集群的流程,可用于开发测试. 以下的安装流程是通过linux shell来执行的:假设你只有一台机器,装了linux(如Ubuntu)系统和docker环境,那么可以参考以下步骤安装Ceph: # 要用root用户创建, 或有sudo权限 # 注: 建议使用这个docker镜像源:https://registry.docker-cn.com # 1. 修改docker镜像源 cat > /etc/docker/daemon.

利用Docker部署mongodb集群--分片与副本集

环境 Docker version 1.6.2  mongodb 3.0.4 第一步  编写Dockerfile并生成镜像 主意包含两个Dockerfile镜像,一个mongod的,一个mongos(在集群中负责路由) 编写Mongod的Dockerfile: FROM ubuntu:14.04 RUN apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 7F0CEB10 ENV MONGO_MAJOR 3.0 RUN ech

docker部署redis-cluster集群

https://segmentfault.com/a/1190000010131816 1>拉取reids镜像:docker pull redis 2>创建虚拟网卡 :docker network create redis-net 3>创建redis配置文件 mkdir docker/redisContainer/redis-cluster,进入redis-cluster目录执行下面指令 for port in `seq 7000 7005`; do \ mkdir -p ./${por

docker部署mongo集群

无聊,自建轮子 创建mongo镜像,dockerfile如下 from centos:7 RUN yum install net-tools vim -y RUN mkdir -p /mongodb/bin && mkdir -p /mongodb/conf && mkdir -p /mongodb/log && touch /mongodb/log/mongodb.log && mkdir -p /mongodb/data &&am

Centos 7 部署lnmp集群架构

前言介绍 lnmp的全程是 linux + nginx + mysql + php; lnmp就是上述系统及应用程序的简写组合: lnmp其实已经代表了一个用户正常对一个页面请求的流程,nginx接收请求,mysql进行数据存储,php进行后端处理:类似的架构还有lamp或者 linux + nginx + mysql + java等等: lnmp又叫lemp,外国人喜欢叫lemp,中国人喜欢叫lnmp: lnmp相比于lamp架构的优势在于轻便.操作相对简单:lamp优势相对于nginx而言模

有个想法,想吧LNMP和NGINX和HAPROXY都放到docker里做集群,大家觉得怎么样?

有个想法,想把LNMP和NGINX和HAPROXY都放到docker里做集群 顶层HAPROXY+KERPALIVE 第二层NGINX+KERPALIVE 第三层APACHE集群+MYSQL集群 第四层docker 第五层LINUX内核 有想法的可以一起讨论下哈

使用docker安装部署Spark集群来训练CNN(含Python实例)

使用docker安装部署Spark集群来训练CNN(含Python实例) 本博客仅为作者记录笔记之用,不免有很多细节不对之处. 还望各位看官能够见谅,欢迎批评指正. 博客虽水,然亦博主之苦劳也. 如需转载,请附上本文链接,不甚感激! http://blog.csdn.net/cyh_24/article/details/49683221 实验室有4台神服务器,每台有8个tesla-GPU,然而平时做实验都只使用了其中的一个GPU,实在暴遣天物! 于是想用spark来把这些GPU都利用起来.听闻d