一、squid
1、实现透明代理Transparent Proxy
路由功能需打开:echo 1 > /proc/sys/net/ipv4/ip_forward
squid:
http_port 192.168.0.45:8080 transparent
acl allow all
iptables -t nat -A PREROUTING -i eth1 -s 192.168.10.0/24 -p tcp --dport 80 -j REDIRECT --to-ports 8080
client:
route add default gw 192.168.10.5
两种解决方案:
1、内部DNS
2、DNS SNAT
iptables -t nat -A POSTROUTING -s 192.168.10.0/24 -j SNAT --to-source 192.168.0.45
2、reverse proxy,DNAT 实现反向代理
mv squid.conf squid.conf.transparent
cp squid.conf.bak squid.conf
http_port 192.168.10.11:80 vhost
二、DNS(Domain Name Sytem)
C/S架构
FQDN(Full Qualified Domain Name)完全限定域名
ICANN
根域
.
顶级域
gov,edu,net,com,org,mil,int
cn,hk,ge,uk,jp...
二级域名
ibm,hp。。。
DNS查询类型:(同时存在)
递归
迭代
缓存 (时长 - ip与主机名变化频度)
domain与zone
资源记录类型:
SOA 起始授权记录(权威,哪个范围谁说的算)
NS 那个说的算的人
A 主机名-->ip
PTR ip-->主机名
MX 邮件交换器
CNAME 别名
TXT 表明域的身份信息--url重定向
正副关系:
主域名服务器
从域名服务器---区域传送
增量传送ixfr
完全区域传送axfr--tcp
allow-transfer { none; };
DNS服务器的类型:
主域名服务器
辅助域名服务器
缓存域名服务器--节约带宽
转发器
——————————————————————————————————————————————————————
二、构建DNS服务器
bind,bind-libs,bind-utils,bind-chroot(jail),caching-nameserver
powerDNS
myDNS---》myDNSng
bind-->named:53-->DNS
named进程:
database:zone file ,FQDN-->IP
reverse zone file ,ip-->FQDN
file,root dns server
database:
localhost,127.0.0.1
**************************************
yum -y install bind bind-libs bind-utils
/etc/named.conf
/var/named
named.ca
localhost.zone
name [TTL] IN RECORD_TYPE value
named.local
/etc/init.d/named
rndc辅助工具--bind的远程名称进程控制工具
953端口
1)/etc/named.conf
options {
directory "/var/named";
};
zone "." IN {
type hint;
file "named.ca";
};
zone "." IN {
type master;
file "localhost.zone";
};
zone "0.0.127.in-addr.arpa" IN {
type master;
file "named.local";
};
2)/var/named/named.ca
dig -t NS .
dig -t NS . @a.root-servers.net > /var/named/named.ca
3)/var/named/localhost.zone
$TTL 86400
@ IN SOA localhost. admin.localhost. (
2011012801
1H
15M
1W
1D )
@ IN NS localhost.
localhost. IN A 127.0.0.1
4)
/var/named/named.local
$TTL 86400
@ IN SOA localhost. admin.localhost. (
2011012801
1H
15M
1W
1D )
@ IN NS localhost.
1 IN PTR localhost.
5) chown :named /etc/named.conf
chown :named /var/named/* -R
service named configtest
dig -t A localhost.
dig -x 127.0.0.1
rndc-confgen > /etc/rndc.conf
tail /etc/rndc.conf |head -9 | sed 's/^# //g' >> /etc/named.conf