主頁 > 作業系統 > CentOS搭建squid正向代理

CentOS搭建squid正向代理

2023-04-27 09:26:12 作業系統

squid介紹

官網地址:http://www.squid-cache.org/


Squid cache(簡稱為 Squid)是一個流行的自由軟體(GNU 通用公共許可證)的代理服務器和 Web 快取服務器,Squid 有廣泛的用途,從作為網頁服務器的前置 cache 服務器快取相關請求來提高 Web 服務器的速度,到為一組人共享網路資源而快取萬維網,域名系統和其他網路搜索,到通過過濾流量幫助網路安全,到局域網通過代理上網,Squid 主要設計用于在 Unix 一類系統運行,

Squid 的發展歷史相當悠久,功能也相當完善,除了 HTTP 外,對于 FTP 與 HTTPS 的支援也相當好,在 3.0 測驗版中也支援了 IPv6,

Squid主要提供快取加速、應用層過濾控制的功能,

代理的作業機制

(1)代替客戶機向網站請求資料,從而可以隱藏用戶的真實IP地址,

(2)將獲得的網頁資料(靜態 Web 元素)保存到快取中并發送給客戶機,以便下次請求相同的資料時快速回應,

代理服務器的概念及其作用

代理服務器是一個位于客戶端和原始(資源)服務器之間的服務器,為了從原始服務器取得內容,客戶端向代理服務器發送一個請求并指定目標原始服務器,然后代理服務器向原始服務器轉交請求并將獲得的內容回傳給客戶端,

快取代理對于Web至關重要,尤其對于大型高負載Web站點,快取可作為性能優化的一個重要手段,可以極大減輕后端服務器的負載,通常對于靜態資源,即較少經常更新的資源,如圖片,css或js等進行快取,從而在每次重繪瀏覽器的時候,不用重新請求,而是從快取里面讀取,這樣就可以減輕服務器的壓力,

主要作用

(1)資源獲取:代替客戶端實作從原始服務器的資源獲取

(2)加速訪問:代理服務器可能離原始服務器更近,從而起到一定的加速作用

(3)快取作用:代理服務器保存從原始服務器所獲取的資源,從而實作客戶端快速的獲取

(4)隱藏真實地址:代理服務器代替客戶端去獲取原始服務器資源,從而隱藏客戶端真實資訊

squid的三種代理型別

squid軟體主要有三種代理型別:

  • 正向代理:代理內部主機上網,共享上網,快取,控制內網用戶上網行為等功能(客戶端需要設定代理服務器的IP和代理埠),
  • 透明代理:客戶機不需指定代理服務器的地址和埠,而是通過默認路由、防火墻策略將Web訪問重定向給代理服務器處理,
  • 反向代理:如果 Squid 反向代理服務器中快取了該請求的資源,則將該請求的資源直接回傳給客戶端;否則反向代理服務器將向后臺的 WEB 服務器請求資源,然后將請求的應答回傳給客戶端,同時也將該應答快取在本地,供下一個請求者使用,

正向代理分析圖:
image

反向代理分析圖:
image

squid安裝和組態檔說明

安裝軟體

# yum鏡像倉庫里有squid的軟體包
yum -y install squid

# squid配置初始化
cat >> /etc/squid/squid.conf<< EOF
cache_mem 64 MB
maximum_object_size 4 MB
maximum_object_size_in_memory 4096 KB
cache_dir ufs /var/spool/squid 100 16 256
access_log /var/log/squid/access.log
EOF

# squid初始化
squid -z

# 啟動squid并設定為開機啟動
service squid start && systemctl enable squid

# 檢查squid是否正常運行
netstat -ntlp | grep squid

# 如果防火墻開啟的話,放開3128埠
firewall-cmd --zone=public --add-service=squid --permanent

軟體的檔案串列

/etc/squid/squid.conf           # 組態檔
/etc/rc.d/init.d/squid          # 啟動腳本
/usr/sbin/squid                 # 二進制命令
/usr/share/doc/squid-3.1.10     # 手冊
/var/log/squid                  # 日志目錄
/var/spool/squid                # 快取目錄

