案例子任务一、安装配置NFS服务器

步骤1:使用docker容器配置NFS服务器

  1. 启动centos容器并进入

    docker run -d --privileged centos:v1 /usr/sbin/init

  2. 在centos容器中使用yum方式安装nfs-utils

    #yum install nfs-utils

  3. 保存容器为镜像

    #docker commit 容器ID nfs

  4. 启动容器nfs,设定地址为172.18.0.120

#docker run -d --privileged --net cluster --ip 172.18.0.120 --name nfs nfs /usr/sbin/init

  1. 进入容器查看nfs配置文件

# more /etc/nfs.conf

# more /etc/nfsmount.conf

  1. 启动nfs服务,查看监听端口

    # systemctl start nfs-server

  2. 新建共享目录/var/www/share,设置权限为777

  1. 编辑/etc/exports文件

/var/www/share 172.18.0.*(rw,sync)

  1. 导出nfs共享目录

    #exportfs -rv

  2. 查看nfs上的共享目录

    #showmount -e IP地址

步骤1:使用宿主机配置NFS服务器

  1. # yum install nfs-utils //在宿主机安装nfs

  1. 查看nfs配置文件

# more /etc/nfs.onf

# more /etc/nfsmount.conf

  1. 启动nfs服务,查看监听端口

    # systemctl start nfs-server

  1. 新建共享目录/var/www/share,设置权限为777

  1. 编辑/etc/exports文件

/var/www/share 172.18.0.*(rw,sync)

  1. 导出nfs共享目录

    #exportfs -rv

  1. 查看nfs上的共享目录

    #showmount -e IP地址

步骤2:启用APP1和APP2两个容器,挂载共享目录

  1. 启动容器APP1,设定地址为172.18.0.111

docker run -d --privileged --net cluster --ip 172.18.0.111 --name APP1 php-apache /usr/sbin/init

  1. 启动容器APP2,设定地址为172.18.0.112

docker run -d --privileged --net cluster --ip 172.18.0.112 --name APP2 php-apache /usr/sbin/init

  1. # yum install nfs-utils //进入容器并安装nfs
  2. #showmount -e 172.18.0.1 //在APP1查看nfs上的共享目录

  1. 共享目录挂在到本地目录

# mkdir /var/www/share

# mount 172.18.0.1:/var/www/share /var/www/share

  1. 在APP1的/var/www/share上读写文件,在nfs上查看

  1. APP2按以上步骤配置

案例子任务二、配置nginx1、APP1实现动静分离

步骤1:在APP1上编写PHP脚本,上传资源文件

  1. 使用任务一中的APP1
  2. # more /etc/httpd/conf/httpd.conf //查看在APP1的lamp环境
  3. vim /var/www/index.php //在APP1上编辑php文件

<?php

function serverIp(){ //获取服务器IP地址

if(isset($_SERVER)){

if($_SERVER['SERVER_ADDR']){

$server_ip=$_SERVER['SERVER_ADDR'];

}else{

$server_ip=$_SERVER['LOCAL_ADDR'];

}

}else{

$server_ip = getenv('SERVER_ADDR');

}

return $server_ip;

}

?>

<!doctype html>

<html>

<head>

<meta charset="utf-8">

<title>动静分离测试</title>

<link rel="stylesheet" type="text/css" href="share/banner.css">

<script type="text/javascript" src="share/jquery-1.7.2.min.js"></script>

</head>

<body>

<div class="banner">

<ul>

<li><img src="share/banner_02.jpg" /></li>

<li><img src="share/banner_01.gif" /></li>

</ul>

</div>

<div class="main_list">

<ul>

<li><a href="#">动静分离测试...</a></li>

<li><a href="#">动静分离测试...</a></li>

</ul>

</div>

<span><?php echo serverIp(); ?></span>

</body>

</html>

  1. 把图片资源文件上传到APP1服务器的 /var/www/share目录

  1. 在宿主机nfs服务器的 /var/www/share目录中检查文件是否存在

  1. 在宿主机使用curl访问http://172.18.0.111/index.php

步骤2:配置nginx反向代理,访问APP1

  1. 启动容器nginx1,设定地址为172.18.0.11,把80端口映射到宿主机8080

docker run -d --privileged --net cluster --ip 172.18.0.11 -p 8080:80 --name nginx1 nginx-keep /usr/sbin/init

  1. 在nginx1上编辑/etc/nginx/nginx.conf,重启nginx服务

