正向代理是一个位于客户端和原始服务器(origin server)之间的服务器,为了从原始服务器取得内容,客户端向代理发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端,客户端才能使用正向代理。

正向代理的典型用途是为在防火墙内的局域网客户端提供访问Internet的途径。正向代理还可以使用缓冲特性(由mod_cache提供)减少网络使用率。

正向代理允许客户端通过它访问任意网站并且隐藏客户端自身,因此你必须采取安全措施以确保仅为经过授权的客户端提供服务。和反向代理不同之处在于,典型的正向代理是一种最终用户知道并主动使用的代理方式。

借用知乎两张图来解释正向代理:反向代理为何叫反向代理?

作用

访问原来无法访问的资源,如google

做缓存,加速访问资源

对客户端访问授权,上网进行认证

代理可以记录用户访问记录(上网行为管理),对外隐藏用户信息

普通代理

普通代理:代替局域网内的所有主机访问公网的网站服务,局域网内的主机需要在自己的浏览器中指定代理服务器的ip地址和监听的端口号
安装软件包squid

[root@ECS58979490c134 ~]# yum -y install squid

编辑主配置文件/etc/squid/squid.conf

[root@ECS58979490c134 ~]# vim  /etc/squid/squid.conf
http_port //squid默认监听的端口号
cache_mem 8MB //默认缓存容量8MB
cache_dir ufs /var/spool/squid //设置缓存目录的大小,缓存文件的格式,大小100M,一级子目录16个,每个一级子目录下有256个二级子目录
access_log /var/log/squid/access.log squid //访问日志文件,默认开启
visible_hostname proxy.eflycloud.com //默认用环回口的主机名作为代理服务器的主机名。手动指定主机名时必须与物理接口绑定
maximum_object_size //允许缓存数据的最大值。不设置时,不限制
reply_body_max_size //允许通过代理服务器访问的最大目标对象
http_access allow all //默认拒绝所有主机
[root@ECS58979490c134 ~]# cat /etc/hosts
127.0.0.1 localhost.localdomain localhost
:: localhost6.localdomain6 localhost6
192.168.1.254 proxy.eflycloud.com proxy //物理接口绑定主机名

启动服务

[root@ECS58979490c134 ~]# service squid start
init_cache_dir /var/spool/squid... Starting squid: .[ OK ]
[root@ECS58979490c134 ~]# netstat -anptu | grep :
Tcp 0.0.0.0: 0.0.0.0:* LISTEN /(squid)

客户端浏览器中设置代理服务器

透明代理

透明代理:客户端不需要在本机的浏览器里指定代理服务器的IP地址和监听的端口号,给客户端的感觉是直接与公网通讯的。不过客户端需要指定或者添加透明代理服务器为网关。

配置透明代理服务器

[root@ECS58979490c134 ~]# vim /etc/squid/squid.conf
http_port transparent //透明传输
[root@ECS58979490c134 ~]#service squid restart

写防火墙规则,把访问目标端口是80的请求转到3128端口。如果不指定端口则是全部请求都会转到3128端口

[root@ECS58979490c134 ~]# service iptables start     //开启防火墙服务
[root@ECS58979490c134 ~]#setup
[root@ECS58979490c134 ~]# iptables -t filter -F //清空表filter防火墙规则
[root@ECS58979490c134 ~]# iptables -t nat -F //清空表nat防火墙规则
[root@ECS58979490c134 ~]# iptables -t nat -A PREROUTING -i eth0 -s 192.168.1.0/ -p tcp --dport -j REDIRECT --to-ports //PREROUTING 在路由之前,-i 数据包从哪个口进来,-s 源IP地址, –p 协议, –dport 目标端口, --to-ports 转到哪个端口
[root@ECS58979490c134 ~]# service iptables save //永久生效

客户端将网关指向代理服务器的内网接口的ip地址

[root@ECS58979490c164 ~]# route add default gw 192.168.1.254

最新文章

  1. LZW压缩算法——简明原理与实现
  2. 20款时尚的 WordPress 博客主题【免费下载】
  3. MMDrawerController的使用
  4. IDEA 新建文件默认加入CVS
  5. 解决eclipse Maven 主项目不能刷新maven
  6. [开发笔记]-获取歌曲ID3信息
  7. greenplum和postgresql
  8. sql_autoload_register() 函数 和__autoload() 的区别
  9. jQuery插件编写及链式编程模型
  10. POJ 3254 Corn Fields(状态压缩)
  11. Android开发之监听器
  12. python之线程学习
  13. PostgreSQL 的 distinct on 的理解
  14. Codeforces Round #548 (Div. 2) F splay(新坑) + 思维
  15. flask 更新数据库
  16. linux用户、文件权限相关命令
  17. 域PC脱域
  18. Android 动态添加线性布局(.java文件内) 实现控件按比例分割空间
  19. ArrayList扩容
  20. python 爬虫 黑科技

热门文章

  1. HDU5394 Bomb
  2. CodeForces1000A- Codehorses T-shirts
  3. 【搞定Jvm面试】 Java 内存区域揭秘附常见面试题解析
  4. Ceph分布式存储-总
  5. 显示cifar图片
  6. WebAPI接口的自动化测试2
  7. Shell排序 C&&C++
  8. layui扩展组件,下拉树多选
  9. PostgreSQL 、springboot 、spring data jpa 集成
  10. ACM-ICPC 2018 南京赛区网络预赛 L. Magical Girl Haze (分层dijkstra)