-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathTiltfile
101 lines (88 loc) · 3.98 KB
/
Tiltfile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
run_fpd_on_host = 'fpd' in os.getenv('RUN_ON_HOST', '').split(',') or os.getenv('RUN_ON_HOST') == 'all'
# Mapping from the provider name to the port it listens on
all_providers = {
'elasticsearch': 9200,
'loki': 3100,
'prometheus': 9090,
}
# Start the data source providers
if not os.getenv('PROVIDERS'):
providers = [] # Default to no providers, since especially Elastic is really memory hungry
elif os.getenv('PROVIDERS') == 'all':
providers = all_providers.keys()
else:
providers = os.getenv('PROVIDERS').split(',')
data_sources_yaml = ''
for provider in providers:
if provider not in all_providers:
print('Provider %s not found. Available providers: %s' % (provider, ', '.join(all_providers.keys())))
continue
port = all_providers[provider]
# If the daemon is running outside of docker, it will access the providers via ports on localhost
# Otherwise, it will access them via the provider-specific kubernetes service
url = 'http://{}:{}'.format('localhost' if run_fpd_on_host else provider, port)
k8s_yaml([
'./deployment/local/%s_deployment.yaml' % provider,
'./deployment/local/%s_service.yaml' % provider,
])
k8s_resource(provider, port_forwards=port, labels=['customer'])
# Append the configuration to the data sources file used to configure the daemon
data_sources_yaml += '''
- name: {provider}
providerType: {provider}
description: {provider} on the local daemon
config:
url: {url}
'''.format(provider=provider, url=url)
# If elasticsearch is running, add fluentd to forward logs to it
if 'elasticsearch' in providers:
fluentd_env={}
# In some k8s versions, logging is done with a different standard
# so this configures fluentd to understand the correct one
# See https://github.com/fluent/fluentd-kubernetes-daemonset/tree/master#use-cri-parser-for-containerdcri-o-logs
if k8s_context() in ['kind-kind']:
fluentd_env['FLUENT_CONTAINER_TAIL_PARSER_TYPE'] = '/^(?<time>.+) (?<stream>stdout|stderr)( (?<logtag>.))? (?<log>.*)$/'
k8s_yaml(local('./scripts/template.sh ./deployment/local/fluentd.template.yaml', env=fluentd_env))
k8s_resource('fluentd',
resource_deps=['elasticsearch'],
objects=['fluentd:serviceaccount', 'fluentd:clusterrole', 'fluentd:clusterrolebinding'],
labels=['customer'])
env={
'RUST_LOG': os.getenv('RUST_LOG', 'fpd=trace'),
'LISTEN_ADDRESS': '127.0.0.1:3002',
'API_BASE': 'ws://localhost:3030' if run_fpd_on_host else 'ws://api',
# The Token still contains "proxy" as it's the legacy name of fpd
# To change this, a synchronized change in fiberplane/api/src/fixtures/mod.rs::PROXY_NAME
# is necessary
'TOKEN':'8Z3flBLMQ7O7-b2uS85QLw:proxy:MVPpfxAYRxcQ4rFZUB7RRzirzwhR7htlkU3zcDm-pZk',
}
if run_fpd_on_host:
# Write the data_sources.yaml to disk and point the daemon to it
env['DATA_SOURCES'] = 'deployment/local/data_sources.yaml'
if os.getenv('OVERWRITE_DATA_SOURCES') != '0':
local('echo %s > deployment/local/data_sources.yaml' % shlex.quote(data_sources_yaml))
# Make sure providers have been pulled at least once.
if not os.path.exists("providers"):
local('cargo run pull --wasm-dir=providers')
local_resource('fpd',
serve_env=env,
serve_cmd='cargo run -- --wasm-dir providers',
deps=['fpd', 'providers', 'deployment/local/data_sources.yaml'],
resource_deps=providers,
# Note: this endpoint is called "/health" rather than "healthz"
readiness_probe=probe(http_get=http_get_action(3002, path='/health')))
else:
k8s_resource(workload='fpd', resource_deps=providers, objects=['fpd:configmap'], port_forwards=3002, labels=['customer'])
k8s_yaml(local('./scripts/template.sh deployment/local/deployment.template.yaml', env=env))
# Apply the data sources configuration using k8s configmap
data_sources_yaml = '"[]"' if len(data_sources_yaml) == 0 else ('|\n' + data_sources_yaml).replace('\n', '\n ')
configmap = '''
apiVersion: v1
kind: ConfigMap
metadata:
name: fpd
namespace: default
data:
data_sources.yaml: %s
''' % data_sources_yaml
k8s_yaml(blob(configmap))