Mercurial > code > home > repos > infra
annotate tasks.py @ 145:ee0384eebee5
minor
author | drewp@bigasterisk.com |
---|---|
date | Sat, 11 Mar 2023 11:22:48 -0800 |
parents | 105b628e3bfa |
children | ae13e608b105 |
rev | line source |
---|---|
0
1550a6db59b3
first ported section from ansible. shorter, faster, clearer.
drewp@bigasterisk.com
parents:
diff
changeset
|
1 from invoke import task |
1550a6db59b3
first ported section from ansible. shorter, faster, clearer.
drewp@bigasterisk.com
parents:
diff
changeset
|
2 |
1 | 3 cmd = ''' |
0
1550a6db59b3
first ported section from ansible. shorter, faster, clearer.
drewp@bigasterisk.com
parents:
diff
changeset
|
4 HOME=/root |
1550a6db59b3
first ported section from ansible. shorter, faster, clearer.
drewp@bigasterisk.com
parents:
diff
changeset
|
5 export HOME |
1550a6db59b3
first ported section from ansible. shorter, faster, clearer.
drewp@bigasterisk.com
parents:
diff
changeset
|
6 eval `keychain --quiet --eval id_ecdsa` |
1550a6db59b3
first ported section from ansible. shorter, faster, clearer.
drewp@bigasterisk.com
parents:
diff
changeset
|
7 cd /my/proj/infra |
3
61945df2a392
updates to work on recent raspbian installs
drewp@bigasterisk.com
parents:
1
diff
changeset
|
8 env/bin/pyinfra ''' |
1 | 9 |
139 | 10 def _run(ctx, s): |
11 ctx.run(cmd + 'inventory.py %s' % s, pty=True, echo=True) | |
34
d4fb38f13c79
refactor dns and some other non-net setup
drewp@bigasterisk.com
parents:
23
diff
changeset
|
12 |
103
8b8ef9d8f0fd
dead code and templates, reformat, maybe a little refactor
drewp@bigasterisk.com
parents:
96
diff
changeset
|
13 |
59
fa7a71b8a97f
more dns checks, including from inside containers in k8s`
drewp@bigasterisk.com
parents:
54
diff
changeset
|
14 @task |
139 | 15 def users(ctx): _run(ctx, 'users.py') |
59
fa7a71b8a97f
more dns checks, including from inside containers in k8s`
drewp@bigasterisk.com
parents:
54
diff
changeset
|
16 |
139 | 17 @task |
18 def ssh(ctx): _run(ctx, 'ssh.py') | |
19 | |
20 @task | |
145 | 21 def system(ctx): _run(ctx, 'system.py') |
34
d4fb38f13c79
refactor dns and some other non-net setup
drewp@bigasterisk.com
parents:
23
diff
changeset
|
22 |
d4fb38f13c79
refactor dns and some other non-net setup
drewp@bigasterisk.com
parents:
23
diff
changeset
|
23 @task |
145 | 24 def packages(ctx): _run(ctx, 'packages.py') |
5 | 25 |
3
61945df2a392
updates to work on recent raspbian installs
drewp@bigasterisk.com
parents:
1
diff
changeset
|
26 @task |
139 | 27 def net(ctx): _run(ctx, 'net.py') |
12 | 28 |
139 | 29 @task |
30 def dns(ctx): _run(ctx, 'dns.py') | |
31 | |
32 @task | |
33 def dns_check(ctx): _run(ctx, 'dns_check.py -v') | |
103
8b8ef9d8f0fd
dead code and templates, reformat, maybe a little refactor
drewp@bigasterisk.com
parents:
96
diff
changeset
|
34 |
68 | 35 @task |
139 | 36 def dns_k8s_check(ctx): ctx.run('env/bin/python dns_k8s_check.py', pty=True) |
8 | 37 |
14 | 38 @task |
139 | 39 def wireguard(ctx): _run(ctx, 'wireguard.py') |
14 | 40 |
139 | 41 @task |
42 def kube(ctx): _run(ctx, 'kube.py') | |
8 | 43 |
44 @task | |
139 | 45 def kube_bang(ctx): _run(ctx, 'kube.py --limit bang') |
16 | 46 |
139 | 47 @task |
48 def sync(ctx): _run(ctx, 'sync.py') | |
103
8b8ef9d8f0fd
dead code and templates, reformat, maybe a little refactor
drewp@bigasterisk.com
parents:
96
diff
changeset
|
49 |
96
b70070570e10
new task for building ntop from source
drewp@bigasterisk.com
parents:
72
diff
changeset
|
50 @task |
139 | 51 def mail(ctx): _run(ctx, 'mail.py') |
110 | 52 |
53 @task | |
139 | 54 def home(ctx): _run(ctx, 'home.py') |
55 | |
56 @task | |
57 def pipe(ctx): ctx.run(cmd + 'inventory.py pipe.py --limit pipe', pty=True) | |
96
b70070570e10
new task for building ntop from source
drewp@bigasterisk.com
parents:
72
diff
changeset
|
58 |
111 | 59 @task |
115 | 60 def multikube(ctx): # danger- wipes previous k3s |
111 | 61 from multikube_config import server_node, nodes |
62 ctx.run(cmd + 'inventory.py multikube_wipe.py', pty=True) | |
63 ctx.run(cmd + f'inventory.py multikube.py --limit {server_node}', pty=True) | |
113
c520672d0930
closer to multi-node k3s working, but still doesn't quite network right
drewp@bigasterisk.com
parents:
111
diff
changeset
|
64 if nodes: |
136
375515ab60ba
multikube experiment junk. do not run
drewp@bigasterisk.com
parents:
126
diff
changeset
|
65 ctx.run(cmd + f'inventory.py multikube.py {" ".join(f"--limit {n}" for n in nodes)}', pty=True) |
375515ab60ba
multikube experiment junk. do not run
drewp@bigasterisk.com
parents:
126
diff
changeset
|
66 print("""now try |
375515ab60ba
multikube experiment junk. do not run
drewp@bigasterisk.com
parents:
126
diff
changeset
|
67 curl http://10.43.0.10:9153/metrics | head |
375515ab60ba
multikube experiment junk. do not run
drewp@bigasterisk.com
parents:
126
diff
changeset
|
68 k3s kubectl run hello --image crccheck/hello-world |
375515ab60ba
multikube experiment junk. do not run
drewp@bigasterisk.com
parents:
126
diff
changeset
|
69 curl -m2 http://`kubectl get pod/hello '-o=jsonpath={.status.podIP}'`:8000 |
375515ab60ba
multikube experiment junk. do not run
drewp@bigasterisk.com
parents:
126
diff
changeset
|
70 """) |
111 | 71 |
16 | 72 |
60 | 73 @task |
54 | 74 def all(ctx): |
60 | 75 configs = [ |
76 'users.py', | |
77 'ssh.py', | |
78 'system.py', | |
79 'packages.py', | |
80 'net.py', | |
81 'dns.py', | |
82 'wireguard.py', | |
83 'kube.py', | |
84 'sync.py', | |
85 'mail.py', | |
110 | 86 'home.py', |
60 | 87 ] |
88 # https://github.com/Fizzadar/pyinfra/issues/787 | |
89 #ctx.run(' '.join([cmd, 'inventory.py'] + configs), pty=True) | |
90 for c in configs: | |
126
fe3ae7c95e65
collect all apt/sources.list into a central template
drewp@bigasterisk.com
parents:
115
diff
changeset
|
91 ctx.run(' '.join([cmd, 'inventory.py', c]), pty=True) |
54 | 92 ctx.run('touch /my/proj/infra/ran_all.timestamp') |
93 | |
94 | |
16 | 95 @task |
3
61945df2a392
updates to work on recent raspbian installs
drewp@bigasterisk.com
parents:
1
diff
changeset
|
96 def get_fact(ctx, host='dash', fact='server.LinuxDistribution'): |
8 | 97 ctx.run(cmd + f'{host} -vv fact {fact}', pty=True) |