組態檔說明

# cat /etc/squid/squid.conf

#####	設定監聽的IP與埠號
http_port 3128

#####	額外提供給squid使用的記憶體大小,默認256 MB
cache_mem   64 MB   

#####	設定squid磁盤快取最大檔案,超過4M的檔案不保存到硬碟
maximum_object_size 4 MB   

#####	設定squid磁盤快取最小檔案
minimum_object_size 0 KB 

#####	設定squid記憶體快取最大檔案,超過4M的檔案不保存到記憶體
maximum_object_size_in_memory 4096 KB  

#####	定義squid的cache存放路徑 、cache目錄容量(單位M)、一級快取目錄數量、二級快取目錄數量,此處的100 一定要大于 cache_mem 否則報錯,
cache_dir ufs /var/spool/squid 100 16 256  

#####	log檔案日志格式
logformat combined %&gt;a %ui %un [%tl] "%rm %ru HTTP/%rv" %Hs %<st "%{Referer}>h" "%{User-Agent}&gt;h" %Ss:%Sh

#####	log檔案存放路徑和日志格式
access_log /var/log/squid/access.log combined

#####	設定快取日志
cache_log /var/log/squid/cache.log

#####	log輪轉60天
logfile_rotate 60

#####	cache目錄使用量大于95%時,開始清理舊的cache
cache_swap_high 95

#####	cache目錄清理到90%時停止
cache_swap_low 90

#####	定義本地網段
acl localnet src 192.168.1.0/24

#####	允許本地網段使用
http_access allow localnet

#####	拒絕所有
http_access deny all

#####	主機名
visible_hostname xxx.xxxx.xxxx

#####	管理員郵箱
cache_mgr [email protected]

正向代理客戶端配置

Windows客戶端配置代理:

Internet 選項 > 連接 > 局域網設定 ”,在代理服務器區域,按照以下格式設定:
image

Linux客戶端:

先創建并修改/etc/profile.d/proxy.sh檔案

# 創建proxy.sh檔案
touch /etc/profile.d/proxy.sh

編輯proxy.sh檔案

# 進入profile.d目錄
cd /etc/profile.d/
# 編輯proxy.sh檔案
vim proxy.sh

添加下列內容

# squid正向代理只支持http、https、ftp協議,把下面的proxy_server_ip更換為自己搭建的squid服務器IP
export https_proxy=http://proxy_server_ip:3128
export http_proxy=http://proxy_server_ip:3128
export ftp_proxy=http://proxy_server_ip:3128

執行source /etc/profile使其生效

# 執行source /etc/profile
source /etc/profile

配置完成

轉載請註明出處,本文鏈接:https://www.uj5u.com/caozuo/551360.html

標籤:Linux

上一篇:快速上手Linux核心命令(四):檔案內容相關命令

下一篇:返回列表

