Linux 服务器启用 DNS 加密

DNS 加密的常用协议包括 DNS over HTTPS (DoH)DNS over TLS (DoT)DNSCrypt。以下是实现这些加密的步骤和工具建议:


1. 使用 DoH (DNS over HTTPS)

工具推荐:
  • cloudflared(Cloudflare 提供的客户端)
  • doh-client(轻量级 DoH 客户端)
  • coredns(可配置 DoH 服务)
配置步骤:
  1. 安装工具

    例如,使用 cloudflared

    bash 复制代码
    sudo apt update
    sudo apt install cloudflared
  2. 配置 DNS 服务

    修改 /etc/cloudflared/config.yml

    yaml 复制代码
    proxy-dns: true
    proxy-dns-port: 5053
    proxy-dns-upstream:
      - https://1.1.1.1/dns-query
      - https://8.8.8.8/dns-query
  3. 启动服务

    bash 复制代码
    sudo systemctl enable cloudflared
    sudo systemctl start cloudflared
  4. 更改系统 DNS

    编辑 /etc/resolv.conf,将本地解析器指向 127.0.0.1:5053


2. 使用 DoT (DNS over TLS)

工具推荐:
  • Stubby
  • Unbound
配置步骤(以 Stubby 为例):
  1. 安装 Stubby

    bash 复制代码
    sudo apt install stubby
  2. 配置 Stubby

    编辑 /etc/stubby/stubby.yml

    yaml 复制代码
    resolution_type: GETDNS_RESOLUTION_STUB
    dns_transport_list:
      - GETDNS_TRANSPORT_TLS
    tls_authentication: GETDNS_AUTHENTICATION_REQUIRED
    upstream_recursive_servers:
      - address_data: 1.1.1.1
        tls_port: 853
        tls_auth_name: "cloudflare-dns.com"
      - address_data: 8.8.8.8
        tls_port: 853
        tls_auth_name: "dns.google"
  3. 启动服务

    bash 复制代码
    sudo systemctl enable stubby
    sudo systemctl start stubby
  4. 更改系统 DNS

    /etc/resolv.conf 配置为:

    text 复制代码
    nameserver 127.0.0.1

3. 使用 DNSCrypt

工具推荐:
  • dnscrypt-proxy
配置步骤:
  1. 安装 dnscrypt-proxy

    从官方 GitHub 页面下载并安装:

    bash 复制代码
    sudo apt install dnscrypt-proxy
  2. 配置 dnscrypt-proxy

    编辑 /etc/dnscrypt-proxy/dnscrypt-proxy.toml

    toml 复制代码
    server_names = ['cloudflare', 'google']
    listen_addresses = ['127.0.0.1:5353']
  3. 启动服务

    bash 复制代码
    sudo systemctl enable dnscrypt-proxy
    sudo systemctl start dnscrypt-proxy
  4. 更改系统 DNS

    修改 /etc/resolv.conf,指向 127.0.0.1:5353


4. 验证 DNS 加密是否启用

使用以下工具检查 DNS 请求是否加密:

  • dig(检查解析是否通过加密服务)
  • tcpdump(捕获网络流量,验证是否走加密端口)

例如:

bash 复制代码
dig @127.0.0.1 -p 5053 google.com

如果需要进一步优化或解决问题,可以告诉我具体的场景或需求。 😊

相关推荐
烟雨书信17 分钟前
Linux中MySQL的逻辑备份与恢复
linux·运维·mysql
wkj00129 分钟前
QuaggaJS 配置参数详解
java·linux·服务器·javascript·quaggajs
藥瓿亭1 小时前
K8S认证|CKS题库+答案| 5.日志审计
linux·运维·docker·云原生·容器·kubernetes·cka
coder_lorraine1 小时前
【Linux系列】Linux用户大揭秘:从“公寓住户”到“社区管理员”的奇幻之旅
linux
家庭云计算专家2 小时前
飞牛云一键设置动态域名+ipv6内网直通访问内网的ssh服务-家庭云计算专家
运维·云计算·ssh·nextcloud·ddns·动态域名解析
藥瓿锻2 小时前
2024 CKA题库+详尽解析| 15、备份还原Etcd
linux·运维·数据库·docker·容器·kubernetes·cka
bbsh20992 小时前
WebFuture:Ubuntu 系统上在线安装.NET Core 8 的步骤
linux·ubuntu·.netcore·webfuture
太阳之神aboluo2 小时前
压测软件-Jmeter
java·运维·jmeter
ZZZKKKRTSAE2 小时前
快速上手Linux全局搜索正则表达式(grep)
linux·服务器·正则表达式
有谁看见我的剑了?2 小时前
stress 服务器压力测试的工具学习
服务器·学习·压力测试