NAT 下代理最佳实践:HTTP(S)_PROXY/NO_PROXY

目标:在 NAT 模式下,把代理配置成可控、可回滚、不污染系统的状态。
核心策略:优先"按场景临时生效",再考虑"系统级永久生效"。


1) 先搞清楚三类代理场景

1.1 临时代理(推荐:最安全)

只对当前终端/当前命令生效,不会影响系统其他程序。

1.2 用户级代理(较常用)

写进 ~/.bashrc / ~/.zshrc,对该用户所有终端生效。

1.3 系统级代理(最强也最容易踩坑)

影响 apt、GUI、服务进程,配置错了会导致"全系统都上不了网"。

新手优先用临时代理,避免一把梭把系统搞崩。


2) 代理环境变量:你需要记住的 6 个名字

  • HTTP_PROXY
  • HTTPS_PROXY
  • NO_PROXY
  • http_proxy
  • https_proxy
  • no_proxy

经验建议:

  • 同时设置大写 + 小写(兼容更多程序)
  • NO_PROXY 一定要配好(否则本地/内网访问会被代理绕远甚至失败)

3) 临时代理(推荐):只对当前命令生效

3.1 只让这一次 curl 走代理

bash 复制代码
HTTPS_PROXY="http://127.0.0.1:7890" curl -I https://www.google.com

3.2 让这一次 apt update 走代理(常见)

bash 复制代码
sudo HTTPS_PROXY="http://127.0.0.1:7890" HTTP_PROXY="http://127.0.0.1:7890" apt update

这里 127.0.0.1:7890 只是示例:你的代理地址要以实际为准。


4) 会话级代理:对当前终端窗口生效(关闭窗口即失效)

bash 复制代码
export HTTP_PROXY="http://127.0.0.1:7890"
export HTTPS_PROXY="http://127.0.0.1:7890"
export http_proxy="$HTTP_PROXY"
export https_proxy="$HTTPS_PROXY"

# NO_PROXY:本地/内网不走代理(非常重要)
export NO_PROXY="localhost,127.0.0.1,::1,10.0.0.0/8,172.16.0.0/12,192.168.0.0/16"
export no_proxy="$NO_PROXY"

验证:

bash 复制代码
env | egrep -i 'proxy|http_proxy|https_proxy|no_proxy'

5) 用户级永久生效(可回滚):写到 shell 配置里

例如写到 ~/.bashrc 或 ~/.zshrc:

bash 复制代码
# Proxy (optional)
export HTTP_PROXY="http://127.0.0.1:7890"
export HTTPS_PROXY="http://127.0.0.1:7890"
export http_proxy="$HTTP_PROXY"
export https_proxy="$HTTPS_PROXY"
export NO_PROXY="localhost,127.0.0.1,::1,10.0.0.0/8,172.16.0.0/12,192.168.0.0/16"
export no_proxy="$NO_PROXY"

让配置生效:

bash 复制代码
source ~/.bashrc
# 或
source ~/.zshrc

回滚(注释掉那几行即可):

  • 在 rc 文件里删掉/注释 proxy 段
  • 新开终端或 source 一次

6) apt 专用代理(更稳):只影响 apt,不影响全系统

新建配置文件:

bash 复制代码
sudo tee /etc/apt/apt.conf.d/99proxy <<'EOF'
Acquire::http::Proxy "http://127.0.0.1:7890";
Acquire::https::Proxy "http://127.0.0.1:7890";
EOF

验证:

bash 复制代码
sudo apt update

取消(删除文件即可):

bash 复制代码
sudo rm -f /etc/apt/apt.conf.d/99proxy

7) NO_PROXY 怎么写更合理(通用模板)

推荐保留:

  • localhost,127.0.0.1,::1
  • 内网网段:10.0.0.0/8,172.16.0.0/12,192.168.0.0/16

如果你有 Host-only 网段(例如 192.168.56.0/24),也加进去。


8) 代理排障:3 个最小验证命令

bash 复制代码
# 1) 解析是否正常
dig +short google.com

# 2) HTTPS 是否通(看状态码/握手)
curl -I https://www.google.com

# 3) apt 是否通(看是否超时/证书问题)
sudo apt update

相关推荐
_Evan_Yao5 小时前
端口80之外:一个Java小白和HTTP、DNS、FTP、SSH的“隐秘”交手
网络协议·http·ssh
桌面运维家6 小时前
IDV云桌面vDisk机房网络管控访问限制部署方案
运维·服务器·网络
橙子也要努力变强8 小时前
Linux信号机制
linux·服务器·网络
程序猿编码8 小时前
给你的网络流量穿件“隐形衣“:手把手教你用对称加密打造透明安全隧道
linux·开发语言·网络·安全·linux内核
skilllite作者8 小时前
AI agent 的 Assistant Auto LLM Routing 规划的思考
网络·人工智能·算法·rust·openclaw·agentskills
pengyi8710158 小时前
私网IP映射公网基础原理,搭配代理IP远程访问入门
linux·服务器·网络
AILabNotes9 小时前
014、隐私增强技术:零知识证明与混合网络在网关中的应用
网络·区块链·零知识证明
Y学院12 小时前
网络安全基础核心知识点教程
网络·web安全·php
风曦Kisaki14 小时前
#企业级网络架构Day01:网络概述,网络参考模型,交换机命令行
网络·架构·智能路由器
大熊背14 小时前
Serial over TCP实现原理
网络·tcp·isppipeline