mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-27 00:23:41 +09:00 
			
		
		
		
	Reduce unnecessary DB queries for Actions tasks (#25199)
Close #24544 Changes: - Create `action_tasks_version` table to store the latest version of each scope (global, org and repo). - When a job with the status of `waiting` is created, the tasks version of the scopes it belongs to will increase. - When the status of a job already in the database is updated to `waiting`, the tasks version of the scopes it belongs to will increase. - On Gitea side, in `FeatchTask()`, will try to query the `action_tasks_version` record of the scope of the runner that call `FetchTask()`. If the record does not exist, will insert a row. Then, Gitea will compare the version passed from runner to Gitea with the version in database, if inconsistent, try pick task. Gitea always returns the latest version from database to the runner. Related: - Protocol: https://gitea.com/gitea/actions-proto-def/pulls/10 - Runner: https://gitea.com/gitea/act_runner/pulls/219
This commit is contained in:
		| @@ -111,6 +111,13 @@ func UpdateRunJob(ctx context.Context, job *ActionRunJob, cond builder.Cond, col | ||||
| 		return affected, nil | ||||
| 	} | ||||
|  | ||||
| 	if affected != 0 && util.SliceContains(cols, "status") && job.Status.IsWaiting() { | ||||
| 		// if the status of job changes to waiting again, increase tasks version. | ||||
| 		if err := IncreaseTaskVersion(ctx, job.OwnerID, job.RepoID); err != nil { | ||||
| 			return affected, err | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	if job.RunID == 0 { | ||||
| 		var err error | ||||
| 		if job, err = GetRunJobByID(ctx, job.ID); err != nil { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user