KEMBAR78
Add a retry logic to docker login operation by enescakir · Pull Request #3089 · actions/runner · GitHub
Skip to content

Conversation

enescakir
Copy link
Contributor

While there's an existing retry mechanism for the docker pull command 1, it's missing for docker login.

Similar to the docker pull scenario, the container registry could potentially be briefly unavailable or inaccessible, leading to failed docker login attempt and subsequent workflow run failures.

Since it's container based workflow, there is not way to retry on customer side. The runner should retry itself.

It also aligns with community feedback 2.

Footnotes

  1. https://github.com/actions/runner/blob/8e0cd36cd8c74c3067ffe10189c1e42f7e753af2/src/Runner.Worker/ContainerOperationProvider.cs#L201

  2. https://github.com/orgs/community/discussions/73069

@enescakir enescakir requested a review from a team as a code owner January 16, 2024 14:11
@igwejk
Copy link

igwejk commented Feb 14, 2024

Hi @enescakir, this probably fell through the crack. I'm doing something about getting attention to it.

While there's an existing retry mechanism for the `docker pull` command
[^1], it's missing for `docker login`.

Similar to the `docker pull` scenario, the container registry could
potentially be briefly unavailable or inaccessible, leading to failed
`docker login` attempt and subsequent workflow run failures.

Since it's container based workflow, there is not way to retry on
customer side. The runner should retry itself.

It also aligns with community feedback [^2].

[^1]: https://github.com/actions/runner/blob/8e0cd36cd8c74c3067ffe10189c1e42f7e753af2/src/Runner.Worker/ContainerOperationProvider.cs#L201
[^2]: https://github.com/orgs/community/discussions/73069
@enescakir
Copy link
Contributor Author

enescakir commented Feb 20, 2024

Hi @enescakir, this probably fell through the crack. I'm doing something about getting attention to it.

@igwejk It seems that contributors primarily review each other's pull requests. Pull requests from the community don't receive much attention. What can I do to gain more visibility?

Copy link
Contributor

@nikola-jokic nikola-jokic left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@igwejk
Copy link

igwejk commented Feb 20, 2024

@enescakir quite visible now 🙂

@igwejk
Copy link

igwejk commented Feb 20, 2024

@nikola-jokic shall we merge this PR already?

Copy link
Collaborator

@thboop thboop left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

lgtm

@thboop
Copy link
Collaborator

thboop commented Feb 21, 2024

Thanks for the contribution @enescakir, I'm going to go ahead and merge this pr, it should roll out with the next runner release, which should be within the next couple weeks

