用Apache反向代理设置对外的WWW和文件服务器


Posted in PHP onOctober 09, 2006

简介:一台机器用专线接入Internet作为防火墙,在内部网段上有一台WWW服务器 
(Redhat 6.1,Apache 1.3.9)希望这台机器能对外提供WWW服务器和基于apache 
的文件服务。供外部世界公共访问WWW服务器,或者外地分公司下载需要的文件。 
优点: 内部的WWW服务器和文件服务完全与外部世界隔开,不直接连接到外部,通过 
防火墙上运行的Apache服务提供对内部的代理访问,增强了安全性,同时在 
防火墙上运行的Apache服务运用基于名字的虚拟主机技术,使得防火墙上的 
主页不会被访问到。符合了作为防火墙要求运行服务越少越安全的准则。 

实现方法:在内部网段上的Apache服务器(192.168.11.2)存放的是公司主页,供内部 
和外部用户公共访问,并设置/home/ftp/pub目录为文件存放区域,用 
http://download.yourdomain.com/pub/来访问。 
在防火墙上设置apache反向代理技术,由防火墙代理对内部网段上的访问。 

步骤: 
一. 内部网段上的Apache服务器设置 

apache采用默认配置。主目录为/home/httpd/html,主机域名为 sun.yourdomain.com, 
且别名www.yourdomain.com, 并且设置srm.conf加一行别名定义如下: 
Alias /pub /home/ftp/pub/ 

且更改默认应用程序类型定义如下: 
DefaultType application/octet-stream 

最后在/etc/httpd/conf/access.conf中增加一项定义 

Options Indexes 
AllowOverride AuthConfig 
order allow,deny 
allow from all 

注:Options Indexes允许在找不到index.html文件的情况下允许列出目录/文件列表。 
AllowOverride AuthConfig允许做基本的用户名和口令验证。 
这样的话,你需要在/home/ftp/pub目录下放入.htaccess,内容如下: 
------- 
[root@shopu pub]# more .htaccess 
AuthName Branch Office Public Software Download Area 
AuthType Basic 
AuthUserFile /etc/.usrpasswd 
require valid-user 
------ 
然后用#htpasswd -c /etc/.usrpasswd user1 
分别创建不同的允许访问/pub下文件服务的外部用户名和口令。 

二. 防火墙上反向代理配置: 
加下面的行到/etc/httpd/conf/httpd.conf 

NameVirtualHost 1.2.3.4 

# 1.2.3.4是防火墙外部网卡的互联网上永久IP地址 

servername www.yourdomain.com 
errorlog /var/log/httpd/error_log 
transferlog /var/log/httpd/access_log 
rewriteengine on 
proxyrequests off 
usecanonicalname off 
rewriterule ^/(.*)$ http://192.168.11.2/$1 [P,L] 

servername download.yourdomain.com 
errorlog /var/log/httpd/download/error_log 
transferlog /var/log/httpd/download/access_log 
rewriteengine on 
proxyrequests off 
usecanonicalname off 
rewriterule ^/(.*)$ http://192.168.11.2/$1 [P,L] 

注:设置防火墙上的DNS,让download.yourdomain.comwww.yourdomain.com都指向 
防火墙的外部网卡地址。www.yourdomain.com防问你的公司主页, 用 
http://download.yourdomain.com/pub/...?参募?略厍??/a> 

你需要在内部网段的apache主机上建立目录/var/log/httpd/download/目录,否则会 
出错。另外,你也可以设置防火墙主机上的/home/httpd/html/index.html的属性为 
750

PHP 相关文章推荐
php 全文搜索和替换的实现代码
Jul 29 PHP
修改PHP的memory_limit限制的方法分享
Feb 21 PHP
浅析linux下apache服务器的配置和管理
Aug 10 PHP
thinkphp的c方法使用示例
Feb 24 PHP
PHP下的Oracle客户端扩展(OCI8)安装教程
Sep 10 PHP
初识PHP
Sep 28 PHP
PHP连接MSSQL2008/2005数据库(SQLSRV)配置实例
Oct 22 PHP
CodeIgniter中使用Smarty3基本配置
Jun 29 PHP
PHP Mysqli 常用代码集合
Nov 12 PHP
微信 开发生成带参数的二维码的实例
Nov 23 PHP
php+redis实现多台服务器内网存储session并读取示例
Jan 12 PHP
php设计模式之状态模式实例分析【星际争霸游戏案例】
Mar 26 PHP
Mysql的常用命令
Oct 09 #PHP
提升PHP执行速度全攻略
Oct 09 #PHP
Apache设置虚拟WEB
Oct 09 #PHP
PHP&MYSQL服务器配置说明
Oct 09 #PHP
国内php原创论坛
Oct 09 #PHP
强烈推荐:php.ini中文版(2)
Oct 09 #PHP
强烈推荐:php.ini中文版(1)
Oct 09 #PHP
You might like
缅甸的咖啡简史
2021/03/04 咖啡文化
过滤掉PHP数组中的重复值的实现代码
2011/07/17 PHP
浅析get与post的一些特殊情况
2014/07/28 PHP
php基础教程
2015/08/26 PHP
变量在 PHP7 内部的实现(一)
2015/12/21 PHP
php设计模式之委托模式
2016/02/13 PHP
实例讲解PHP中使用命名空间
2019/01/27 PHP
PHP常见字符串操作函数与用法总结
2019/03/04 PHP
向fckeditor编辑器插入指定代码的方法
2007/05/25 Javascript
JavaScript 版本自动生成文章摘要
2008/07/23 Javascript
JS中 用户登录系统的解决办法
2013/04/15 Javascript
js取整数、取余数的方法
2014/05/11 Javascript
js读取cookie方法总结
2014/10/31 Javascript
javascript中定义类的方法详解
2015/02/10 Javascript
JS实现网页每隔3秒弹出一次对话框的方法
2015/11/09 Javascript
探讨:JavaScript ECAMScript5 新特性之get/set访问器
2016/05/05 Javascript
基于JavaScript实现鼠标箭头移动图片跟着移动
2016/08/30 Javascript
Bootstrap中的fileinput 多图片上传及编辑功能
2016/09/05 Javascript
详解Nodejs之静态资源处理
2017/06/05 NodeJs
node命令行工具之实现项目工程自动初始化的标准流程
2019/08/12 Javascript
微信小程序 如何保持登录状态
2019/08/16 Javascript
javascript设计模式 ? 建造者模式原理与应用实例分析
2020/04/10 Javascript
[02:38]DOTA2英雄基础教程 噬魂鬼
2014/01/03 DOTA
Python中多线程thread与threading的实现方法
2014/08/18 Python
Python作用域用法实例详解
2016/03/15 Python
Python计算两个日期相差天数的方法示例
2017/05/23 Python
Python 模拟员工信息数据库操作的实例
2017/10/23 Python
Python通过调用mysql存储过程实现更新数据功能示例
2018/04/03 Python
利用Python库Scapy解析pcap文件的方法
2019/07/23 Python
Django rest framework jwt的使用方法详解
2019/08/08 Python
python如何查看安装了的模块
2020/06/23 Python
团队队名口号大全
2014/06/06 职场文书
大学生职业生涯十年规划书范文
2014/09/17 职场文书
2015年感恩节演讲稿(优选篇)
2015/03/20 职场文书
Prometheus 监控MySQL使用grafana展示
2021/08/30 MySQL
css弧边选项卡的项目实践
2023/05/07 HTML / CSS