browsertrix/backend/btrixcloud/k8s/templates/profile_job.yaml
Ilya Kreymer 30bda8c75d
VNC-Based Profile Browser (#433)
* profile browser vnc support + fixes:
- switch profile browser rendering to use VNC
- frontend: add @novnc/novnc as dependency, create separate bundle novnc.js to load into vnc browser (to avoid loading from each container)
- frontend: update proxy paths to proxy websocket, index page to crawler
- frontend: allow browser profiles in all browsers, remove browser compatibility check
- frontend: update webpack dev config, apply prettier
- frontend: node version fix
- backend: get vncpassword, build new URL for proxying to crawler iframe
- backend: fix profile / crawl job pull policy from 'Always' -> 'Never', should use existing image for job
- backend: fix kill signal to use bash -c to work with latest backend image
- backend/chart: add 'profile_browser_timeout_seconds' to chart values to control how long profile browser to remain when idle (default to 60)
- backend: remove utils.py, now using secret.token_hex() for random suffix
Co-authored-by: sua yoo <sua@suayoo.com>
2023-01-10 14:42:42 -08:00

84 lines
1.9 KiB
YAML

apiVersion: batch/v1
kind: Job
metadata:
name: "job-{{ id }}"
labels:
btrix.profile: "1"
btrix.archive: {{ aid }}
btrix.user: {{ userid }}
{%- if baseprofile %}
btrix.baseprofile: "{{ baseprofile }}"
{%- endif %}
spec:
template:
metadata:
labels:
btrix.profile: "1"
btrix.archive: {{ aid }}
btrix.user: {{ userid }}
{%- if baseprofile %}
btrix.baseprofile: "{{ baseprofile }}"
{%- endif %}
spec:
restartPolicy: OnFailure
affinity:
nodeAffinity:
preferredDuringSchedulingIgnoredDuringExecution:
- weight: 1
preference:
matchExpressions:
- key: nodeType
operator: In
values:
- "{{ crawler_node_type }}"
tolerations:
- key: "nodeType"
operator: "Equal"
value: "crawling"
effect: "NoSchedule"
containers:
- name: crawl-job
image: {{ job_image }}
imagePullPolicy: Never
command: ["python", "-m", "btrixcloud.k8s.profile_job"]
volumeMounts:
- name: config-volume
mountPath: /config
env:
- name: JOB_ID
valueFrom:
fieldRef:
fieldPath: metadata.labels['job-name']
- name: STORE_PATH
value: {{ storage_path }}
- name: STORAGE_NAME
value: {{ storage_name }}
- name: IDLE_TIMEOUT
value: "{{ idle_timeout }}"
- name: START_URL
value: {{ url }}
- name: PROFILE_PATH
value: {{ profile_path }}
volumes:
- name: config-volume
configMap:
name: shared-job-config
items:
- key: config.yaml
path: config.yaml