annotate dns_check.py @ 59:fa7a71b8a97f

more dns checks, including from inside containers in k8s`
author drewp@bigasterisk.com
date Sun, 01 May 2022 23:30:09 -0700
parents 8945bf71da22
children 5ad4b4c712d9
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
45
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
1 # run key dns lookups everywhere
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
2 import tempfile
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
3
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
4 import requests
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
5 from pyinfra import host
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
6 from pyinfra.operations import apt, files, server, systemd
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
7
59
fa7a71b8a97f more dns checks, including from inside containers in k8s`
drewp@bigasterisk.com
parents: 53
diff changeset
8
45
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
9 def check(name, addr):
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
10 server.shell(commands=[
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
11 # note: one big string
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
12 f"out=`dnsget -q {name}`; "
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
13 f'[ -n "$out" ] || exit 1; '
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
14 f"if [ $out != {addr} ]; then echo got $out >&2 ; exit 1; fi"
59
fa7a71b8a97f more dns checks, including from inside containers in k8s`
drewp@bigasterisk.com
parents: 53
diff changeset
15 ])
fa7a71b8a97f more dns checks, including from inside containers in k8s`
drewp@bigasterisk.com
parents: 53
diff changeset
16
45
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
17
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
18 '''
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
19 idea: read a file that looks like this:
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
20
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
21 on host: bang dash slash prime
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
22 lookup:
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
23 bang 127.0.1.1 10.1.0.1 10.1.0.1 10.5.0.1
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
24 bang5 10.5.0.1 10.5.0.1 10.5.0.1 10.5.0.1
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
25 dash 10.1.0.5 127.0.1.1 10.1.0.5 10.5.0.5
59
fa7a71b8a97f more dns checks, including from inside containers in k8s`
drewp@bigasterisk.com
parents: 53
diff changeset
26 bang.bigasterisk.com
fa7a71b8a97f more dns checks, including from inside containers in k8s`
drewp@bigasterisk.com
parents: 53
diff changeset
27 bang.bigasterisk.com.
fa7a71b8a97f more dns checks, including from inside containers in k8s`
drewp@bigasterisk.com
parents: 53
diff changeset
28 prime
fa7a71b8a97f more dns checks, including from inside containers in k8s`
drewp@bigasterisk.com
parents: 53
diff changeset
29 projects.bigasterisk.com
45
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
30 etc
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
31
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
32 (or another idea: wireguard everywhere all the time)
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
33 '''
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
34
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
35 if host.name in ['dash', 'bang', 'slash']:
59
fa7a71b8a97f more dns checks, including from inside containers in k8s`
drewp@bigasterisk.com
parents: 53
diff changeset
36 check('dash', '10.2.0.77')
fa7a71b8a97f more dns checks, including from inside containers in k8s`
drewp@bigasterisk.com
parents: 53
diff changeset
37 check('projects.bigasterisk.com', '10.2.0.1')
45
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
38 elif host.name in ['prime']:
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
39 check('dash', '10.5.0.5')
53
8945bf71da22 make bang look to itself, not just to ISP, for projects.bigasterisk.com
drewp@bigasterisk.com
parents: 45
diff changeset
40 check('projects.bigasterisk.com', '10.2.0.1') # expected the public addr, but fine
45
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
41 else:
59
fa7a71b8a97f more dns checks, including from inside containers in k8s`
drewp@bigasterisk.com
parents: 53
diff changeset
42 check('dash', '10.2.0.77')
53
8945bf71da22 make bang look to itself, not just to ISP, for projects.bigasterisk.com
drewp@bigasterisk.com
parents: 45
diff changeset
43 check('projects.bigasterisk.com', '10.2.0.1')
45
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
44
59
fa7a71b8a97f more dns checks, including from inside containers in k8s`
drewp@bigasterisk.com
parents: 53
diff changeset
45 if host.name in ['prime']:
45
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
46 check('bang', '10.5.0.1')
59
fa7a71b8a97f more dns checks, including from inside containers in k8s`
drewp@bigasterisk.com
parents: 53
diff changeset
47 check('slash', '10.5.0.6')
45
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
48 else:
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
49 check('bang', '10.2.0.1')
59
fa7a71b8a97f more dns checks, including from inside containers in k8s`
drewp@bigasterisk.com
parents: 53
diff changeset
50 check('slash', '10.2.0.138')
45
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
51
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
52 check('bang5', '10.5.0.1')
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
53 check('prime', '10.5.0.2')
ee00f4b5801a new dns-check task
drewp@bigasterisk.com
parents:
diff changeset
54