用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模板引擎SMARTY
Oct 09 PHP
PHP脚本的10个技巧(2)
Oct 09 PHP
追求程序速度,而不是编程的速度
Apr 23 PHP
PHP XML操作的各种方法解析(比较详细)
Jun 17 PHP
PHP求最大子序列和的算法实现
Jun 24 PHP
php 目录与文件处理-郑阿奇(续)
Jul 04 PHP
php中防止伪造跨站请求的小招式
Sep 02 PHP
分享PHP header函数使用教程
Sep 05 PHP
PHP数字和字符串ID互转函数(类似优酷ID)
Jun 30 PHP
重新认识php array_merge函数
Aug 31 PHP
php运行提示:Fatal error Allowed memory size内存不足的解决方法
Dec 17 PHP
通过代码实例解析PHP session工作原理
Dec 11 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
destoon实现商铺管理主页设置增加新菜单的方法
2014/06/26 PHP
php抓取网站图片并保存的实现方法
2015/10/29 PHP
PHP屏蔽关键字实现方法
2016/11/17 PHP
PHP使用标准库spl实现的观察者模式示例
2018/08/04 PHP
PHP常用正则表达式精选(推荐)
2019/05/28 PHP
基于jquery的jqDnR拖拽溢出的修改
2011/02/12 Javascript
jquery事件机制扩展插件 jquery鼠标右键事件。
2011/12/26 Javascript
在图片上显示左右箭头类似翻页的代码
2013/03/04 Javascript
jquery 使用简明教程
2014/03/05 Javascript
如何正确使用Nodejs 的 c++ module 链接到 OpenSSL
2014/08/03 NodeJs
使用javascript实现雪花飘落的效果
2015/01/13 Javascript
jQuery实现为LI列表前3行设置样式的方法【2种方法】
2016/09/04 Javascript
js for终止循环 跳出多层循环
2018/10/04 Javascript
傻瓜式解读koa中间件处理模块koa-compose的使用
2018/10/30 Javascript
Next.js实现react服务器端渲染的方法示例
2019/01/06 Javascript
推荐下python/ironpython:从入门到精通
2007/10/02 Python
Python实现的双色球生成功能示例
2017/12/18 Python
详解将Django部署到Centos7全攻略
2018/09/26 Python
详解Python装饰器
2019/03/25 Python
python-docx文件定位读取过程(尝试替换)
2020/02/13 Python
django 数据库 get_or_create函数返回值是tuple的问题
2020/05/15 Python
CSS中几个与换行有关的属性简明总结
2014/04/15 HTML / CSS
canvas之自定义头像功能实现代码示例
2017/09/29 HTML / CSS
英国创新设计文具、卡片和礼品包装网站:Paperchase
2018/07/14 全球购物
介绍一下代理模式(Proxy)
2014/10/17 面试题
应届生求职信写作技巧
2013/10/24 职场文书
个人自荐书
2013/12/20 职场文书
中专生自我鉴定范文
2014/02/02 职场文书
机电专业毕业生求职信
2014/07/01 职场文书
改进作风怎么办发言材料
2014/08/17 职场文书
群众路线自我剖析材料
2014/10/08 职场文书
优秀党员事迹材料
2014/12/18 职场文书
导游欢迎词范文
2015/01/23 职场文书
清洁工个人总结
2015/03/04 职场文书
会议通知格式范文
2015/04/15 职场文书
alibaba seata服务端具体实现
2022/02/24 Java/Android