* ansible: digitalocean tweaks: - add org_name to template - better check for db existence - simplify domain, fix default_org chart: - make job images pull IfNotPresent
		
			
				
	
	
		
			110 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
			
		
		
	
	
			110 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
| apiVersion: batch/v1
 | |
| kind: Job
 | |
| metadata:
 | |
|   name: job-{{ id }}
 | |
|   annotations:
 | |
|     btrix.run.manual: "{{ manual }}"
 | |
| 
 | |
|   labels:
 | |
|     btrix.user: {{ userid }}
 | |
|     btrix.archive: {{ aid }}
 | |
|     btrix.crawlconfig: {{ cid }}
 | |
| 
 | |
| spec:
 | |
|   backoffLimit: 1000
 | |
|   ttlSecondsAfterFinished: 20
 | |
|   template:
 | |
|     metadata:
 | |
|       labels:
 | |
|         btrix.user: {{ userid }}
 | |
|         btrix.archive: {{ aid }}
 | |
|         btrix.crawlconfig: {{ cid }}
 | |
|     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: IfNotPresent
 | |
|           command: ["uvicorn", "btrixcloud.k8s.crawl_job:app", "--host", "0.0.0.0", "--access-log", "--log-level", "info"]
 | |
| 
 | |
|           volumeMounts:
 | |
|             - name: config-volume
 | |
|               mountPath: /config
 | |
| 
 | |
|           envFrom:
 | |
|             - secretRef:
 | |
|                 name: mongo-auth
 | |
| 
 | |
|           env:
 | |
|             - name: JOB_ID
 | |
|               valueFrom:
 | |
|                 fieldRef:
 | |
|                   fieldPath: metadata.labels['job-name']
 | |
| 
 | |
|             - name: RUN_MANUAL
 | |
|               value: "{{ manual }}"
 | |
| 
 | |
|             - name: USER_ID
 | |
|               value: "{{ userid }}"
 | |
| 
 | |
|             - name: ARCHIVE_ID
 | |
|               value: "{{ aid }}"
 | |
| 
 | |
|             - name: CRAWL_CONFIG_ID
 | |
|               value: "{{ cid }}"
 | |
| 
 | |
|             - name: TAGS
 | |
|               value: "{{ tags }}"
 | |
| 
 | |
|             - name: STORE_PATH
 | |
|               valueFrom:
 | |
|                 configMapKeyRef:
 | |
|                   name: crawl-config-{{ cid }}
 | |
|                   key: STORE_PATH
 | |
| 
 | |
|             - name: STORE_FILENAME
 | |
|               valueFrom:
 | |
|                 configMapKeyRef:
 | |
|                   name: crawl-config-{{ cid }}
 | |
|                   key: STORE_FILENAME
 | |
| 
 | |
|             - name: STORAGE_NAME
 | |
|               valueFrom:
 | |
|                 configMapKeyRef:
 | |
|                   name: crawl-config-{{ cid }}
 | |
|                   key: STORAGE_NAME
 | |
| 
 | |
|             - name: PROFILE_FILENAME
 | |
|               valueFrom:
 | |
|                 configMapKeyRef:
 | |
|                   name: crawl-config-{{ cid }}
 | |
|                   key: PROFILE_FILENAME
 | |
| 
 | |
|       volumes:
 | |
|         - name: config-volume
 | |
|           configMap:
 | |
|             name: shared-job-config
 | |
|             items:
 | |
|               - key: config.yaml
 | |
|                 path: config.yaml
 | |
|             
 | |
| 
 | |
| 
 |