標籤雲
其他(158229) Python(38107) JavaScript(25395) Java(18001) C(15217) 區塊鏈(8260) C#(7972) AI(7469) 爪哇(7425) MySQL(7151) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5870) 数组(5741) R(5409) Linux(5330) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4564) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2431) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1961) Web開發(1951) HtmlCss(1928) python-3.x(1918) 弹簧靴(1913) C++(1912) xml(1889) PostgreSQL(1874) .NETCore(1855) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • CA和證書

    1、在 CentOS7 中使用 gpg 創建 RSA 非對稱密鑰對 gpg --gen-key #Centos上生成公鑰/密鑰對(存放在家目錄.gnupg/) 2、將 CentOS7 匯出的公鑰,拷貝到 CentOS8 中,在 CentOS8 中使用 CentOS7 的公鑰加密一個檔案 gpg -a ......

    uj5u.com 2020-09-10 00:09:53 more
  • Kubernetes K8S之資源控制器Job和CronJob詳解

    Kubernetes的資源控制器Job和CronJob詳解與示例 ......

    uj5u.com 2020-09-10 00:10:45 more
  • VMware下安裝CentOS

    VMware下安裝CentOS 一、軟硬體準備 1 Centos鏡像準備 1.1 CentOS鏡像下載地址 下載地址 1.2 CentOS鏡像下載程序 點擊下載地址進入如下圖的網站,選擇需要下載的版本,這里選擇的是Centos8,點擊如圖所示。 決定選擇Centos8后,選擇想要的鏡像源進行下載,此 ......

    uj5u.com 2020-09-10 00:12:10 more
  • 如何使用Grep命令查找多個字串

    如何使用Grep 命令查找多個字串 大家好,我是良許! 今天向大家介紹一個非常有用的技巧,那就是使用 grep 命令查找多個字串。 簡單介紹一下,grep 命令可以理解為是一個功能強大的命令列工具,可以用它在一個或多個輸入檔案中搜索與正則運算式相匹配的文本,然后再將每個匹配的文本用標準輸出的格式 ......

    uj5u.com 2020-09-10 00:12:28 more
  • git配置http代理

    git配置http代理 經常遇到克隆 github 慢的問題,這里記錄一下幾種配置 git 代理的方法,解決 clone github 過慢。 目錄 git配置代理 git單獨配置github代理 git配置全域代理 配置終端環境變數 git配置代理 主要使用 git config 命令 git單獨 ......

    uj5u.com 2020-09-10 00:12:33 more
  • Linux npm install 裝包時提示Error EACCES permission denied解

    npm install 裝包時提示Error EACCES permission denied解決辦法 ......

    uj5u.com 2020-09-10 00:12:53 more
  • Centos 7下安裝nginx,使用yum install nginx,提示沒有可用的軟體包

    Centos 7下安裝nginx,使用yum install nginx,提示沒有可用的軟體包。 18 (flaskApi) [root@67 flaskDemo]# yum -y install nginx 19 已加載插件:fastestmirror, langpacks 20 Loading ......

    uj5u.com 2020-09-10 00:13:13 more
  • Linux查看服務器暴力破解ssh IP

    在公網的服務器上經常遇到別人爆破你服務器的22埠,用來挖礦或者干其他嘿嘿嘿的事情~ 這種情況下正確的做法是: 修改默認ssh的22埠 使用設定密鑰登錄或者白名單ip登錄 建議服務器密碼為復雜密碼 創建普通用戶登錄服務器(root權限過大) 建立堡壘機,實作統一管理服務器 統計爆破IP [root ......

    uj5u.com 2020-09-10 00:13:17 more
  • CentOS 7系統常見快捷鍵操作方式

    Linux系統中一些常見的快捷方式,可有效提高操作效率,在某些時刻也能避免操作失誤帶來的問題。 ......

    uj5u.com 2020-09-10 00:13:31 more
  • CentOS 7作業系統目錄結構介紹

    作業系統存在著大量的資料檔案資訊,相應檔案資訊會存在于系統相應目錄中,為了更好的管理資料資訊,會將系統進行一些目錄規劃,不同目錄存放不同的資源。 ......

    uj5u.com 2020-09-10 00:13:35 more
最新发布
  • CentOS搭建squid正向代理

    squid介紹 官網地址:http://www.squid-cache.org/ Squid cache(簡稱為 Squid)是一個流行的自由軟體(GNU 通用公共許可證)的代理服務器和 Web 快取服務器。Squid 有廣泛的用途,從作為網頁服務器的前置 cache 服務器快取相關請求來提高 We ......

    uj5u.com 2023-04-27 09:26:12 more
  • 快速上手Linux核心命令(四):檔案內容相關命令

    @(檔案內容相關命令) 前言 上一篇中已經預告,我們這篇主要說一說Linux中檔案內容查看處理相關的命令。一共16個命令,其中 標注的為重點命令,作業中用的也比較多,需要熟練掌握 cat 合并檔案或查看檔案內容 1、簡介 cat 是concatenate 單詞的縮寫,或者理解成貓,"喵"一下檔案內容 ......

    uj5u.com 2023-04-25 09:19:54 more
  • 快速上手Linux核心命令(四):檔案內容相關命令

    @(檔案內容相關命令) 前言 上一篇中已經預告,我們這篇主要說一說Linux中檔案內容查看處理相關的命令。一共16個命令,其中 標注的為重點命令,作業中用的也比較多,需要熟練掌握 cat 合并檔案或查看檔案內容 1、簡介 cat 是concatenate 單詞的縮寫,或者理解成貓,"喵"一下檔案內容 ......

    uj5u.com 2023-04-25 09:13:56 more
  • 飛騰X100 LPDDR顆粒線序配置輔助工具

    飛騰愛好者技術交流群碼公眾號“烏拉大喵喵” 顆粒線序配置輔助工具 B站講解視頻: 正文內容: 一、 飛騰X100顯存使用LPDDR4時,需要工程師在X100的韌體中去配置線序交換說明,就類似下面這個: 圖1 我們需要輸入每個slice中DQ的線序,也需要輸入slice之間的交換關系,這個作業量也不小 ......

    uj5u.com 2023-04-25 07:19:24 more
  • 手動拷貝檔案至nextcloud中并掃描(docker)

    出于不能在nextcloud的web頁面手動上傳,需要寫腳本實作自動上傳檔案至nextcloud的目的,直接在服務器上將檔案手動拷貝到nextcloud目錄: docker cp /data/files nextcloud:/var/www/html/data/賬號名/files 但是一般人不這么做 ......

    uj5u.com 2023-04-24 09:45:46 more
  • 手動拷貝檔案至nextcloud中并掃描(docker)

    出于不能在nextcloud的web頁面手動上傳,需要寫腳本實作自動上傳檔案至nextcloud的目的,直接在服務器上將檔案手動拷貝到nextcloud目錄: docker cp /data/files nextcloud:/var/www/html/data/賬號名/files 但是一般人不這么做 ......

    uj5u.com 2023-04-24 09:45:00 more
  • vim的常用命令

    Vim的6種基本模式 1. 普通模式在普通模式中,用的編輯器命令,比如移動游標,洗掉文本等等。這也是Vim啟動后的默認模式。這正好和許多新用戶期待的操作方式相反(大多數編輯器默認模式為插入模式)。 2. 插入模式在這個模式中,大多數按鍵都會向文本緩沖中插入文本。大多數新用戶希望文本編輯器編輯程序中一 ......

    uj5u.com 2023-04-20 08:43:21 more
  • vim的常用命令

    Vim的6種基本模式 1. 普通模式在普通模式中,用的編輯器命令,比如移動游標,洗掉文本等等。這也是Vim啟動后的默認模式。這正好和許多新用戶期待的操作方式相反(大多數編輯器默認模式為插入模式)。 2. 插入模式在這個模式中,大多數按鍵都會向文本緩沖中插入文本。大多數新用戶希望文本編輯器編輯程序中一 ......

    uj5u.com 2023-04-20 08:42:36 more
  • docker學習

    ###Docker概述 真實專案部署環境可能非常復雜,傳統發布專案一個只需要一個jar包,運行環境需要單獨部署。而通過Docker可將jar包和相關環境(如jdk,redis,Hadoop...)等打包到docker鏡像里,將鏡像發布到Docker倉庫,部署時下載發布的鏡像,直接運行發布的鏡像即可。 ......

    uj5u.com 2023-04-19 09:26:53 more
  • 設定Windows主機的瀏覽器為wls2的默認瀏覽器

    這里以Chrome為例。 1. 準備作業 wsl是可以使用Windows主機上安裝的exe程式,出于安全考慮,默認情況下改功能是無法使用。要使用的話,終端需要以管理員權限啟動。 我這里以Windows Terminal為例,介紹如何默認使用管理員權限打開終端,具體操作如下圖所示: 2. 操作 wsl ......

    uj5u.com 2023-04-19 09:25:49 more