码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • docker 部署 coredns(内部域名解析)


    在系统应用中,经常会遇到需要使用 https 域名通讯的需要,在内网中,我们不需要正式在互联网上注册域名,自建一个 dns 服务就能很好的解决问题。

    基本应用

    本文内网为使用 docker 运行一个 coredns 服务的代码示例:

    docker-compose.yml 片段内容如下:

    version: '3.7'
    services:
    
      coredns:
        image: coredns/coredns:1.10.0
        container_name: coredns
        ports:
          - 53:53/udp
        volumes:
          - ./coredns/Corefile:/Corefile
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    脚本中 Corefile 文件内容如下:

    .:53 {
        hosts {
            192.168.1.11 test.com
            192.168.1.12 test1.com
            fallthrough
        }
        forward . 8.8.8.8:53 114.114.114.114:53
        log
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    其中 forward 指向上级 dns 服务

    独立hosts文件方式

    我们还可以将 hosts 独立出来为一个单独的文件,如下所示:

    .:53 {
        hosts /etc/coredns/hostsfile {
            fallthrough
        }
        forward . 8.8.8.8:53 114.114.114.114:53
        log
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    其中 /etc/coredns/hostsfile 为内部域名解析映射文件,使用 docker-compose 的话你需要对应挂载出来:

    version: '3.7'
    services:
    
      coredns:
        image: coredns/coredns:1.10.0
        container_name: coredns
        ports:
          - 53:53/udp
        volumes:
          - ./coredns/hostsfile:/etc/coredns/hostsfile
          - ./coredns/Corefile:/Corefile
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    hostsfile 内容示例如下:

    192.168.1.11 test.com
    192.168.1.12 test1.com
    
    • 1
    • 2

    使用

    以 Linux 为例,修改配置文件 cat /etc/resolv.conf 设置 nameserver 为运行的这个 dns 服务IP地址即可,如下示例:

    [root@localhost /]# cat /etc/resolv.conf 
    # Generated by NetworkManager
    nameserver 192.168.1.2
    
    • 1
    • 2
    • 3

    保持后就可以使用 nslookup 或者 ping 来验证内部域名解析是否正常了。

    参考资料:coredns 官网


    (END)

  • 相关阅读:
    QT笔记——QT组合键 成为 快捷键
    IceRPC之服务器地址与TLS的安全性->快乐的RPC
    Redis缓存使用技巧和设计方案
    内存泄漏Memory leak
    cesiumlab中shp转3dtiles白模效果一
    【微服务部署】五、Jenkins+Docker一键打包部署NodeJS(Vue)项目的Docker镜像步骤详解
    飞桨机器学习最小实现,出租车计费规则预测
    js小数计算丢失精度问题
    德鲁克《卓有成效的管理者》学习&读书-总结
    LeetCode 206. 反转链表(迭代+递归)
  • 原文地址:https://blog.csdn.net/catoop/article/details/127732299
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号