Merge pull request #7914 from shawnmssu/fix_ucloud_builder

UCloud Builder: update api about stop instance
This commit is contained in:
Megan Marsh 2019-07-26 11:37:36 -07:00 committed by GitHub
commit a99c0802be
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 49 additions and 9 deletions

View File

@ -30,7 +30,7 @@ func (s *stepCopyUCloudImage) Run(ctx context.Context, state multistep.StateBag)
srcImageId := state.Get("image_id").(string) srcImageId := state.Get("image_id").(string)
artifactImages := state.Get("ucloud_images").(*imageInfoSet) artifactImages := state.Get("ucloud_images").(*imageInfoSet)
expectedImages := newImageInfoSet(nil) expectedImages := newImageInfoSet(nil)
ui.Say(fmt.Sprintf("Copying image with %q...", srcImageId)) ui.Say(fmt.Sprintf("Copying images from %q...", srcImageId))
for _, v := range s.ImageDestinations { for _, v := range s.ImageDestinations {
if v.ProjectId == s.ProjectId && v.Region == s.RegionId { if v.ProjectId == s.ProjectId && v.Region == s.RegionId {
continue continue
@ -59,6 +59,7 @@ func (s *stepCopyUCloudImage) Run(ctx context.Context, state multistep.StateBag)
ui.Message(fmt.Sprintf("Copying image from %s:%s:%s to %s:%s:%s)", ui.Message(fmt.Sprintf("Copying image from %s:%s:%s to %s:%s:%s)",
s.ProjectId, s.RegionId, srcImageId, v.ProjectId, v.Region, resp.TargetImageId)) s.ProjectId, s.RegionId, srcImageId, v.ProjectId, v.Region, resp.TargetImageId))
} }
ui.Message("Waiting for the copied images to become available...")
err := retry.Config{ err := retry.Config{
Tries: 200, Tries: 200,

View File

@ -23,7 +23,7 @@ func (s *stepCreateImage) Run(ctx context.Context, state multistep.StateBag) mul
ui := state.Get("ui").(packer.Ui) ui := state.Get("ui").(packer.Ui)
config := state.Get("config").(*Config) config := state.Get("config").(*Config)
ui.Say(fmt.Sprintf("Creating image %s", config.ImageName)) ui.Say(fmt.Sprintf("Creating image %s...", config.ImageName))
req := conn.NewCreateCustomImageRequest() req := conn.NewCreateCustomImageRequest()
req.ImageName = ucloud.String(config.ImageName) req.ImageName = ucloud.String(config.ImageName)
@ -34,6 +34,7 @@ func (s *stepCreateImage) Run(ctx context.Context, state multistep.StateBag) mul
if err != nil { if err != nil {
return halt(state, err, "Error on creating image") return halt(state, err, "Error on creating image")
} }
ui.Message(fmt.Sprintf("Waiting for the created image %q to become available...", resp.ImageId))
err = retry.Config{ err = retry.Config{
Tries: 200, Tries: 200,

View File

@ -141,9 +141,9 @@ func (s *stepCreateInstance) Cleanup(state multistep.StateBag) {
} }
if instance.State != instanceStateStopped { if instance.State != instanceStateStopped {
stopReq := conn.NewPoweroffUHostInstanceRequest() stopReq := conn.NewStopUHostInstanceRequest()
stopReq.UHostId = ucloud.String(s.instanceId) stopReq.UHostId = ucloud.String(s.instanceId)
if _, err = conn.PoweroffUHostInstance(stopReq); err != nil { if _, err = conn.StopUHostInstance(stopReq); err != nil {
ui.Error(fmt.Sprintf("Error on stopping instance when deleting %q, %s", ui.Error(fmt.Sprintf("Error on stopping instance when deleting %q, %s",
s.instanceId, err.Error())) s.instanceId, err.Error()))
return return

View File

@ -27,7 +27,7 @@ func (s *stepStopInstance) Run(ctx context.Context, state multistep.StateBag) mu
} }
if instance.State != instanceStateStopped { if instance.State != instanceStateStopped {
stopReq := conn.NewPoweroffUHostInstanceRequest() stopReq := conn.NewStopUHostInstanceRequest()
stopReq.UHostId = ucloud.String(instance.UHostId) stopReq.UHostId = ucloud.String(instance.UHostId)
ui.Say(fmt.Sprintf("Stopping instance %q", instance.UHostId)) ui.Say(fmt.Sprintf("Stopping instance %q", instance.UHostId))
err = retry.Config{ err = retry.Config{
@ -37,7 +37,7 @@ func (s *stepStopInstance) Run(ctx context.Context, state multistep.StateBag) mu
}, },
RetryDelay: (&retry.Backoff{InitialBackoff: 2 * time.Second, MaxBackoff: 6 * time.Second, Multiplier: 2}).Linear, RetryDelay: (&retry.Backoff{InitialBackoff: 2 * time.Second, MaxBackoff: 6 * time.Second, Multiplier: 2}).Linear,
}.Run(ctx, func(ctx context.Context) error { }.Run(ctx, func(ctx context.Context) error {
if _, err = conn.PoweroffUHostInstance(stopReq); err != nil { if _, err = conn.StopUHostInstance(stopReq); err != nil {
return err return err
} }
return nil return nil

View File

@ -26,7 +26,7 @@ In addition to the options listed here, a
[communicator](../templates/communicator.html) can be configured for this [communicator](../templates/communicator.html) can be configured for this
builder. builder.
\~&gt; **Note:** The bulider doesn't support Windows images for now and only supports CentoOS and ubuntu images via SSH anthentication with `ssh_username` (Required) and `ssh_password` (Optional). The `ssh_username` must be `root` for CentOS images and `ubuntu` for Ubuntu images. The `ssh_password` may contain 8-30 characters, and must be consisted with at least 2 items out of the capital letters, lower case letters, numbers and special characters. The special characters include <code>`()~!@#$%^&*-+=_|{}\[]:;'<>,.?/</code>. \~&gt; **Note:** The bulider doesn't support Windows images for now and only supports CentOS and Ubuntu images via SSH anthentication with `ssh_username` (Required) and `ssh_password` (Optional). The `ssh_username` must be `root` for CentOS images and `ubuntu` for Ubuntu images. The `ssh_password` may contain 8-30 characters, and must consist of at least 2 items out of the capital letters, lower case letters, numbers and special characters. The special characters include <code>`()~!@#$%^&*-+=_|{}\[]:;'<>,.?/</code>.
### Required: ### Required:
@ -84,9 +84,9 @@ builder.
- `description` (number) - The copied image description. - `description` (number) - The copied image description.
## Basic Example ## Examples
Here is a basic example for build UCloud image. Here is a basic example for build UCloud CentOS image:
``` json ``` json
{ {
@ -95,6 +95,7 @@ Here is a basic example for build UCloud image.
"ucloud_private_key": "{{env `UCLOUD_PRIVATE_KEY`}}", "ucloud_private_key": "{{env `UCLOUD_PRIVATE_KEY`}}",
"ucloud_project_id": "{{env `UCLOUD_PROJECT_ID`}}" "ucloud_project_id": "{{env `UCLOUD_PROJECT_ID`}}"
}, },
"builders": [{ "builders": [{
"type":"ucloud-uhost", "type":"ucloud-uhost",
"public_key":"{{user `ucloud_public_key`}}", "public_key":"{{user `ucloud_public_key`}}",
@ -110,6 +111,43 @@ Here is a basic example for build UCloud image.
} }
``` ```
Here is a example for build UCloud Ubuntu image:
``` json
{
"variables": {
"ucloud_public_key": "{{env `UCLOUD_PUBLIC_KEY`}}",
"ucloud_private_key": "{{env `UCLOUD_PRIVATE_KEY`}}",
"ucloud_project_id": "{{env `UCLOUD_PROJECT_ID`}}",
"password": "ucloud_2019"
},
"builders": [{
"type": "ucloud-uhost",
"public_key": "{{user `ucloud_public_key`}}",
"private_key": "{{user `ucloud_private_key`}}",
"project_id": "{{user `ucloud_project_id`}}",
"region": "cn-bj2",
"availability_zone": "cn-bj2-02",
"instance_type": "n-basic-2",
"source_image_id": "uimage-irofn4",
"ssh_password": "{{user `password`}}",
"ssh_username": "ubuntu",
"image_name": "packer-test-ubuntu-bj"
}],
"provisioners": [{
"type": "shell",
"execute_command": "echo '{{user `password`}}' | sudo -S '{{.Path}}'",
"inline": [
"sleep 30",
"sudo apt update",
"sudo apt install nginx -y"
]
}]
}
```
-&gt; **Note:** Packer can also read the public key and private key from -&gt; **Note:** Packer can also read the public key and private key from
environmental variables. See the configuration reference in the section above environmental variables. See the configuration reference in the section above
for more information on what environmental variables Packer will look for. for more information on what environmental variables Packer will look for.