@thboop thboop enabled auto-merge (squash) February 21, 2024 17:28
@thboop thboop merged commit 6603bfb into actions:main Feb 21, 2024
@enescakir enescakir deleted the retry-docker-login branch February 21, 2024 18:14
lumiere-bot bot referenced this pull request in coolguy1771/home-ops Feb 27, 2024
…314.0 ) (#4273)

This PR contains the following updates:

| Package | Update | Change |
|---|---|---|
|
[ghcr.io/onedr0p/actions-runner](https://ghcr.io/onedr0p/actions-runner)
([source](https://togithub.com/actions/runner)) | minor | `2.313.0` ->
`2.314.0` |

---

> [!WARNING]
> Some dependencies could not be looked up. Check the Dependency
Dashboard for more information.

---

### Release Notes

<details>
<summary>actions/runner (ghcr.io/onedr0p/actions-runner)</summary>

###
[`v2.314.0`](https://togithub.com/actions/runner/releases/tag/v2.314.0)

[Compare
Source](https://togithub.com/actions/runner/compare/v2.313.0...v2.314.0)

##### What's Changed

- Prepare v2.313.0 Release by
[@&#8203;luketomlinson](https://togithub.com/luketomlinson) in
[https://github.com/actions/runner/pull/3137](https://togithub.com/actions/runner/pull/3137)
- Pass RunnerOS during job acquire. by
[@&#8203;TingluoHuang](https://togithub.com/TingluoHuang) in
[https://github.com/actions/runner/pull/3140](https://togithub.com/actions/runner/pull/3140)
- Process `snapshot` tokens by
[@&#8203;davidomid](https://togithub.com/davidomid) in
[https://github.com/actions/runner/pull/3135](https://togithub.com/actions/runner/pull/3135)
- Update dotnet sdk to latest version
[@&#8203;6](https://togithub.com/6).0.419 by
[@&#8203;github-actions](https://togithub.com/github-actions) in
[https://github.com/actions/runner/pull/3158](https://togithub.com/actions/runner/pull/3158)
- handle broker run service exception handling by
[@&#8203;yaananth](https://togithub.com/yaananth) in
[https://github.com/actions/runner/pull/3163](https://togithub.com/actions/runner/pull/3163)
- Add a retry logic to docker login operation by
[@&#8203;enescakir](https://togithub.com/enescakir) in
[https://github.com/actions/runner/pull/3089](https://togithub.com/actions/runner/pull/3089)
- Broker fixes for token refreshes and AccessDeniedException by
[@&#8203;luketomlinson](https://togithub.com/luketomlinson) in
[https://github.com/actions/runner/pull/3161](https://togithub.com/actions/runner/pull/3161)
- Remove USE_BROKER_FLOW by
[@&#8203;luketomlinson](https://togithub.com/luketomlinson) in
[https://github.com/actions/runner/pull/3162](https://togithub.com/actions/runner/pull/3162)
- Refresh Token for BrokerServer by
[@&#8203;luketomlinson](https://togithub.com/luketomlinson) in
[https://github.com/actions/runner/pull/3167](https://togithub.com/actions/runner/pull/3167)
- Better step timeout message. by
[@&#8203;TingluoHuang](https://togithub.com/TingluoHuang) in
[https://github.com/actions/runner/pull/3166](https://togithub.com/actions/runner/pull/3166)

##### New Contributors

- [@&#8203;davidomid](https://togithub.com/davidomid) made their first
contribution in
[https://github.com/actions/runner/pull/3135](https://togithub.com/actions/runner/pull/3135)
- [@&#8203;enescakir](https://togithub.com/enescakir) made their first
contribution in
[https://github.com/actions/runner/pull/3089](https://togithub.com/actions/runner/pull/3089)

**Full Changelog**:
actions/runner@v2.313.0...v2.314.0

*Note: Actions Runner follows a progressive release policy, so the
latest release might not be available to your enterprise, organization,
or repository yet.
To confirm which version of the Actions Runner you should expect, please
view the download instructions for your enterprise, organization, or
repository.
See
https://docs.github.com/en/enterprise-cloud@latest/actions/hosting-your-own-runners/adding-self-hosted-runners*

##### Windows x64

We recommend configuring the runner in a root folder of the Windows
drive (e.g. "C:\actions-runner"). This will help avoid issues related to
service identity folder permissions and long file path restrictions on
Windows.

The following snipped needs to be run on `powershell`:

```powershell

##### Create a folder under the drive root
mkdir \actions-runner ; cd \actions-runner

##### Download the latest runner package
Invoke-WebRequest -Uri https://github.com/actions/runner/releases/download/v2.314.0/actions-runner-win-x64-2.314.0.zip -OutFile actions-runner-win-x64-2.314.0.zip

##### Extract the installer
Add-Type -AssemblyName System.IO.Compression.FileSystem ;
[System.IO.Compression.ZipFile]::ExtractToDirectory("$PWD\actions-runner-win-x64-2.314.0.zip", "$PWD")
```

##### \[Pre-release] Windows arm64

**Warning:** Windows arm64 runners are currently in preview status and
use [unofficial versions of
nodejs](https://unofficial-builds.nodejs.org/). They are not intended
for production workflows.

We recommend configuring the runner in a root folder of the Windows
drive (e.g. "C:\actions-runner"). This will help avoid issues related to
service identity folder permissions and long file path restrictions on
Windows.

The following snipped needs to be run on `powershell`:

```powershell

##### Create a folder under the drive root
mkdir \actions-runner ; cd \actions-runner

##### Download the latest runner package
Invoke-WebRequest -Uri https://github.com/actions/runner/releases/download/v2.314.0/actions-runner-win-arm64-2.314.0.zip -OutFile actions-runner-win-arm64-2.314.0.zip

##### Extract the installer
Add-Type -AssemblyName System.IO.Compression.FileSystem ;
[System.IO.Compression.ZipFile]::ExtractToDirectory("$PWD\actions-runner-win-arm64-2.314.0.zip", "$PWD")
```

##### OSX x64

```bash

##### Create a folder
mkdir actions-runner && cd actions-runner

##### Download the latest runner package
curl -O -L https://github.com/actions/runner/releases/download/v2.314.0/actions-runner-osx-x64-2.314.0.tar.gz

##### Extract the installer
tar xzf ./actions-runner-osx-x64-2.314.0.tar.gz
```

##### OSX arm64 (Apple silicon)

```bash

##### Create a folder
mkdir actions-runner && cd actions-runner

##### Download the latest runner package
curl -O -L https://github.com/actions/runner/releases/download/v2.314.0/actions-runner-osx-arm64-2.314.0.tar.gz

##### Extract the installer
tar xzf ./actions-runner-osx-arm64-2.314.0.tar.gz
```

##### Linux x64

```bash

##### Create a folder
mkdir actions-runner && cd actions-runner

##### Download the latest runner package
curl -O -L https://github.com/actions/runner/releases/download/v2.314.0/actions-runner-linux-x64-2.314.0.tar.gz

##### Extract the installer
tar xzf ./actions-runner-linux-x64-2.314.0.tar.gz
```

##### Linux arm64

```bash

##### Create a folder
mkdir actions-runner && cd actions-runner

##### Download the latest runner package
curl -O -L https://github.com/actions/runner/releases/download/v2.314.0/actions-runner-linux-arm64-2.314.0.tar.gz

##### Extract the installer
tar xzf ./actions-runner-linux-arm64-2.314.0.tar.gz
```

##### Linux arm

```bash

##### Create a folder
mkdir actions-runner && cd actions-runner

##### Download the latest runner package
curl -O -L https://github.com/actions/runner/releases/download/v2.314.0/actions-runner-linux-arm-2.314.0.tar.gz

##### Extract the installer
tar xzf ./actions-runner-linux-arm-2.314.0.tar.gz
```

##### Using your self hosted runner

For additional details about configuring, running, or shutting down the
runner please check out our [product
docs.](https://help.github.com/en/actions/automating-your-workflow-with-github-actions/adding-self-hosted-runners)

##### SHA-256 Checksums

The SHA-256 checksums for the packages included in this build are shown
below:

- actions-runner-win-x64-2.314.0.zip <!-- BEGIN SHA win-x64
-->70737a3df30ff9bc0b395a0331309aba59da760eb50da4ea2ff5cb768fa7f6e4<!--
END SHA win-x64 -->
- actions-runner-win-arm64-2.314.0.zip <!-- BEGIN SHA win-arm64
-->e4677bbd8fa0a4fcab0491e6865cbd5cb0597eba0690ab8f5b097a15ef8d4554<!--
END SHA win-arm64 -->
- actions-runner-osx-x64-2.314.0.tar.gz <!-- BEGIN SHA osx-x64
-->5d928a482572e84f6c823a5f340e7fddec612cfad108908f4e4ea30cf58e370c<!--
END SHA osx-x64 -->
- actions-runner-osx-arm64-2.314.0.tar.gz <!-- BEGIN SHA osx-arm64
-->4a24368657a5a994e8c4d2c0e4b304005e6b093ebd3081dd03e5e9436ba52b9e<!--
END SHA osx-arm64 -->
- actions-runner-linux-x64-2.314.0.tar.gz <!-- BEGIN SHA linux-x64
-->82ac833f291f0f6b9b546f501043cab1ddb01935281403f435e78ee81a447756<!--
END SHA linux-x64 -->
- actions-runner-linux-arm64-2.314.0.tar.gz <!-- BEGIN SHA linux-arm64
-->cc9d28a9e7b6e9e37dea74ce55f5c314724e7f81225b8e3b0d3eaf1f27a90171<!--
END SHA linux-arm64 -->
- actions-runner-linux-arm-2.314.0.tar.gz <!-- BEGIN SHA linux-arm
-->a90fbc2d0bcce91be2d3d112cffde0c363b33ef9a807c05f238bcd5b75fa26a7<!--
END SHA linux-arm -->

</details>

---

### Configuration

📅 **Schedule**: Branch creation - At any time (no schedule defined),
Automerge - At any time (no schedule defined).

🚦 **Automerge**: Disabled by config. Please merge this manually once you
are satisfied.

♻ **Rebasing**: Whenever PR becomes conflicted, or you tick the
rebase/retry checkbox.

🔕 **Ignore**: Close this PR and you won't be reminded about these
updates again.

---

- [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check
this box

---

This PR has been generated by [Renovate
Bot](https://togithub.com/renovatebot/renovate).

<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiIzNy4yMTQuMSIsInVwZGF0ZWRJblZlciI6IjM3LjIxNC4xIiwidGFyZ2V0QnJhbmNoIjoibWFpbiJ9-->

Co-authored-by: lumiere-bot[bot] <98047013+lumiere-bot[bot]@users.noreply.github.com>
lumiere-bot bot referenced this pull request in coolguy1771/home-ops Mar 3, 2024
…14.1 ) (#4287)

This PR contains the following updates:

| Package | Update | Change |
|---|---|---|
|
[ghcr.io/onedr0p/actions-runner](https://ghcr.io/onedr0p/actions-runner)
([source](https://togithub.com/actions/runner)) | patch | `2.314.0` ->
`2.314.1` |

---

> [!WARNING]
> Some dependencies could not be looked up. Check the Dependency
Dashboard for more information.

---

### Release Notes

<details>
<summary>actions/runner (ghcr.io/onedr0p/actions-runner)</summary>

###
[`v2.314.1`](https://togithub.com/actions/runner/releases/tag/v2.314.1)

[Compare
Source](https://togithub.com/actions/runner/compare/v2.314.0...v2.314.1)

##### What's Changed

- Prepare v2.313.0 Release by
[@&#8203;luketomlinson](https://togithub.com/luketomlinson) in
[https://github.com/actions/runner/pull/3137](https://togithub.com/actions/runner/pull/3137)
- Pass RunnerOS during job acquire. by
[@&#8203;TingluoHuang](https://togithub.com/TingluoHuang) in
[https://github.com/actions/runner/pull/3140](https://togithub.com/actions/runner/pull/3140)
- Process `snapshot` tokens by
[@&#8203;davidomid](https://togithub.com/davidomid) in
[https://github.com/actions/runner/pull/3135](https://togithub.com/actions/runner/pull/3135)
- Update dotnet sdk to latest version
[@&#8203;6](https://togithub.com/6).0.419 by
[@&#8203;github-actions](https://togithub.com/github-actions) in
[https://github.com/actions/runner/pull/3158](https://togithub.com/actions/runner/pull/3158)
- handle broker run service exception handling by
[@&#8203;yaananth](https://togithub.com/yaananth) in
[https://github.com/actions/runner/pull/3163](https://togithub.com/actions/runner/pull/3163)
- Add a retry logic to docker login operation by
[@&#8203;enescakir](https://togithub.com/enescakir) in
[https://github.com/actions/runner/pull/3089](https://togithub.com/actions/runner/pull/3089)
- Broker fixes for token refreshes and AccessDeniedException by
[@&#8203;luketomlinson](https://togithub.com/luketomlinson) in
[https://github.com/actions/runner/pull/3161](https://togithub.com/actions/runner/pull/3161)
- Remove USE_BROKER_FLOW by
[@&#8203;luketomlinson](https://togithub.com/luketomlinson) in
[https://github.com/actions/runner/pull/3162](https://togithub.com/actions/runner/pull/3162)
- Refresh Token for BrokerServer by
[@&#8203;luketomlinson](https://togithub.com/luketomlinson) in
[https://github.com/actions/runner/pull/3167](https://togithub.com/actions/runner/pull/3167)
- Better step timeout message. by
[@&#8203;TingluoHuang](https://togithub.com/TingluoHuang) in
[https://github.com/actions/runner/pull/3166](https://togithub.com/actions/runner/pull/3166)
- Fix summaries for actions results by
[@&#8203;SrRyan](https://togithub.com/SrRyan) in
[https://github.com/actions/runner/pull/3174](https://togithub.com/actions/runner/pull/3174)

##### New Contributors

- [@&#8203;davidomid](https://togithub.com/davidomid) made their first
contribution in
[https://github.com/actions/runner/pull/3135](https://togithub.com/actions/runner/pull/3135)
- [@&#8203;enescakir](https://togithub.com/enescakir) made their first
contribution in
[https://github.com/actions/runner/pull/3089](https://togithub.com/actions/runner/pull/3089)
- [@&#8203;SrRyan](https://togithub.com/SrRyan) made their first
contribution in
[https://github.com/actions/runner/pull/3174](https://togithub.com/actions/runner/pull/3174)

**Full Changelog**:
actions/runner@v2.313.0...v2.314.0

*Note: Actions Runner follows a progressive release policy, so the
latest release might not be available to your enterprise, organization,
or repository yet.
To confirm which version of the Actions Runner you should expect, please
view the download instructions for your enterprise, organization, or
repository.
See
https://docs.github.com/en/enterprise-cloud@latest/actions/hosting-your-own-runners/adding-self-hosted-runners*

##### Windows x64

We recommend configuring the runner in a root folder of the Windows
drive (e.g. "C:\actions-runner"). This will help avoid issues related to
service identity folder permissions and long file path restrictions on
Windows.

The following snipped needs to be run on `powershell`:

```powershell

##### Create a folder under the drive root
mkdir \actions-runner ; cd \actions-runner

##### Download the latest runner package
Invoke-WebRequest -Uri https://github.com/actions/runner/releases/download/v2.314.1/actions-runner-win-x64-2.314.1.zip -OutFile actions-runner-win-x64-2.314.1.zip

##### Extract the installer
Add-Type -AssemblyName System.IO.Compression.FileSystem ;
[System.IO.Compression.ZipFile]::ExtractToDirectory("$PWD\actions-runner-win-x64-2.314.1.zip", "$PWD")
```

##### \[Pre-release] Windows arm64

**Warning:** Windows arm64 runners are currently in preview status and
use [unofficial versions of
nodejs](https://unofficial-builds.nodejs.org/). They are not intended
for production workflows.

We recommend configuring the runner in a root folder of the Windows
drive (e.g. "C:\actions-runner"). This will help avoid issues related to
service identity folder permissions and long file path restrictions on
Windows.

The following snipped needs to be run on `powershell`:

```powershell

##### Create a folder under the drive root
mkdir \actions-runner ; cd \actions-runner

##### Download the latest runner package
Invoke-WebRequest -Uri https://github.com/actions/runner/releases/download/v2.314.1/actions-runner-win-arm64-2.314.1.zip -OutFile actions-runner-win-arm64-2.314.1.zip

##### Extract the installer
Add-Type -AssemblyName System.IO.Compression.FileSystem ;
[System.IO.Compression.ZipFile]::ExtractToDirectory("$PWD\actions-runner-win-arm64-2.314.1.zip", "$PWD")
```

##### OSX x64

```bash

##### Create a folder
mkdir actions-runner && cd actions-runner

##### Download the latest runner package
curl -O -L https://github.com/actions/runner/releases/download/v2.314.1/actions-runner-osx-x64-2.314.1.tar.gz

##### Extract the installer
tar xzf ./actions-runner-osx-x64-2.314.1.tar.gz
```

##### OSX arm64 (Apple silicon)

```bash

##### Create a folder
mkdir actions-runner && cd actions-runner

##### Download the latest runner package
curl -O -L https://github.com/actions/runner/releases/download/v2.314.1/actions-runner-osx-arm64-2.314.1.tar.gz

##### Extract the installer
tar xzf ./actions-runner-osx-arm64-2.314.1.tar.gz
```

##### Linux x64

```bash

##### Create a folder
mkdir actions-runner && cd actions-runner

##### Download the latest runner package
curl -O -L https://github.com/actions/runner/releases/download/v2.314.1/actions-runner-linux-x64-2.314.1.tar.gz

##### Extract the installer
tar xzf ./actions-runner-linux-x64-2.314.1.tar.gz
```

##### Linux arm64

```bash

##### Create a folder
mkdir actions-runner && cd actions-runner

##### Download the latest runner package
curl -O -L https://github.com/actions/runner/releases/download/v2.314.1/actions-runner-linux-arm64-2.314.1.tar.gz

##### Extract the installer
tar xzf ./actions-runner-linux-arm64-2.314.1.tar.gz
```

##### Linux arm

```bash

##### Create a folder
mkdir actions-runner && cd actions-runner

##### Download the latest runner package
curl -O -L https://github.com/actions/runner/releases/download/v2.314.1/actions-runner-linux-arm-2.314.1.tar.gz

##### Extract the installer
tar xzf ./actions-runner-linux-arm-2.314.1.tar.gz
```

##### Using your self hosted runner

For additional details about configuring, running, or shutting down the
runner please check out our [product
docs.](https://help.github.com/en/actions/automating-your-workflow-with-github-actions/adding-self-hosted-runners)

##### SHA-256 Checksums

The SHA-256 checksums for the packages included in this build are shown
below:

- actions-runner-win-x64-2.314.1.zip <!-- BEGIN SHA win-x64
-->2e1d73c3fe00ad37c359e4f48bd09aa88ef09a46fca16d6f1e94776ccf67fc27<!--
END SHA win-x64 -->
- actions-runner-win-arm64-2.314.1.zip <!-- BEGIN SHA win-arm64
-->acc807696d1dcad6fb45f6038f884185c54c48127445c365e86d03adb164a9e2<!--
END SHA win-arm64 -->
- actions-runner-osx-x64-2.314.1.tar.gz <!-- BEGIN SHA osx-x64
-->3faff4667d6d12c41da962580168415d628e3ffba9924b9ac995752087efc921<!--
END SHA osx-x64 -->
- actions-runner-osx-arm64-2.314.1.tar.gz <!-- BEGIN SHA osx-arm64
-->e34dab0b4707ad9a9db75f5edf47a804e293af853967a5e0e3b29c8c65f3a004<!--
END SHA osx-arm64 -->
- actions-runner-linux-x64-2.314.1.tar.gz <!-- BEGIN SHA linux-x64
-->6c726a118bbe02cd32e222f890e1e476567bf299353a96886ba75b423c1137b5<!--
END SHA linux-x64 -->
- actions-runner-linux-arm64-2.314.1.tar.gz <!-- BEGIN SHA linux-arm64
-->3d27b1340086115a118e28628a11ae727ecc6b857430c4b1b6cbe64f1f3b6789<!--
END SHA linux-arm64 -->
- actions-runner-linux-arm-2.314.1.tar.gz <!-- BEGIN SHA linux-arm
-->a653dd46dafd47c9a3a6637a18161a1445ac6b9c3f6d6b0305be9e1ee65769af<!--
END SHA linux-arm -->

</details>

---

### Configuration

📅 **Schedule**: Branch creation - At any time (no schedule defined),
Automerge - At any time (no schedule defined).

🚦 **Automerge**: Disabled by config. Please merge this manually once you
are satisfied.

♻ **Rebasing**: Whenever PR becomes conflicted, or you tick the
rebase/retry checkbox.

🔕 **Ignore**: Close this PR and you won't be reminded about these
updates again.

---

- [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check
this box

---

This PR has been generated by [Renovate
Bot](https://togithub.com/renovatebot/renovate).

<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiIzNy4yMTguMCIsInVwZGF0ZWRJblZlciI6IjM3LjIxOC4wIiwidGFyZ2V0QnJhbmNoIjoibWFpbiJ9-->

Co-authored-by: lumiere-bot[bot] <98047013+lumiere-bot[bot]@users.noreply.github.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

7 participants