免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3079 | 回复: 2
打印 上一主题 下一主题

[proxy] 求教iptables+squid做透明代理iptables设置问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2004-12-16 19:23 |只看该作者 |倒序浏览
我用iptables+squid做透明代理
内网为172.24.0.0/19接口为eth0,限定其只能访问外网的一台web服务器202.114.16.12,公网eth1的ip202.116.52.6
squid工作在透明代理方式,监听80端口,配置没有问题
iptables配置命令如下
iptables -t nat -A PREROUTING -p tcp -i eth0 -j DNAT --to 202.114.16.12
iptables -t nat -A PREROUTING -p tcp -d 202.114.16.12 -j REDIRECT --to-port 80
iptables -t nat -A POSTROUTING -o eth1 SNAT --to 202.116.52.6
结果可以上网,但是数据没有经过squid
我怀疑是不是一个包经过PREROUTING时匹配第一条规则
iptables -t nat -A PREROUTING -p tcp -i eth0 -j DNAT --to 202.114.16.12后就直接跳出PREROURING链了,不会再去匹配第二条规则了,所以iptables -t nat -A PREROUTING -p tcp -d 202.114.16.12 -j REDIRECT --to-port 80在这里根本就没有起作用
究竟DNAT对包做完操作之后,包还会继续和其他的规则比较又或者不再继续比较当前链中的其他规则或父链中的其他规则直接跳出这条链呢?

论坛徽章:
0
2 [报告]
发表于 2007-05-20 15:17 |只看该作者
晕倒~~~~~~~~~`
规则都写出错了,
#!/bin/bash
echo "starting iptables rules"
echo "1" > /proc/sys/net/ipv4/ip_forward
/sbin/iptables -F
/sbin/iptables -X
/sbin/iptables -Z
/sbin/iptables -t nat -F
/sbin/iptables -t nat -X
/sbin/iptables -t nat -Z
/sbin/iptables -P INPUT DROP
/sbin/iptables -A INPUT -i eth1 -s  202.114.16.12 -p tcp --sport 80 \
--dport 1024:65535 -j ACCEPT
/sbin/iptables -A INPUT -p tcp -s 172.24.0.0/24 --sport 1024:65535 -d 202.114.16.12 --dport 80 -j ACCEPT
/sbin/iptables -t nat -A PREROUTING -i eth0 -p tcp -m tcp --dport 80 -j REDIRECT \
--to-ports 3128
/sbin/iptables -t nat -A POSTROUTING -o eth1 -j  SNAT --to-source 202.116.52.6
用这个脚本 试一下,应该就可以了

[ 本帖最后由 liheng 于 2007-5-20 15:47 编辑 ]

论坛徽章:
0
3 [报告]
发表于 2007-05-20 15:19 |只看该作者
每个命令有什么用,我就不解释了吧,自己慢慢琢磨吧,不行的话,再留言,大家一起解决
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP