mirror of https://github.com/kubernetes/kops.git
Clean up "kops delete -f"
This commit is contained in:
parent
5095ae93fd
commit
c864dc02ca
|
|
@ -30,7 +30,6 @@ import (
|
||||||
"k8s.io/kops/pkg/sshcredentials"
|
"k8s.io/kops/pkg/sshcredentials"
|
||||||
"k8s.io/kops/util/pkg/text"
|
"k8s.io/kops/util/pkg/text"
|
||||||
"k8s.io/kops/util/pkg/vfs"
|
"k8s.io/kops/util/pkg/vfs"
|
||||||
cmdutil "k8s.io/kubectl/pkg/cmd/util"
|
|
||||||
"k8s.io/kubectl/pkg/util/i18n"
|
"k8s.io/kubectl/pkg/util/i18n"
|
||||||
"k8s.io/kubectl/pkg/util/templates"
|
"k8s.io/kubectl/pkg/util/templates"
|
||||||
)
|
)
|
||||||
|
|
@ -41,59 +40,40 @@ type DeleteOptions struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
var (
|
var (
|
||||||
deleteLong = templates.LongDesc(i18n.T(`
|
|
||||||
Delete Kubernetes clusters, instancegroups, instances, and secrets, or a combination of the before mentioned.
|
|
||||||
`))
|
|
||||||
|
|
||||||
deleteExample = templates.Examples(i18n.T(`
|
deleteExample = templates.Examples(i18n.T(`
|
||||||
# Delete an instance
|
|
||||||
kops delete instance i-0a5ed581b862d3425
|
|
||||||
|
|
||||||
# Delete a cluster using a manifest file
|
# Delete a cluster using a manifest file
|
||||||
kops delete -f my-cluster.yaml
|
kops delete -f my-cluster.yaml
|
||||||
|
|
||||||
# Delete a cluster using a pasted manifest file from stdin.
|
# Delete a cluster using a pasted manifest file from stdin.
|
||||||
pbpaste | kops delete -f -
|
pbpaste | kops delete -f -
|
||||||
|
|
||||||
# Delete a cluster in AWS.
|
|
||||||
kops delete cluster --name=k8s.example.com --state=s3://my-state-store
|
|
||||||
|
|
||||||
# Delete an instancegroup for the k8s-cluster.example.com cluster.
|
|
||||||
# The --yes option runs the command immediately.
|
|
||||||
kops delete ig --name=k8s-cluster.example.com node-example --yes
|
|
||||||
`))
|
`))
|
||||||
|
|
||||||
deleteShort = i18n.T("Delete clusters, instancegroups, instances, or secrets.")
|
deleteShort = i18n.T("Delete clusters, instancegroups, instances, and secrets.")
|
||||||
)
|
)
|
||||||
|
|
||||||
func NewCmdDelete(f *util.Factory, out io.Writer) *cobra.Command {
|
func NewCmdDelete(f *util.Factory, out io.Writer) *cobra.Command {
|
||||||
options := &DeleteOptions{}
|
options := &DeleteOptions{}
|
||||||
|
|
||||||
cmd := &cobra.Command{
|
cmd := &cobra.Command{
|
||||||
Use: "delete -f FILENAME [--yes]",
|
Use: "delete {-f FILENAME}...",
|
||||||
Short: deleteShort,
|
Short: deleteShort,
|
||||||
Long: deleteLong,
|
|
||||||
Example: deleteExample,
|
Example: deleteExample,
|
||||||
SuggestFor: []string{"rm"},
|
SuggestFor: []string{"rm"},
|
||||||
Run: func(cmd *cobra.Command, args []string) {
|
Args: cobra.NoArgs,
|
||||||
ctx := context.TODO()
|
RunE: func(cmd *cobra.Command, args []string) error {
|
||||||
if len(options.Filenames) == 0 {
|
return RunDelete(context.TODO(), f, out, options)
|
||||||
cmd.Help()
|
|
||||||
return
|
|
||||||
}
|
|
||||||
cmdutil.CheckErr(RunDelete(ctx, f, out, options))
|
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
cmd.Flags().StringSliceVarP(&options.Filenames, "filename", "f", options.Filenames, "Filename to use to delete the resource")
|
cmd.Flags().StringSliceVarP(&options.Filenames, "filename", "f", options.Filenames, "Filename to use to delete the resource")
|
||||||
cmd.Flags().BoolVarP(&options.Yes, "yes", "y", options.Yes, "Specify --yes to delete the resource")
|
cmd.Flags().BoolVarP(&options.Yes, "yes", "y", options.Yes, "Specify --yes to immediately delete the resource")
|
||||||
cmd.MarkFlagRequired("filename")
|
cmd.MarkFlagRequired("filename")
|
||||||
|
|
||||||
// create subcommands
|
// create subcommands
|
||||||
cmd.AddCommand(NewCmdDeleteCluster(f, out))
|
cmd.AddCommand(NewCmdDeleteCluster(f, out))
|
||||||
|
cmd.AddCommand(NewCmdDeleteInstance(f, out))
|
||||||
cmd.AddCommand(NewCmdDeleteInstanceGroup(f, out))
|
cmd.AddCommand(NewCmdDeleteInstanceGroup(f, out))
|
||||||
cmd.AddCommand(NewCmdDeleteSecret(f, out))
|
cmd.AddCommand(NewCmdDeleteSecret(f, out))
|
||||||
cmd.AddCommand(NewCmdDeleteInstance(f, out))
|
|
||||||
|
|
||||||
return cmd
|
return cmd
|
||||||
}
|
}
|
||||||
|
|
@ -108,12 +88,12 @@ func RunDelete(ctx context.Context, factory *util.Factory, out io.Writer, d *Del
|
||||||
if f == "-" {
|
if f == "-" {
|
||||||
contents, err = ConsumeStdin()
|
contents, err = ConsumeStdin()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("error reading from stdin: %v", err)
|
return fmt.Errorf("reading from stdin: %v", err)
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
contents, err = vfs.Context.ReadFile(f)
|
contents, err = vfs.Context.ReadFile(f)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("error reading file %q: %v", f, err)
|
return fmt.Errorf("reading file %q: %v", f, err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -121,7 +101,7 @@ func RunDelete(ctx context.Context, factory *util.Factory, out io.Writer, d *Del
|
||||||
for _, section := range sections {
|
for _, section := range sections {
|
||||||
o, gvk, err := kopscodecs.Decode(section, nil)
|
o, gvk, err := kopscodecs.Decode(section, nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("error parsing file %q: %v", f, err)
|
return fmt.Errorf("parsing file %q: %v", f, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
switch v := o.(type) {
|
switch v := o.(type) {
|
||||||
|
|
@ -132,7 +112,7 @@ func RunDelete(ctx context.Context, factory *util.Factory, out io.Writer, d *Del
|
||||||
}
|
}
|
||||||
err = RunDeleteCluster(ctx, factory, out, options)
|
err = RunDeleteCluster(ctx, factory, out, options)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
exitWithError(err)
|
return err
|
||||||
}
|
}
|
||||||
deletedClusters.Insert(v.ObjectMeta.Name)
|
deletedClusters.Insert(v.ObjectMeta.Name)
|
||||||
case *kopsapi.InstanceGroup:
|
case *kopsapi.InstanceGroup:
|
||||||
|
|
@ -150,7 +130,7 @@ func RunDelete(ctx context.Context, factory *util.Factory, out io.Writer, d *Del
|
||||||
|
|
||||||
err := RunDeleteInstanceGroup(ctx, factory, out, options)
|
err := RunDeleteInstanceGroup(ctx, factory, out, options)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
exitWithError(err)
|
return err
|
||||||
}
|
}
|
||||||
case *kopsapi.SSHCredential:
|
case *kopsapi.SSHCredential:
|
||||||
fingerprint, err := sshcredentials.Fingerprint(v.Spec.PublicKey)
|
fingerprint, err := sshcredentials.Fingerprint(v.Spec.PublicKey)
|
||||||
|
|
@ -167,11 +147,11 @@ func RunDelete(ctx context.Context, factory *util.Factory, out io.Writer, d *Del
|
||||||
|
|
||||||
err = RunDeleteSecret(ctx, factory, out, options)
|
err = RunDeleteSecret(ctx, factory, out, options)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
exitWithError(err)
|
return err
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
klog.V(2).Infof("Type of object was %T", v)
|
klog.V(2).Infof("Type of object was %T", v)
|
||||||
return fmt.Errorf("Unhandled kind %q in %s", gvk, f)
|
return fmt.Errorf("unhandled kind %q in %s", gvk, f)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -39,7 +39,7 @@ kOps is Kubernetes Operations.
|
||||||
|
|
||||||
* [kops completion](kops_completion.md) - generate the autocompletion script for the specified shell
|
* [kops completion](kops_completion.md) - generate the autocompletion script for the specified shell
|
||||||
* [kops create](kops_create.md) - Create a resource by command line, filename or stdin.
|
* [kops create](kops_create.md) - Create a resource by command line, filename or stdin.
|
||||||
* [kops delete](kops_delete.md) - Delete clusters, instancegroups, instances, or secrets.
|
* [kops delete](kops_delete.md) - Delete clusters, instancegroups, instances, and secrets.
|
||||||
* [kops describe](kops_describe.md) - Describe a resource.
|
* [kops describe](kops_describe.md) - Describe a resource.
|
||||||
* [kops distrust](kops_distrust.md) - Distrust keypairs.
|
* [kops distrust](kops_distrust.md) - Distrust keypairs.
|
||||||
* [kops edit](kops_edit.md) - Edit clusters and other resources.
|
* [kops edit](kops_edit.md) - Edit clusters and other resources.
|
||||||
|
|
|
||||||
|
|
@ -3,34 +3,20 @@
|
||||||
|
|
||||||
## kops delete
|
## kops delete
|
||||||
|
|
||||||
Delete clusters, instancegroups, instances, or secrets.
|
Delete clusters, instancegroups, instances, and secrets.
|
||||||
|
|
||||||
### Synopsis
|
|
||||||
|
|
||||||
Delete Kubernetes clusters, instancegroups, instances, and secrets, or a combination of the before mentioned.
|
|
||||||
|
|
||||||
```
|
```
|
||||||
kops delete -f FILENAME [--yes] [flags]
|
kops delete {-f FILENAME}... [flags]
|
||||||
```
|
```
|
||||||
|
|
||||||
### Examples
|
### Examples
|
||||||
|
|
||||||
```
|
```
|
||||||
# Delete an instance
|
|
||||||
kops delete instance i-0a5ed581b862d3425
|
|
||||||
|
|
||||||
# Delete a cluster using a manifest file
|
# Delete a cluster using a manifest file
|
||||||
kops delete -f my-cluster.yaml
|
kops delete -f my-cluster.yaml
|
||||||
|
|
||||||
# Delete a cluster using a pasted manifest file from stdin.
|
# Delete a cluster using a pasted manifest file from stdin.
|
||||||
pbpaste | kops delete -f -
|
pbpaste | kops delete -f -
|
||||||
|
|
||||||
# Delete a cluster in AWS.
|
|
||||||
kops delete cluster --name=k8s.example.com --state=s3://my-state-store
|
|
||||||
|
|
||||||
# Delete an instancegroup for the k8s-cluster.example.com cluster.
|
|
||||||
# The --yes option runs the command immediately.
|
|
||||||
kops delete ig --name=k8s-cluster.example.com node-example --yes
|
|
||||||
```
|
```
|
||||||
|
|
||||||
### Options
|
### Options
|
||||||
|
|
@ -38,7 +24,7 @@ kops delete -f FILENAME [--yes] [flags]
|
||||||
```
|
```
|
||||||
-f, --filename strings Filename to use to delete the resource
|
-f, --filename strings Filename to use to delete the resource
|
||||||
-h, --help help for delete
|
-h, --help help for delete
|
||||||
-y, --yes Specify --yes to delete the resource
|
-y, --yes Specify --yes to immediately delete the resource
|
||||||
```
|
```
|
||||||
|
|
||||||
### Options inherited from parent commands
|
### Options inherited from parent commands
|
||||||
|
|
|
||||||
|
|
@ -54,5 +54,5 @@ kops delete cluster CLUSTERNAME [--yes] [flags]
|
||||||
|
|
||||||
### SEE ALSO
|
### SEE ALSO
|
||||||
|
|
||||||
* [kops delete](kops_delete.md) - Delete clusters, instancegroups, instances, or secrets.
|
* [kops delete](kops_delete.md) - Delete clusters, instancegroups, instances, and secrets.
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -64,5 +64,5 @@ kops delete instance [flags]
|
||||||
|
|
||||||
### SEE ALSO
|
### SEE ALSO
|
||||||
|
|
||||||
* [kops delete](kops_delete.md) - Delete clusters, instancegroups, instances, or secrets.
|
* [kops delete](kops_delete.md) - Delete clusters, instancegroups, instances, and secrets.
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -52,5 +52,5 @@ kops delete instancegroup [flags]
|
||||||
|
|
||||||
### SEE ALSO
|
### SEE ALSO
|
||||||
|
|
||||||
* [kops delete](kops_delete.md) - Delete clusters, instancegroups, instances, or secrets.
|
* [kops delete](kops_delete.md) - Delete clusters, instancegroups, instances, and secrets.
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -50,5 +50,5 @@ kops delete secret [flags]
|
||||||
|
|
||||||
### SEE ALSO
|
### SEE ALSO
|
||||||
|
|
||||||
* [kops delete](kops_delete.md) - Delete clusters, instancegroups, instances, or secrets.
|
* [kops delete](kops_delete.md) - Delete clusters, instancegroups, instances, and secrets.
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue