Skip to content

Commit f2427b8

Browse files
author
OpenShift Bot
authored
Merge pull request #11973 from smarterclayton/mirror_pullthrough
Merged by openshift-bot
2 parents 93ca46f + 0ce6fd2 commit f2427b8

File tree

18 files changed

+225
-52
lines changed

18 files changed

+225
-52
lines changed

contrib/completions/bash/oadm

+2
Original file line numberDiff line numberDiff line change
@@ -4108,6 +4108,8 @@ _oadm_prune_images()
41084108
flags_with_completion=()
41094109
flags_completion=()
41104110

4111+
flags+=("--all")
4112+
local_nonpersistent_flags+=("--all")
41114113
flags+=("--certificate-authority=")
41124114
local_nonpersistent_flags+=("--certificate-authority=")
41134115
flags+=("--confirm")

contrib/completions/bash/oc

+2
Original file line numberDiff line numberDiff line change
@@ -4161,6 +4161,8 @@ _oc_adm_prune_images()
41614161
flags_with_completion=()
41624162
flags_completion=()
41634163

4164+
flags+=("--all")
4165+
local_nonpersistent_flags+=("--all")
41644166
flags+=("--certificate-authority=")
41654167
local_nonpersistent_flags+=("--certificate-authority=")
41664168
flags+=("--confirm")

contrib/completions/bash/openshift

+4
Original file line numberDiff line numberDiff line change
@@ -4108,6 +4108,8 @@ _openshift_admin_prune_images()
41084108
flags_with_completion=()
41094109
flags_completion=()
41104110

4111+
flags+=("--all")
4112+
local_nonpersistent_flags+=("--all")
41114113
flags+=("--certificate-authority=")
41124114
local_nonpersistent_flags+=("--certificate-authority=")
41134115
flags+=("--confirm")
@@ -8723,6 +8725,8 @@ _openshift_cli_adm_prune_images()
87238725
flags_with_completion=()
87248726
flags_completion=()
87258727

8728+
flags+=("--all")
8729+
local_nonpersistent_flags+=("--all")
87268730
flags+=("--certificate-authority=")
87278731
local_nonpersistent_flags+=("--certificate-authority=")
87288732
flags+=("--confirm")

contrib/completions/zsh/oadm

+2
Original file line numberDiff line numberDiff line change
@@ -4269,6 +4269,8 @@ _oadm_prune_images()
42694269
flags_with_completion=()
42704270
flags_completion=()
42714271

4272+
flags+=("--all")
4273+
local_nonpersistent_flags+=("--all")
42724274
flags+=("--certificate-authority=")
42734275
local_nonpersistent_flags+=("--certificate-authority=")
42744276
flags+=("--confirm")

contrib/completions/zsh/oc

+2
Original file line numberDiff line numberDiff line change
@@ -4322,6 +4322,8 @@ _oc_adm_prune_images()
43224322
flags_with_completion=()
43234323
flags_completion=()
43244324

4325+
flags+=("--all")
4326+
local_nonpersistent_flags+=("--all")
43254327
flags+=("--certificate-authority=")
43264328
local_nonpersistent_flags+=("--certificate-authority=")
43274329
flags+=("--confirm")

contrib/completions/zsh/openshift

+4
Original file line numberDiff line numberDiff line change
@@ -4269,6 +4269,8 @@ _openshift_admin_prune_images()
42694269
flags_with_completion=()
42704270
flags_completion=()
42714271

4272+
flags+=("--all")
4273+
local_nonpersistent_flags+=("--all")
42724274
flags+=("--certificate-authority=")
42734275
local_nonpersistent_flags+=("--certificate-authority=")
42744276
flags+=("--confirm")
@@ -8884,6 +8886,8 @@ _openshift_cli_adm_prune_images()
88848886
flags_with_completion=()
88858887
flags_completion=()
88868888

8889+
flags+=("--all")
8890+
local_nonpersistent_flags+=("--all")
88878891
flags+=("--certificate-authority=")
88888892
local_nonpersistent_flags+=("--certificate-authority=")
88898893
flags+=("--confirm")

docs/generated/oadm_by_example_content.adoc

+1-1
Original file line numberDiff line numberDiff line change
@@ -649,7 +649,7 @@ Remove unreferenced images
649649
oadm prune images --keep-tag-revisions=3 --keep-younger-than=60m --confirm
650650
651651
# See, what the prune command would delete if we're interested in removing images
652-
# exceeding currently set LimitRanges ('openshift.io/Image')
652+
# exceeding currently set limit ranges ('openshift.io/Image')
653653
oadm prune images --prune-over-size-limit
654654
655655
# To actually perform the prune operation, the confirm flag must be appended

docs/generated/oc_by_example_content.adoc

+1-1
Original file line numberDiff line numberDiff line change
@@ -649,7 +649,7 @@ Remove unreferenced images
649649
oc adm prune images --keep-tag-revisions=3 --keep-younger-than=60m --confirm
650650
651651
# See, what the prune command would delete if we're interested in removing images
652-
# exceeding currently set LimitRanges ('openshift.io/Image')
652+
# exceeding currently set limit ranges ('openshift.io/Image')
653653
oc adm prune images --prune-over-size-limit
654654
655655
# To actually perform the prune operation, the confirm flag must be appended

docs/man/man1/oadm-prune-images.1

+9-2
Original file line numberDiff line numberDiff line change
@@ -13,7 +13,10 @@ oadm prune images \- Remove unreferenced images
1313

1414
.SH DESCRIPTION
1515
.PP
16-
Prune images no longer needed due to age and/or status
16+
Remove image stream tags, images, and image layers by age or usage
17+
18+
.PP
19+
This command removes historical image stream tags, unused images, and unreferenced image layers from the integrated registry. It prefers images that have been directly pushed to the registry, but you may specify \-\-all to include images that were imported (if registry mirroring is enabled).
1720

1821
.PP
1922
By default, the prune operation performs a dry run making no changes to internal registry. A \-\-confirm flag is needed for changes to be effective.
@@ -23,6 +26,10 @@ Only a user with a cluster role system:image\-pruner or higher who is logged\-in
2326

2427

2528
.SH OPTIONS
29+
.PP
30+
\fB\-\-all\fP=false
31+
Include images that were not pushed to the registry but have been mirrored by pullthrough. Requires \-\-registry\-url
32+
2633
.PP
2734
\fB\-\-certificate\-authority\fP=""
2835
The path to a certificate authority bundle to use when communicating with the managed Docker registries. Defaults to the certificate authority data from the current user's config file.
@@ -127,7 +134,7 @@ Only a user with a cluster role system:image\-pruner or higher who is logged\-in
127134
oadm prune images \-\-keep\-tag\-revisions=3 \-\-keep\-younger\-than=60m \-\-confirm
128135

129136
# See, what the prune command would delete if we're interested in removing images
130-
# exceeding currently set LimitRanges ('openshift.io/Image')
137+
# exceeding currently set limit ranges ('openshift.io/Image')
131138
oadm prune images \-\-prune\-over\-size\-limit
132139

133140
# To actually perform the prune operation, the confirm flag must be appended

docs/man/man1/oc-adm-prune-images.1

+9-2
Original file line numberDiff line numberDiff line change
@@ -13,7 +13,10 @@ oc adm prune images \- Remove unreferenced images
1313

1414
.SH DESCRIPTION
1515
.PP
16-
Prune images no longer needed due to age and/or status
16+
Remove image stream tags, images, and image layers by age or usage
17+
18+
.PP
19+
This command removes historical image stream tags, unused images, and unreferenced image layers from the integrated registry. It prefers images that have been directly pushed to the registry, but you may specify \-\-all to include images that were imported (if registry mirroring is enabled).
1720

1821
.PP
1922
By default, the prune operation performs a dry run making no changes to internal registry. A \-\-confirm flag is needed for changes to be effective.
@@ -23,6 +26,10 @@ Only a user with a cluster role system:image\-pruner or higher who is logged\-in
2326

2427

2528
.SH OPTIONS
29+
.PP
30+
\fB\-\-all\fP=false
31+
Include images that were not pushed to the registry but have been mirrored by pullthrough. Requires \-\-registry\-url
32+
2633
.PP
2734
\fB\-\-certificate\-authority\fP=""
2835
The path to a certificate authority bundle to use when communicating with the managed Docker registries. Defaults to the certificate authority data from the current user's config file.
@@ -127,7 +134,7 @@ Only a user with a cluster role system:image\-pruner or higher who is logged\-in
127134
oc adm prune images \-\-keep\-tag\-revisions=3 \-\-keep\-younger\-than=60m \-\-confirm
128135

129136
# See, what the prune command would delete if we're interested in removing images
130-
# exceeding currently set LimitRanges ('openshift.io/Image')
137+
# exceeding currently set limit ranges ('openshift.io/Image')
131138
oc adm prune images \-\-prune\-over\-size\-limit
132139

133140
# To actually perform the prune operation, the confirm flag must be appended

docs/man/man1/openshift-admin-prune-images.1

+9-2
Original file line numberDiff line numberDiff line change
@@ -13,7 +13,10 @@ openshift admin prune images \- Remove unreferenced images
1313

1414
.SH DESCRIPTION
1515
.PP
16-
Prune images no longer needed due to age and/or status
16+
Remove image stream tags, images, and image layers by age or usage
17+
18+
.PP
19+
This command removes historical image stream tags, unused images, and unreferenced image layers from the integrated registry. It prefers images that have been directly pushed to the registry, but you may specify \-\-all to include images that were imported (if registry mirroring is enabled).
1720

1821
.PP
1922
By default, the prune operation performs a dry run making no changes to internal registry. A \-\-confirm flag is needed for changes to be effective.
@@ -23,6 +26,10 @@ Only a user with a cluster role system:image\-pruner or higher who is logged\-in
2326

2427

2528
.SH OPTIONS
29+
.PP
30+
\fB\-\-all\fP=false
31+
Include images that were not pushed to the registry but have been mirrored by pullthrough. Requires \-\-registry\-url
32+
2633
.PP
2734
\fB\-\-certificate\-authority\fP=""
2835
The path to a certificate authority bundle to use when communicating with the managed Docker registries. Defaults to the certificate authority data from the current user's config file.
@@ -127,7 +134,7 @@ Only a user with a cluster role system:image\-pruner or higher who is logged\-in
127134
openshift admin prune images \-\-keep\-tag\-revisions=3 \-\-keep\-younger\-than=60m \-\-confirm
128135

129136
# See, what the prune command would delete if we're interested in removing images
130-
# exceeding currently set LimitRanges ('openshift.io/Image')
137+
# exceeding currently set limit ranges ('openshift.io/Image')
131138
openshift admin prune images \-\-prune\-over\-size\-limit
132139

133140
# To actually perform the prune operation, the confirm flag must be appended

docs/man/man1/openshift-cli-adm-prune-images.1

+9-2
Original file line numberDiff line numberDiff line change
@@ -13,7 +13,10 @@ openshift cli adm prune images \- Remove unreferenced images
1313

1414
.SH DESCRIPTION
1515
.PP
16-
Prune images no longer needed due to age and/or status
16+
Remove image stream tags, images, and image layers by age or usage
17+
18+
.PP
19+
This command removes historical image stream tags, unused images, and unreferenced image layers from the integrated registry. It prefers images that have been directly pushed to the registry, but you may specify \-\-all to include images that were imported (if registry mirroring is enabled).
1720

1821
.PP
1922
By default, the prune operation performs a dry run making no changes to internal registry. A \-\-confirm flag is needed for changes to be effective.
@@ -23,6 +26,10 @@ Only a user with a cluster role system:image\-pruner or higher who is logged\-in
2326

2427

2528
.SH OPTIONS
29+
.PP
30+
\fB\-\-all\fP=false
31+
Include images that were not pushed to the registry but have been mirrored by pullthrough. Requires \-\-registry\-url
32+
2633
.PP
2734
\fB\-\-certificate\-authority\fP=""
2835
The path to a certificate authority bundle to use when communicating with the managed Docker registries. Defaults to the certificate authority data from the current user's config file.
@@ -127,7 +134,7 @@ Only a user with a cluster role system:image\-pruner or higher who is logged\-in
127134
openshift cli adm prune images \-\-keep\-tag\-revisions=3 \-\-keep\-younger\-than=60m \-\-confirm
128135

129136
# See, what the prune command would delete if we're interested in removing images
130-
# exceeding currently set LimitRanges ('openshift.io/Image')
137+
# exceeding currently set limit ranges ('openshift.io/Image')
131138
openshift cli adm prune images \-\-prune\-over\-size\-limit
132139

133140
# To actually perform the prune operation, the confirm flag must be appended

images/dockerregistry/config.yml

+2-1
Original file line numberDiff line numberDiff line change
@@ -13,7 +13,7 @@ storage:
1313
auth:
1414
openshift:
1515
realm: openshift
16-
16+
1717
# tokenrealm is a base URL to use for the token-granting registry endpoint.
1818
# If unspecified, the scheme and host for the token redirect are determined from the incoming request.
1919
# If specified, a scheme and host must be chosen that all registry clients can resolve and access:
@@ -27,6 +27,7 @@ middleware:
2727
options:
2828
acceptschema2: false
2929
pullthrough: true
30+
mirrorpullthrough: true
3031
enforcequota: false
3132
projectcachettl: 1m
3233
blobrepositorycachettl: 10m

pkg/cmd/admin/prune/images.go

+17-2
Original file line numberDiff line numberDiff line change
@@ -34,7 +34,12 @@ const PruneImagesRecommendedName = "images"
3434

3535
var (
3636
imagesLongDesc = templates.LongDesc(`
37-
Prune images no longer needed due to age and/or status
37+
Remove image stream tags, images, and image layers by age or usage
38+
39+
This command removes historical image stream tags, unused images, and unreferenced image
40+
layers from the integrated registry. It prefers images that have been directly pushed to
41+
the registry, but you may specify --all to include images that were imported (if registry
42+
mirroring is enabled).
3843
3944
By default, the prune operation performs a dry run making no changes to internal registry. A
4045
--confirm flag is needed for changes to be effective.
@@ -51,7 +56,7 @@ var (
5156
%[1]s %[2]s --keep-tag-revisions=3 --keep-younger-than=60m --confirm
5257
5358
# See, what the prune command would delete if we're interested in removing images
54-
# exceeding currently set LimitRanges ('openshift.io/Image')
59+
# exceeding currently set limit ranges ('openshift.io/Image')
5560
%[1]s %[2]s --prune-over-size-limit
5661
5762
# To actually perform the prune operation, the confirm flag must be appended
@@ -70,6 +75,7 @@ type PruneImagesOptions struct {
7075
KeepYoungerThan *time.Duration
7176
KeepTagRevisions *int
7277
PruneOverSizeLimit *bool
78+
AllImages *bool
7379
CABundle string
7480
RegistryUrlOverride string
7581
Namespace string
@@ -82,11 +88,13 @@ type PruneImagesOptions struct {
8288

8389
// NewCmdPruneImages implements the OpenShift cli prune images command.
8490
func NewCmdPruneImages(f *clientcmd.Factory, parentName, name string, out io.Writer) *cobra.Command {
91+
allImages := false
8592
opts := &PruneImagesOptions{
8693
Confirm: false,
8794
KeepYoungerThan: &defaultKeepYoungerThan,
8895
KeepTagRevisions: &defaultKeepTagRevisions,
8996
PruneOverSizeLimit: &defaultPruneImageOverSizeLimit,
97+
AllImages: &allImages,
9098
}
9199

92100
cmd := &cobra.Command{
@@ -104,6 +112,7 @@ func NewCmdPruneImages(f *clientcmd.Factory, parentName, name string, out io.Wri
104112
}
105113

106114
cmd.Flags().BoolVar(&opts.Confirm, "confirm", opts.Confirm, "Specify that image pruning should proceed. Defaults to false, displaying what would be deleted but not actually deleting anything.")
115+
cmd.Flags().BoolVar(opts.AllImages, "all", *opts.AllImages, "Include images that were not pushed to the registry but have been mirrored by pullthrough. Requires --registry-url")
107116
cmd.Flags().DurationVar(opts.KeepYoungerThan, "keep-younger-than", *opts.KeepYoungerThan, "Specify the minimum age of an image for it to be considered a candidate for pruning.")
108117
cmd.Flags().IntVar(opts.KeepTagRevisions, "keep-tag-revisions", *opts.KeepTagRevisions, "Specify the number of image revisions for a tag in an image stream that will be preserved.")
109118
cmd.Flags().BoolVar(opts.PruneOverSizeLimit, "prune-over-size-limit", *opts.PruneOverSizeLimit, "Specify if images which are exceeding LimitRanges (see 'openshift.io/Image'), specified in the same namespace, should be considered for pruning. This flag cannot be combined with --keep-younger-than nor --keep-tag-revisions.")
@@ -130,6 +139,11 @@ func (o *PruneImagesOptions) Complete(f *clientcmd.Factory, cmd *cobra.Command,
130139
o.KeepTagRevisions = nil
131140
}
132141
}
142+
if *o.AllImages {
143+
if len(o.RegistryUrlOverride) == 0 {
144+
return kcmdutil.UsageError(cmd, "--registry-url must be specified when --all is true")
145+
}
146+
}
133147
o.Namespace = kapi.NamespaceAll
134148
if cmd.Flags().Lookup("namespace").Changed {
135149
var err error
@@ -228,6 +242,7 @@ func (o PruneImagesOptions) Run() error {
228242
KeepYoungerThan: o.KeepYoungerThan,
229243
KeepTagRevisions: o.KeepTagRevisions,
230244
PruneOverSizeLimit: o.PruneOverSizeLimit,
245+
AllImages: o.AllImages,
231246
Images: allImages,
232247
Streams: allStreams,
233248
Pods: allPods,

0 commit comments

Comments
 (0)