案例子任务一、安装配置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. MAC下go语言的安装和配置

    Mac下安装一些文件都是比较简单的.安装了brew以后,很多的程序只要一条命令就搞定了. brew install go 安装好go语言以后主要是配置go_path,和go_root的地址. go_r ...

  2. python核心高级学习总结2----------pdb的调试

    PDB调试 def getAverage(a,b): result =a+b print("result=%d"%result) return result a=100 b=200 ...

  3. moviepy应用pyinstaller打包后执行报错AttributeError: module audio/video.fx.all has no attribute fadein、crop

    专栏:Python基础教程目录 专栏:使用PyQt开发图形界面Python应用 专栏:PyQt入门学习 老猿Python博文目录 在开发moviepy的Python程序使用pyinstaller打包后 ...

  4. 被老猿误解的Python匿名函数lambda

    在<第2.3节 Python运算符大全>老猿这样描述lambda:"上述运算符中有个lambda,这是个lambda就是用来定义一个匿名函数的.老猿认为用处不大,具体内容大家可以 ...

  5. PyQt学习随笔:Model/View中TableView视图数据项编辑结果及视图数据项的访问

    按照<PyQt学习随笔:Model/View中设置视图数据项可编辑的方法>的方法支持视图数据可编辑后,编辑后的数据无需主动保存,PyQt会自动将界面变更的数据保存到对应的Model存储中, ...

  6. PyQt(Python+Qt)学习随笔

    老猿Python博文目录 老猿Python博客地址 PyQt学习随笔 PyQt(Python+Qt)帮助文档官网及文档下载 PyQt(Python+Qt)学习随笔:PyQt帮助文档导入assistan ...

  7. PyQt(Python+Qt)学习随笔:Designer中的QDialogButtonBox增加自定义按钮的方法

    在Qt Designer中可以预先定义标准按钮,相关支持的标准按钮请见<PyQt(Python+Qt)学习随笔:Designer中的QDialogButtonBox的StandardButton ...

  8. [SWPU2019]Web1 空格过滤用/**/ 注释过滤闭合单引号 imformation_schema.columns/tables过滤 用5.7新特性 或无名注入(此处database()不能用)

    0x00 知识点 二次注入流程分析 二次注入漏洞在CTF中常见于留言板和注册登录功能,简单来说可以分为两个步骤: 插入恶意数据(发布帖子,注册账号),用mysql_escape_string()函数对 ...

  9. print(end="\r") 滚动输出到屏幕

    for i in range(10000): print(i, end = "\r") print(end="\r") 滚动输出到屏幕

  10. 第 4 篇 Scrum 冲刺博客

    每天举行会议 会议照片: 昨天已完成的工作与今天计划完成的工作及工作中遇到的困难: 成员姓名 昨天完成工作 今天计划完成的工作 工作中遇到的困难 蔡双浩 实现收藏夹功能 实现重设计的个人界面功能 无 ...