server {

listen 80;

server_name localhost;

location / {

proxy_pass http://172.18.0.111;

}

  1. 在主机使用浏览器访问http://192.168.*.100/index.php

步骤3:配置nginx反向代理,宿主机nginx,支持动静分离

  1. 在nfs宿主机编辑/etc/nginx/conf.d/ default.conf,启用nginx服务

server {

listen 80;

server_name file.test.com;

location / {

root /var/www;

index index.html index.htm;

}

}

  1. 在nginx1上编辑/etc/nginx/nginx.conf,重启nginx服务

server {

listen 80;

server_name localhost;

location / {

proxy_pass http://172.18.0.111;

}

location /share {

proxy_pass http://172.18.0.1/share;

}

}

  1. 在主机使用浏览器访问http://192.168.*.100/index.php

步骤4:配置nginx1、APP1、APP2、宿主机nfs和nginx,支持负载均衡动静分离

  1. 容器APP1和宿主机使用上面步骤做好的,不做调整
  2. 仿照步骤1,在APP2上编写PHP脚本,上传资源文件

  1. 在nginx1上编辑/etc/nginx/nginx.conf,重启nginx服务

server {

listen 80;

server_name localhost;

location / {

proxy_pass http://APP;

}

location /share {

proxy_pass http://172.18.0.1/share;

}

upstream APP {

server 172.18.0.111;

server 172.18.0.112;

}

}

  1. 在主机使用浏览器访问http://192.168.*.100/index.php

配置NFS实现nginx动静分离的更多相关文章

  1. Nginx动静分离经典案例配置

    随着Nginx高性能Web服务器大量被使用,目前Nginx最新稳定版为1.2.6,张宴兄在实际应用中大量使用Nginx,并分享Nginx高性能Web服务器知识,使得Nginx在国内也是飞速的发展.那今 ...

  2. Nginx动静分离知识及配置

    Nginx动静分离知识及配置,本质上与分离上传下载功能是相同功能,本质就是在文件服务器也是需要部署WEB应用的,只是在进行代理分离的时候分配到对应的文件服务器上去. 随着Nginx高性能Web服务器大 ...

  3. 使用nginx和tomcat配置反向代理和动静分离

    背景 本人主修的编程语言是Java语言,因此最开始接触的Web开发也是JSP技术.使用Java开发的Web应用需要部署在专门的服务器程序上运行,比如Tomcat.但是一般很少会有人将Tomcat作为用 ...

  4. Nginx动静分离经典

    Nginx:安装nginx之前需要安装pcre包和zlib以支持重写,正则以及网页压缩等等]把所需的包下载到/usr/src下[根据自己的习惯,路径可以改变]1.首先安装pcre: cd /usr/s ...

  5. Nginx动静分离实现

    Nginx动静分离实现: Nginx是一种轻量级,高性能,多进程的Web服务器,非常适合作为静态资源的服务器使用,而动态的访问操作可以使用稳定的Apache.Tomcat及IIS等来实现,这里就以Ng ...

  6. Nginx动静分离架构

    Nginx动静分离简单来说就将动态与静态资源分开,不能理解成只是单纯的把动态页面和静态页面物理分离,严格意义上说应该是动态请求跟静态请求分开,可以理解成使用Nginx处理静态页面,Tomcat,Res ...

  7. Nginx 动静分离与负载均衡的实现

    一.前提 企业中,随着用户的增长,数据量也几乎成几何增长,数据越来越大,随之也就出现了各种应用的瓶颈问题. 问题出现了,我们就得想办法解决,一般网站环境,均会使用LAMP或者LNMP,而我们对于网站环 ...

  8. Nginx动静分离

    动静分离 Nginx动静分离是让动态网站里的动态网页根据一定规则把不变的资源和经常变的资源区分开来,动静资源做好了拆分以后,我们就可以根据静态资源的特点将其做缓存操作,这就是网站静态化处理的核心思路. ...

  9. Nginx动静分离架构&&HA-LB集群整合

    Nginx动静分离简单来说就将动态与静态资源分开,不能理解成只是单纯的把动态页面和静态页面物理分离,严格意义上说应该是动态请求跟静态请求分开,可以理解成使用Nginx处理静态页面,Tomcat,Res ...

随机推荐

  1. kali-网络桥接

    kali 之网络桥接 前言:之前一直选择的是nat模式,不知道我的什么神操作,kali的网络突然就挂掉了,然后就是重启,配置,一直轮训下去,还是ping不通主机,搞得心态差点爆炸,于是乎就放弃了nat ...

  2. Mybatis学习-配置、作用域和生命周期

    核心配置文件:Mybatis-config.xml Mybatis的配置文件包含了会深深影响Mybatis行为的设置和属性信息 配置(configuration) 在mybatis-config.xm ...

  3. pytorch知识(torch.sum,以及维度问题)

    参考(推荐): https://mathpretty.com/12065.html

  4. 【题解】P2610 [ZJOI2012]旅游

    link 题意 T国的国土可以用一个凸N边形来表示,包含 \(N-2\) 个城市,每个城市都是顶点为 \(N\) 边形顶点的三角形,两人的旅游路线可以看做是连接N个顶点中不相邻两点的线段.问一路能经过 ...

  5. protobuf 协议浅析

    目录 Protobuf 协议浅析 1. Protobuf 介绍 1.1 Protobuf 基本概念 1.2 Protobuf 的优点 1.3 Protobuf, JSON, XML 的区别 2. Pr ...

  6. STL——容器(Map & multimap)的排序与遍历

    1. Map & multimap 的排序与遍历 map<T1,T2,less<T1> >  mapA; //该容器是按键的升序方式排列元素.如果未指定less< ...

  7. Python测试框架unittest

    Python测试框架unittest 一.unittest框架 (1)unittest特点 1.python自带的单元测试框架,不需要安装 2.用例执行互不干扰 3.提供不同范围的setUp和tear ...

  8. JUC(二):CAS及ABA

    CAS是什么? 比较并交换. CAS示例 package com.chinda.java.audition; import java.util.concurrent.atomic.AtomicInte ...

  9. 开源一套原创文本处理工具:Java+Bat脚本实现自动批量处理对账单工具

    原创/朱季谦 这款工具是笔者在2018年初开发完成的,时隔两载,偶然想起这款小工具,于是,决定将其开源,若有人需要做类似Java批处理实现整理文档的工具,可参考该工具逻辑思路来实现. 该工具是运行在w ...

  10. 01-flask-helloWorld

    代码 from flask import Flask # 创建Flask对象 app = Flask(__name__) # 定义路由 @app.route('/') def index(): # 函 ...