Skip to content

Commit

Permalink
CP-51429 Avoid redundant processing when full metadata already exists…
Browse files Browse the repository at this point in the history
… during sync_updates

Signed-off-by: Lunfan Zhang <[email protected]>
  • Loading branch information
LunfanZhang committed Dec 6, 2024
1 parent 8f49371 commit 1586c74
Show file tree
Hide file tree
Showing 3 changed files with 15 additions and 5 deletions.
12 changes: 11 additions & 1 deletion ocaml/xapi/repository.ml
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,8 @@ module Pkgs = (val Pkg_mgr.get_pkg_mgr)

let capacity_in_parallel = 16

let ( // ) = Filename.concat

(* The cache below is protected by pool's current_operations locking mechanism *)
let updates_in_cache : (API.ref_host, Yojson.Basic.t) Hashtbl.t =
Hashtbl.create 64
Expand Down Expand Up @@ -201,7 +203,15 @@ let sync ~__context ~self ~token ~token_id =
* I.E. proxy username/password and temporary token file path.
*)
write_initial_yum_config ()
)
) ;
(* The custom yum-utils will fully download repository metadata.*)
let repodata_dir =
!Xapi_globs.local_pool_repo_dir
// repo_name
// "repodata"
// "repomd.xml.asc"
in
Sys.file_exists repodata_dir
with e ->
error "Failed to sync with remote YUM repository: %s"
(ExnHelper.string_of_exn e) ;
Expand Down
2 changes: 1 addition & 1 deletion ocaml/xapi/repository.mli
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ val sync :
-> self:[`Repository] API.Ref.t
-> token:string
-> token_id:string
-> unit
-> bool

val create_pool_repository :
__context:Context.t -> self:[`Repository] API.Ref.t -> unit
Expand Down
6 changes: 3 additions & 3 deletions ocaml/xapi/xapi_pool.ml
Original file line number Diff line number Diff line change
Expand Up @@ -3534,10 +3534,10 @@ let sync_repos ~__context ~self ~repos ~force ~token ~token_id =
repos
|> List.iter (fun repo ->
if force then cleanup_pool_repo ~__context ~self:repo ;
sync ~__context ~self:repo ~token ~token_id ;
(* Dnf sync all the metadata including updateinfo,
let complete = sync ~__context ~self:repo ~token ~token_id in
(* Dnf and custom yum-utils sync all the metadata including updateinfo,
* Thus no need to re-create pool repository *)
if Pkgs.manager = Yum then
if Pkgs.manager = Yum && complete = false then
create_pool_repository ~__context ~self:repo
) ;
let checksum = set_available_updates ~__context in
Expand Down

0 comments on commit 1586c74

Please sign in to comment.