用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 相关文章推荐
如何开发一个虚拟域名系统
Oct 09 PHP
php+mysql实现无限级分类 | 树型显示分类关系
Nov 19 PHP
由php的call_user_func传reference引发的思考
Jul 23 PHP
PHP file_get_contents设置超时处理方法
Sep 30 PHP
PHP中读取文件的8种方法和代码实例
Aug 05 PHP
PHP IDE phpstorm 常用快捷键
May 18 PHP
PHP中error_reporting()用法详解
Aug 31 PHP
mysql_escape_string()函数用法分析
Apr 25 PHP
PHP简单获取多个checkbox值的方法
Jun 13 PHP
PHP函数rtrim()使用中的怪异现象分析
Feb 24 PHP
PHP调用API接口实现天气查询功能的示例
Sep 21 PHP
PHP的PDO连接讲解
Jan 24 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
php数组函数序列之array_search()- 按元素值返回键名
2011/11/04 PHP
php版微信返回用户text输入的方法
2016/11/14 PHP
php 中phar包的使用教程详解
2018/10/26 PHP
子窗口、父窗口和Silverlight之间的相互调用
2010/08/16 Javascript
基于jquery实现的上传图片及图片大小验证、图片预览效果代码
2011/04/12 Javascript
jQuery学习笔记之控制页面实现代码
2012/02/27 Javascript
js或者jquery判断图片是否加载完成实现代码
2013/03/20 Javascript
ie 7/8不支持trim的属性的解决方案
2014/05/23 Javascript
jQuery简单实现遍历数组的方法
2015/04/14 Javascript
JavaScript中对DOM节点的访问、创建、修改、删除
2015/11/16 Javascript
AngularJS过滤器详解及示例代码
2016/08/16 Javascript
jQuery实现的放大镜效果示例
2016/09/13 Javascript
canvas绘制表盘时钟
2017/01/23 Javascript
jQuery插件HighCharts实现的2D面积图效果示例【附demo源码下载】
2017/03/15 Javascript
ES6学习教程之对象的扩展详解
2017/05/02 Javascript
vue2.0实现分页组件的实例代码
2017/06/22 Javascript
完美解决axios在ie下的兼容性问题
2018/03/05 Javascript
jQuery each和js forEach用法比较
2019/02/27 jQuery
Laravel 如何在blade文件中使用Vue组件的示例代码
2020/06/28 Javascript
vue界面发送表情的实现代码
2020/09/11 Javascript
python监控网站运行异常并发送邮件的方法
2015/03/13 Python
深入解答关于Python的11道基本面试题
2017/04/01 Python
python实现二叉查找树实例代码
2018/02/08 Python
python对常见数据类型的遍历解析
2019/08/27 Python
Python基于pyjnius库实现访问java类
2020/07/31 Python
Python tkinter之ComboBox(下拉框)的使用简介
2021/02/05 Python
HTML5通用接口详解
2016/06/12 HTML / CSS
HTML5 weui使用笔记
2019/11/21 HTML / CSS
字符串str除首尾字符外的其他字符按升序排列
2013/03/08 面试题
银行毕业实习自我鉴定
2013/09/19 职场文书
入党申请自荐书范文
2014/02/11 职场文书
企业党员一句话承诺
2014/05/30 职场文书
学校捐书活动总结
2015/05/08 职场文书
2015年征兵工作总结
2015/07/23 职场文书
JavaScript实现显示和隐藏图片
2021/04/29 Javascript
nginx的zabbix 5.0安装部署的方法步骤
2021/07/16 Servers