• Dnsmasq的使用


    Dnsmasq的简介

    Dnsmasq 提供 DNS 缓存和 DHCP 服务功能。

    作为域名解析服务器(DNS),dnsmasq可以通过缓存 DNS 请求来提高对访问过的网址的连接速度。作为DHCP 服务器,dnsmasq 可以为局域网电脑提供内网ip地址和路由。

    DNS和DHCP两个功能可以同时或分别单独实现。

    dnsmasq轻量且易配置,适用于个人用户或少于50台主机的网络。

    Dnsmasq原理

    •本机APP访问主机的/etc/resolv.conf获取DNSServer,该文件指向的DNSServer为Dnsmasq。

    •本地局域网中的主机可以直接访问Dnsmasq,即在这些主机中/etc/resolv.conf指向了Dnsmasq。

    •Dnsmasq需要通过上游DNS来进行域名解析,上游DNS可以配置在/etc/resolv.dnsmasq.conf中,该文件需要在Dnsmasq的配置文件/etc/dnsmasq.conf中指定。


    DNS子系统为网络提供本地DNS服务器,将所有查询类型转发到上游递归DNS服务器并缓存常用记录类型(A,AAAA,CNAME和PTR,以及启用DNSSEC时的DNSKEY和DS

    • 本地DNS名称可通过读取/ etc / hosts,通过从DHCP子系统导入名称或配置各种有用的记录类型来定义。
    • 上游服务器可以用各种方便的方式进行配置,包括动态配置,这些配置会随着移动上游网络而发生变化。
    • 权威DNS模式允许本地DNS名称可以导出到全球DNS中的区域。Dnsmasq充当此区域的权威服务器,并且还根据需要为该区域的辅助区域提供区域传输。
    • 可以对来自上游名称服务器的DNS答复执行DNSSEC验证,从而提供针对欺骗和缓存中毒的安全性。
    • 指定的子域可以定向到它们自己的上游DNS服务器,从而使VPN配置变得容易。
    • 支持国际化域名。

    DHCP子系统支持DHCPv4,DHCPv6,BOOTP和PXE。

    • 支持静态和动态DHCP租约,以及DHCPv6中的无状态模式。
    • PXE系统是一个完整的PXE服务器,支持网络引导菜单和多种体系结构支持。它包括代理模式,PXE系统与另一台DHCP服务器协同工作。
    • 有一个内置的只读TFTP服务器来支持网络启动。
    • 通过DHCP配置的计算机的名称会自动包含在DNS中,并且名称可以由每台计算机指定,或者通过在dnsmasq配置文件中将名称与MAC地址或UID关联来集中进行。
    • 路由器通告子系统为IPv6主机提供基本的自动配置。它可以单独使用或与DHCPv6结合使用。

    M和O位是可配置的,以控制主机使用DHCPv6。

    • 路由器通告可以包含RDNSS选项。
    • 有一种方式使用来自DHCPv4配置的名称信息来为自动配置的IPv6地址提供DNS条目,否则这些地址将是匿名的。
    • 为了更加紧凑,编译时可能会
    • 省略未使用的特性。

    配置

    1. #############################################################################
    2. #
    3. # DNS 选项
    4. #
    5. ##############################################################################
    6. # 不加载本地的 /etc/hosts 文件
    7. #no-hosts
    8. # 添加读取额外的 hosts 文件路径,可以多次指定。如果指定为目录,则读取目录中的所有文件。
    9. #addn-hosts=/etc/hosts
    10. # 读取目录中的所有文件,文件更新将自动读取
    11. #hostsdir=<path>
    12. # 例如,/etc/hosts中的os01将扩展成os01.example.com
    13. #expand-hosts
    14. ##############################################################################
    15. # 缓存时间设置,一般不需要设置
    16. # 本地 hosts 文件的缓存时间,通常不要求缓存本地,这样更改hosts文件后就即时生效。
    17. #local-ttl=3600
    18. # 同 local-ttl 仅影响 DHCP 租约
    19. #dhcp-ttl=<time>
    20. # 对于上游返回的值没有ttl时,dnsmasq给一个默认的ttl,一般不需要设置,
    21. #neg-ttl=<time>
    22. # 指定返回给客户端的ttl时间,一般不需要设置
    23. #max-ttl=<time>
    24. # 设置在缓存中的条目的最大 TTL。
    25. #max-cache-ttl=<time>
    26. # 不需要设置,除非你知道你在做什么。
    27. #min-cache-ttl=<time>
    28. # 一般不需要设置
    29. #auth-ttl=<time>
    30. ##############################################################################
    31. # 记录dns查询日志
    32. #log-queries
    33. # 设置日志记录器,‘-‘ 为 stderr,也可以是文件路径。默认为:DAEMON,调试时使用 LOCAL0。
    34. #log-facility=<facility>
    35. #log-facility=/var/log/dnsmasq/dnsmasq.log
    36. # 异步log,缓解阻塞,提高性能。默认为5,最大100。
    37. #log-async[=<lines>]
    38. #log-async=50
    39. ##############################################################################
    40. # 指定用户和组
    41. #user=nobody
    42. #group=nobody
    43. ##############################################################################
    44. # 指定DNS的端口,默认53,设置 port=0 将完全禁用 DNS 功能,仅使用 DHCP/TFTP
    45. #port=53
    46. # 指定 EDNS.0 UDP 包的最大尺寸,默认为 RFC5625 推荐的 edns-packet-max=4096
    47. #edns-packet-max=<size>
    48. # 指定向上游查询的 UDP 端口,默认是随机端口,指定后降低安全性、加快速度、减少资源消耗。
    49. # 设置为 0 有操作系统分配。
    50. query-port=53535
    51. # 指定向上游查询的 UDP 端口范围,方便防火墙设置。
    52. #min-port=<port>
    53. #max-port=<port>
    54. # 指定接口,指定后同时附加 lo 接口,可以使用‘*‘通配符
    55. #interface=wlp2s0
    56. # 指定排除的接口,排除高优先级,可以使用‘*‘通配符
    57. #except-interface=
    58. # 启用 DNS 验证模式
    59. #auth-server=<domain>,<interface>|<ip-address>
    60. # 仅接收同一子网的 DNS 请求,仅在未指定 interface、except-interface、listen-address
    61. # 或者 auth-server 时有效。
    62. #local-service
    63. # 指定不提供 DHCP 或 TFTP 服务的接口,仅提供 DNS 服务
    64. #no-dhcp-interface=enp3s0
    65. # 指定IP地址,可以多次指定。下面两行跟指定接口的作用类似。
    66. #listen-address=192.168.10.254
    67. #listen-address=127.0.0.1
    68. # 绑定接口,开启此项将仅监听指定的接口。
    69. #bind-interfaces
    70. # 对于新添加的接口也进行绑定。
    71. #bind-dynamic
    72. ##############################################################################
    73. # 如果 hosts 中的主机有多个 IP 地址,仅返回对应子网的 IP 地址。
    74. #localise-queries
    75. # 如果反向查找的是私有地址例如192.168.X.X,仅从 hosts 文件查找,不再转发到上游服务器
    76. #bogus-priv
    77. # 对于任何被解析到此IP的域名,使其解析失效,可以多次指定
    78. #bogus-nxdomain=64.94.110.11
    79. # 忽略指定的 DNS 响应服务器地址,例如 1.1.1.1 为伪造的 dns 服务器并且响应速度非常快,
    80. # 指定 ignore-address=1.1.1.1 可以忽略它的响应信息,从而等待正确的响应结果。
    81. #ignore-address=<ipaddr>
    82. #filterwin2k
    83. ##############################################################################
    84. # 指定 resolv-file 文件路径,默认/etc/resolv.conf
    85. #resolv-file=/etc/resolv.conf
    86. # 不读取 resolv-file 来确定上游服务器
    87. #no-resolv
    88. # 在编译时需要启用 DBus 支持。
    89. #enable-dbus[=<service-name>]
    90. # 严格按照resolv.conf中的顺序进行查找
    91. #strict-order
    92. # 向所有上有服务器发送查询,而不是一个。
    93. #all-servers
    94. #dns-loop-detect
    95. ##############################################################################
    96. # 这项安全设置是拒绝解析包含私有 IP 地址的域名,
    97. # 这些IP地址包括如下私有地址范围:10.0.0.0/8、172.16.0.0/12、192.168.0.0/16。
    98. # 其初衷是要防止类似上游DNS服务器故意将某些域名解析成特定私有内网IP而劫持用户这样的安全攻击。
    99. # 直接在配置文件中注销 stop-dns-rebind 配置项从而禁用该功能。
    100. # 这个方法确实可以一劳永逸的解决解析内网 IP 地址的问题,但是我们也失去了这项安全保护的特性,
    101. # 所以在这里我不推荐这个办法。
    102. # 使用 rebind-domain-ok 进行特定配置,顾名思义该配置项可以有选择的忽略域名的 rebind 行为
    103. #stop-dns-rebind
    104. #rebind-localhost-ok
    105. #rebind-domain-ok=[<domain>]|[[/<domain>/[<domain>/]
    106. #rebind-domain-ok=/.dinghuangjie.com/.dhj.com/.harlinsu.com/.example.com/.test.com/.esderive.com/
    107. ##############################################################################
    108. # 也不要检测 /etc/resolv.conf 的变化
    109. #no-poll
    110. # 重启后清空缓存
    111. #clear-on-reload
    112. # 完整的域名才向上游服务器查找,如果仅仅是主机名仅查找hosts文件
    113. #domain-needed
    114. ##############################################################################
    115. # IP地址转换
    116. #alias=[<old-ip>]|[<start-ip>-<end-ip>],<new-ip>[,<mask>]
    117. ##############################################################################
    118. #local=[/[<domain>]/[domain/]][<ipaddr>[#<port>][@<source-ip>|<interface>[#<port>]]
    119. #server=[/[<domain>]/[domain/]][<ipaddr>[#<port>][@<source-ip>|<interface>[#<port>]]
    120. #server=/example.com/192.168.10.252
    121. #rev-server=<ip-address>/<prefix-len>,<ipaddr>[#<port>][@<source-ip>|<interface>[#<port>]]
    122. # 将任何属于 <domain> 域名解析成指定的 <ipaddr> 地址。
    123. # 也就是将 <domain> 及其所有子域名解析成指定的 <ipaddr> IPv4 或者 IPv6 地址,
    124. # 通常用于屏蔽特定的域名。
    125. # 一次只能指定一个 IPv4 或者 IPv6 地址,
    126. # 要同时返回 IPv4 和IPv6 地址,请多次指定 address= 选项。
    127. # 注意: /etc/hosts 以及 DHCP 租约将覆盖此项设置。
    128. #address=/<domain>/[domain/][<ipaddr>]
    129. #ipset=/<domain>/[domain/]<ipset>[,<ipset>]
    130. #mx-host=<mx name>[[,<hostname>],<preference>]
    131. #mx-target=<hostname>
    132. # SRV 记录
    133. #srv-host=<_service>.<_prot>.[<domain>],[<target>[,<port>[,<priority>[,<weight>]]]]
    134. # A, AAAA 和 PTR 记录
    135. #host-record=<name>[,<name>....],[<IPv4-address>],[<IPv6-address>][,<TTL>]
    136. # TXT 记录
    137. #txt-record=<name>[[,<text>],<text>]
    138. # PTR 记录
    139. #ptr-record=<name>[,<target>]
    140. #naptr-record=<name>,<order>,<preference>,<flags>,<service>,<regexp>[,<replacement>]
    141. # CNAME 别名记录
    142. #cname=<cname>,<target>[,<TTL>]
    143. #dns-rr=<name>,<RR-number>,[<hex data>]
    144. #interface-name=<name>,<interface>[/4|/6]
    145. #synth-domain=<domain>,<address range>[,<prefix>]
    146. #add-mac[=base64|text]
    147. #add-cpe-id=<string>
    148. #add-subnet[[=[<IPv4 address>/]<IPv4 prefix length>][,[<IPv6 address>/]<IPv6 prefix length>]]
    149. ##############################################################################
    150. ##############################################################################
    151. # 缓存条数,默认为150条,cache-size=0 禁用缓存。
    152. cache-size=1000
    153. # 不缓存未知域名缓存,默认情况下dnsmasq缓存未知域名并直接返回为客户端。
    154. #no-negcache
    155. # 指定DNS同属查询转发数量
    156. dns-forward-max=1000
    157. # 启用连接跟踪,读取 Linux 入栈 DNS 查询请求的连接跟踪标记,
    158. # 并且将上游返回的响应信息设置同样的标记。
    159. # 用于带宽控制和防火墙部署。
    160. # 此选项必须在编译时启用 conntrack 支持,并且内核正确配置并加载 conntrack。
    161. # 此选项不能与 query-port 同时使用。
    162. #conntrack
    163. ##############################################################################
    164. #
    165. # DHCP 选项
    166. #
    167. ##############################################################################
    168. # 设置 DHCP 地址池,同时启用 DHCP 功能。
    169. # IPv4 <mode> 可指定为 static|proxy ,当 <mode> 指定为 static 时,
    170. # 需用 dhcp-host 手动分配地址池中的 IP 地址。
    171. # 当 <mode> 指定为 proxy 时,为指定的地址池提供 DHCP 代理。
    172. #dhcp-range=[tag:<tag>[,tag:<tag>],][set:<tag>,]<start-addr>[,<end-addr>][,<mode>][,<netmask>[,<broadcast>]][,<lease time>]
    173. #dhcp-range=172.16.0.2,172.16.0.250,255.255.255.0,1h
    174. #dhcp-range=192.168.10.150,192.168.10.180,static,255.255.255.0,1h
    175. # 根据 MAC 地址或 id 固定分配客户端的 IP 地址、主机名、租期。
    176. # IPv4 下指定 id:* 将忽略 DHCP 客户端的 ID ,仅根据 MAC 来进行 IP 地址分配。
    177. # 在读取 /etc/hosts 的情况,也可以根据 /etc/hosts 中的主机名分配对应 IP 地址。
    178. # 指定 ignore 将忽略指定客户端得 DHCP 请求。
    179. #dhcp-host=[<hwaddr>][,id:<client_id>|*][,set:<tag>][,<ipaddr>][,<hostname>][,<lease_time>][,ignore]
    180. #dhcp-hostsfile=<path>
    181. #dhcp-hostsdir=<path>
    182. # 读取 /etc/ethers 文件 与使用 dhcp-host 的作用相同。IPv6 无效。
    183. #read-ethers
    184. # 指定给 DHCP 客户端的选项信息,
    185. # 默认情况下 dnsmasq 将发送:子网掩码、广播地址、DNS 服务器地址、网关地址、域等信息。
    186. # 指定此选项也可覆盖这些默认值并且设置其他选项值。
    187. # 重要:可以使用 option:<option-name>或者 option号 来指定。
    188. # <option-name> 和 option号的对应关系可使用命令:
    189. # dnsmasq --help dhcp 以及 dnsmasq --help dhcp6 查看,这点很重要。
    190. # 例如设置网关参数,既可以使用 dhcp-option=3,192.168.4.4 也可以使用 dhcp-option = option:router,192.168.4.4。
    191. # 0.0.0.0 意味着当前运行 dnsmasq 的主机地址。
    192. # 如果指定了多个 tag:<tag> 必须同时匹配才行。
    193. # [encap:<opt>,][vi-encap:<enterprise>,][vendor:[<vendor-class>],] 有待继续研究。
    194. #dhcp-option=[tag:<tag>,[tag:<tag>,]][encap:<opt>,][vi-encap:<enterprise>,][vendor:[<vendor-class>],][<opt>|option:<opt-name>|option6:<opt>|option6:<opt-name>],[<value>[,<value>]]
    195. #dhcp-option-force=[tag:<tag>,[tag:<tag>,]][encap:<opt>,][vi-encap:<enterprise>,][vendor:[<vendor-class>],]<opt>,[<value>[,<value>]]
    196. #dhcp-optsfile=<path>
    197. #dhcp-optsdir=<path>
    198. #dhcp-option=3,1.2.3.4
    199. #dhcp-option=option:router,1.2.3.4
    200. #dhcp-option=option:router,192.168.10.254
    201. #dhcp-option=option:dns-server,192.168.10.254,221.12.1.227,221.12.33.227
    202. ##############################################################################
    203. # (IPv4 only) 禁用重用服务器名称和文件字段作为额外的 dhcp-option 选项。
    204. # 一般情况下 dnsmasq 从 dhcp-boot 移出启动服务器和文件信息到 dhcp-option 选项中。
    205. # 这使得在 dhcp-option 选项封包中有额外的选项空间可用,但是会使老的客户端混淆。
    206. # 此选项将强制使用简单并安全的方式来避免此类情况。可以认为是一个兼容性选项。
    207. #dhcp-no-override
    208. # Send an empty WPAD option. This may be REQUIRED to get windows 7 to behave.
    209. #dhcp-option=252,"\n"
    210. ##############################################################################
    211. # 配置 DHCP 中继。
    212. # <local address> 是运行 dnsmasq 的接口的 IP 地址。
    213. # 所有在 <local address> 接口上接收到的 DHCP 请求将中继到 <server address> 指定的远程 DHCP 服务器。
    214. # 可以多次配置此选项,使用同一个 <local address> 转发到多个不同的 <server address> 指定的远程 DHCP 服务器。
    215. # <server address> 仅允许使用 IP 地址,不能使用域名等其他格式。
    216. # 如果是 DHCPv6,<server address> 可以是 ALL_SERVERS 的多播地址 ff05::1:3 。
    217. # 在这种情况下必须指定接口 <interface> ,不能使用通配符,用于直接多播到对应的 DHCP 服务器所在的接口。
    218. # <interface> 指定了仅允许接收从 <interface> 接口的 DHCP 服务器相应信息。
    219. #dhcp-relay=<local address>,<server address>[,<interface>]
    220. ##############################################################################
    221. # 设置标签
    222. #dhcp-vendorclass=set:<tag>,[enterprise:<IANA-enterprise number>,]<vendor-class>
    223. #dhcp-userclass=set:<tag>,<user-class>
    224. #dhcp-mac=set:<tag>,<MAC address>
    225. #dhcp-circuitid=set:<tag>,<circuit-id>
    226. #dhcp-remoteid=set:<tag>,<remote-id>
    227. #dhcp-subscrid=set:<tag>,<subscriber-id>
    228. #dhcp-match=set:<tag>,<option number>|option:<option name>|vi-encap:<enterprise>[,<value>]
    229. #tag-if=set:<tag>[,set:<tag>[,tag:<tag>[,tag:<tag>]]]
    230. #dhcp-proxy[=<ip addr>]......
    231. ##############################################################################
    232. # 不分配匹配这些 tag:<tag> 的 DHCP 请求。
    233. #dhcp-ignore=tag:<tag>[,tag:<tag>]
    234. #dhcp-ignore-names[=tag:<tag>[,tag:<tag>]]
    235. #dhcp-generate-names=tag:<tag>[,tag:<tag>]
    236. # IPv4 only 使用广播与匹配 tag:<tag> 的客户端通信。一般用于兼容老的 BOOT 客户端。
    237. #dhcp-broadcast[=tag:<tag>[,tag:<tag>]]
    238. ##############################################################################
    239. # IPv4 only 设置 DHCP 服务器返回的 BOOTP 选项,
    240. # <servername> <server address> 可选,
    241. # 如果未设置服务器名称将设为空,服务器地址设为 dnsmasq 的 IP 地址。
    242. # 如果指定了多个 tag:<tag> 必须同时匹配才行。
    243. # 如果指定 <tftp_servername> 将按照 /etc/hosts 中对应的 IP 地址进行轮询负载均衡。
    244. #dhcp-boot=[tag:<tag>,]<filename>,[<servername>[,<server address>|<tftp_servername>]]
    245. # 根据不同的类型使用不同的选项。
    246. # 使用示例:
    247. # dhcp-match=set:EFI_x86-64,option:client-arch,9
    248. # dhcp-boot=tag:EFI_x86-64,uefi/grubx64.efi
    249. # #dhcp-match=set:EFI_Xscale,option:client-arch,8
    250. # #dhcp-boot=tag:EFI_Xscale,uefi/grubx64.efi
    251. # #dhcp-match=set:EFI_BC,option:client-arch,7
    252. # #dhcp-boot=tag:EFI_BC,uefi/grubx64.efi
    253. # #dhcp-match=set:EFI_IA32,option:client-arch,6
    254. # #dhcp-boot=tag:EFI_IA32,uefi/grubx64.efi
    255. # #dhcp-match=set:Intel_Lean_Client,option:client-arch,5
    256. # #dhcp-boot=tag:Intel_Lean_Client,uefi/grubx64.efi
    257. # #dhcp-match=set:Arc_x86,option:client-arch,4
    258. # #dhcp-boot=tag:Arc_x86,uefi/grubx64.efi
    259. # #dhcp-match=set:DEC_Alpha,option:client-arch,3
    260. # #dhcp-boot=tag:DEC_Alpha,uefi/grubx64.efi
    261. # #dhcp-match=set:EFI_Itanium,option:client-arch,2
    262. # #dhcp-boot=tag:EFI_Itanium,uefi/grubx64.efi
    263. # #dhcp-match=set:NEC/PC98,option:client-arch,1
    264. # #dhcp-boot=tag:NEC/PC98,uefi/grubx64.efi
    265. # dhcp-match=set:Intel_x86PC,option:client-arch,0
    266. # dhcp-boot=tag:Intel_x86PC,pxelinux.0
    267. ##############################################################################
    268. # DHCP 使用客户端的 MAC 地址的哈希值为客户端分配 IP 地址,
    269. # 通常情况下即使客户端使自己的租约到期,客户端的 IP 地址仍将长期保持稳定。
    270. # 在默认模式下,IP 地址是随机分配的。
    271. # 启用 dhcp-sequential-ip 选项将按顺序分配 IP 地址。
    272. # 在顺序分配模式下,客户端使租约到期更像是仅仅移动一下 IP 地址。
    273. # 在通常情况下不建议使用这种方式。
    274. #dhcp-sequential-ip
    275. ##############################################################################
    276. # 多数情况下我们使用 PXE,只是简单的允许 PXE 客户端获取 IP 地址,
    277. # 然后 PXE 客户端下载 dhcp-boot 选项指定的文件并执行,也就是 BOOTP 的方式。
    278. # 然而在有适当配置的 DHCP 服务器支持的情况下,PXE 系统能够实现更复杂的功能。
    279. # pxe-service 选项可指定 PXE 环境的启动菜单。
    280. # 为不同的类型系统设定不同的启动菜单,并且覆盖 dhcp-boot 选项。
    281. # <CSA> 为客户端系统类型:x86PC, PC98, IA64_EFI, Alpha, Arc_x86, Intel_Lean_Client,
    282. # IA32_EFI, X86-64_EFI, Xscale_EFI, BC_EFI, ARM32_EFI 和 ARM64_EFI,其他类型可能为一个整数。
    283. # <basename> 引导 PXE 客户端使用 tftp 从 <server address> 或者 <server_name> 下载文件。
    284. # 注意:"layer" 后缀 (通常是 ".0") 由 PXE 提供,也就是 PXE 客户端默认在文件名附加 .0 后缀。
    285. # 示例:pxe-service=x86PC, "Install Linux", pxelinux (读取 pxelinux.0 文件并执行)
    286. # pxe-service=x86PC, "Install Linux", pxelinux, 1.2.3.4(不适用于老的PXE)
    287. # <bootservicetype> 整数,PXE 客户端将通过广播或者通过 <server address>
    288. # 或者 <server_name> 搜索对应类型的适合的启动服务。。
    289. # 示例:pxe-service=x86PC, "Install windows from RIS server", 1
    290. # pxe-service=x86PC, "Install windows from RIS server", 1, 1.2.3.4
    291. # 未指定 <basename>、<bootservicetype> 或者 <bootservicetype> 为 “0”,将从本地启动。
    292. # 示例:pxe-service=x86PC, "Boot from local disk"
    293. # pxe-service=x86PC, "Boot from local disk", 0
    294. # 如果指定 <server_name> 将按照 /etc/hosts 中对应的 IP 地址进行轮询负载均衡。
    295. #pxe-service=[tag:<tag>,]<CSA>,<menu text>[,<basename>|<bootservicetype>][,<server address>|<server_name>]
    296. # 在 PXE 启动后弹出提示,<prompt> 为提示内容,<timeout> 为超时时间,为 0 则立即执行。
    297. # 如果未指定此选项,在有多个启动选项的情况下等待用户选择,不会超时。
    298. #pxe-prompt=[tag:<tag>,]<prompt>[,<timeout>]
    299. # 根据不同的类型使用不同的菜单,使用示例:
    300. # #pxe-prompt="What system shall I netboot?", 120
    301. # # or with timeout before first available action is taken:
    302. # pxe-prompt="Press F8 or Enter key for menu.", 60
    303. # pxe-service=x86PC, "Now in x86PC (BIOS mode), boot from local", 0
    304. # pxe-service=x86PC, "Now in x86PC (BIOS mode)", pxelinux
    305. # pxe-service=PC98, "Now in PC98 mode", PC98
    306. # pxe-service=IA64_EFI, "Now in IA64_EFI mode", IA64_EFI
    307. # pxe-service=Alpha, "Now in Alpha mode", Alpha
    308. # pxe-service=Arc_x86, "Now in Arc_x86 mode", Arc_x86
    309. # pxe-service=Intel_Lean_Client, "Now in Intel_Lean_Client mode", Intel_Lean_Client
    310. # pxe-service=IA32_EFI, "Now in IA32_EFI mode", IA32_EFI
    311. # pxe-service=X86-64_EFI, "Now in X86-64_EFI (UEFI mode), boot from local", 0
    312. # pxe-service=X86-64_EFI, "Now in X86-64_EFI (UEFI mode)", grub/grub-x86_64.efi
    313. # pxe-service=Xscale_EFI, "Now in Xscale_EFI mode", Xscale_EFI
    314. # pxe-service=BC_EFI, "Now in BC_EFI mode", BC_EFI
    315. # # CentOS7 系统不支持下列两个选项
    316. # #pxe-service=ARM32_EFI,"Now in ARM32_EFI mode",ARM32_EFI
    317. # #pxe-service=ARM64_EFI,"Now in ARM64_EFI mode",ARM64_EFI
    318. ##############################################################################
    319. # 默认为150,即最多分配150个ip地址出去,最大1000个ip
    320. #dhcp-lease-max=150
    321. # (IPv4 only) 指定DHCP端口,默认为67和68。如果不指定则为1067和1068,单指定一个,第二个加1
    322. #dhcp-alternate-port[=<server port>[,<client port>]]
    323. # 谨慎使用此选项,避免 IP 地址浪费。(IPv4 only) 允许动态分配 IP 地址给 BOOTP 客户端。
    324. # 注意:BOOTP 客户端获取的 IP 地址是永久的,将无法再次分配给其他客户端。
    325. #bootp-dynamic[=<network-id>[,<network-id>]]
    326. # 谨慎使用此选项。
    327. # 默认情况下 DHCP 服务器使用 ping 的方式进行确保 IP 未被使用的情况下将 IP 地址分配出去。
    328. # 启用此选项将不使用 ping 进行确认。
    329. #no-ping
    330. ##############################################################################
    331. # 记录额外的 dhcp 日志,记录所有发送给 DHCP 客户端的选项(option)以及标签(tag)信息
    332. #log-dhcp
    333. # 禁止记录日常操作日志,错误日志仍然记录。启用 log-dhcp 将覆盖下列选项。
    334. #quiet-dhcp
    335. #quiet-dhcp6
    336. #quiet-ra
    337. # 修改 DHCP 默认租约文件路径,默认情况下无需修改
    338. #dhcp-leasefile=/var/lib/dnsmasq/dnsmasq.leases
    339. # (IPv6 only)
    340. #dhcp-duid=<enterprise-id>,<uid>
    341. ##############################################################################
    342. #dhcp-script=<path>
    343. #dhcp-luascript=<path>
    344. #dhcp-scriptuser=root
    345. #script-arp
    346. #leasefile-ro
    347. #bridge-interface=<interface>,<alias>[,<alias>]
    348. ##############################################################################
    349. # 给 DHCP 服务器指定 domain 域名信息,也可以给对应的 IP 地址池指定域名。
    350. # 直接指定域名
    351. # 示例:domain=thekelleys.org.uk
    352. # 子网对应的域名
    353. # 示例:domain=wireless.thekelleys.org.uk,192.168.2.0/24
    354. # ip范围对应的域名
    355. # 示例:domain=reserved.thekelleys.org.uk,192.68.3.100,192.168.3.200
    356. #domain=<domain>[,<address range>[,local]]
    357. # 在默认情况下 dnsmasq 插入普通的客户端主机名到 DNS 中。
    358. # 在这种情况下主机名必须唯一,即使两个客户端具有不同的域名后缀。
    359. # 如果第二个客户端使用了相同的主机名,DNS 查询将自动更新为第二个客户端的 IP 地址。
    360. # 如果设置了 dhcp-fqdn 选项,普通的主机名将不再插入到 DNS 中去,
    361. # 仅允许合格的具有域名后缀的主机名插入到 DNS 服务器中。
    362. # 指定此选项需同时指定不含 <address range> 地址范围的 domain 选项。
    363. #dhcp-fqdn
    364. # 通常情况下分配 DHCP 租约后,dnsmasq 设置 FQDN 选项告诉客户端不要尝试 DDNS 更新主机名与 IP 地址。
    365. # 这是因为 name-IP 已自动添加到 dnsmasq 的 DNS 视图中的。
    366. # 设置此选项将允许客户端 DDNS 更新,
    367. # 在 windows 下允许客户端更新 windows AD 服务器是非常有用的。
    368. # 参看 RFC 4702 。
    369. #dhcp-client-update
    370. #enable-ra
    371. #ra-param=<interface>,[high|low],[[<ra-interval>],<router lifetime>]
    372. ##############################################################################
    373. #
    374. # TFTP 选项
    375. #
    376. ##############################################################################
    377. # 对于绝大多数的配置,仅需指定 enable-tftp 和 tftp-root 选项即可。
    378. # 是否启用内置的 tftp 服务器,可以指定多个逗号分隔的网络接口
    379. #enable-tftp[=<interface>[,<interface>]]
    380. #enable-tftp
    381. #enable-tftp=enp3s0,lo
    382. # 指定 tftp 的根目录,也就是寻找传输文件时使用的相对路径,可以附加接口,
    383. #tftp-root=<directory>[,<interface>]
    384. #tftp-root=/var/lib/tftpboot/
    385. # 如果取消注释,那么即使指定的 tftp-root 无法访问,仍然启动 tftp 服务。
    386. #tftp-no-fail
    387. # 附加客户端的 IP 地址作为文件路径。此选项仅在正确设置了 tftp-root 的情况下可用,
    388. # 示例:如果 tftp-root=/tftp,客户端为 192.168.1.15 请求 myfile.txt 文件时,
    389. # 将优先请求 /tftp/192.168.1.15/myfile.txt 文件, 其次是 /tftp/myfile.txt 文件。
    390. # 感觉没什么用。
    391. #tftp-unique-root
    392. # 启用安全模式,启用此选项,仅允许 tftp 进程访问属主为自己的文件。
    393. # 不启用此选项,允许访问所有 tftp 进程属主可读取的文件。
    394. # 如果 dnsmasq 是以 root 用户运行,tftp-secure 选项将允许访问全局可读的文件。
    395. # 一般情况下不推荐以 root 用户运行 dnsmasq。
    396. # 在指定了 tftp-root 的情况下并不是很重要。
    397. #tftp-secure
    398. # 将所有文件请求转换为小写。对于 Windows 客户端来说非常有用,建议开启此项。
    399. # 注意:dnsmasq 的 TFTP 服务器总是将文件路径中的“\”转换为“/”。
    400. #tftp-lowercase
    401. # 允许最大的连接数,默认为 50 。
    402. # 如果将连接数设置的很大,需注意每个进程的最大文件描述符限制,详见文档手册。
    403. #tftp-max=<connections>
    404. #tftp-max=50
    405. # 设置传输时的 MTU 值,建议不设置或按需设置。
    406. # 如果设定的值大于网络接口的 MTU 值,将按照网络接口的 MTU 值自动分片传输(不推荐)。
    407. #tftp-mtu=<mtu size>
    408. # 停止 tftp 服务器与客户端协商 "blocksize" 选项。启用后,防止一些古怪的客户端出问题。
    409. #tftp-no-blocksize
    410. # 指定 tftp 的连接端口的范围,方便防火墙部署。
    411. # tftp 侦听在 69/udp ,连接端口默认是由系统自动分配的,
    412. # 非 root 用户运行时指定的连接端口号需大于 1025 最大 65535。
    413. #tftp-port-range=<start>,<end>
    414. ###############################################################################
    415. #conf-dir=<directory>[,<file-extension>......]
    416. #conf-file=/etc/dnsmasq.more.conf
    417. conf-dir=/etc/dnsmasq.d
    418. #servers-file=<file>

     

  • 相关阅读:
    如何将一个实例的内存二进制内容读出来?
    【Yocto2】构建嵌入式Linux系统
    CentOS7.9 安装postgresql
    切片有哪些注意事项是一定要知道的呢
    【ftp篇】 vsftp(ftp) 每天生成一个动态密码
    浅谈制药企业安全供电系统的设计与应用
    【数据结构】A : A DS图_传递信息
    [paddle]paddlepaddle官方安装命令合集
    Python 采集77个教学课件PPT模板
    Git常见命令总结
  • 原文地址:https://blog.csdn.net/qq_21438461/article/details/125501501