Información general
Puedes autenticar Actions Runner Controller (ARC) en la API de GitHub mediante un GitHub App o mediante un personal access token (classic).
Note
No se puede autenticar mediante un GitHub App para los ejecutores en el nivel empresarial. Para más información, consulta Administración del acceso a los ejecutores autohospedados mediante grupos.
Autenticación de ARC con un GitHub App
-
Crea un GitHub App que pertenezca a una organización. Para más información, consulta Registro de una instancia de GitHub App. Configura los datos de GitHub App como se indica a continuación.
-
En "Dirección URL de la página principal", escribe
https://github.com/actions/actions-runner-controller
. -
En "Permisos", haz clic en Permisos de repositorio. A continuación, usa los menús desplegables para seleccionar los siguientes permisos de acceso.
-
Administración: lectura y escritura
Note
Administration: Read and write
solo es necesario al configurar Actions Runner Controller para registrarse en el ámbito del repositorio. No es necesario registrarse en el ámbito de la organización. -
Metadatos: solo lectura
-
-
En "Permisos", haz clic en Permisos de la organización. A continuación, usa los menús desplegables para seleccionar los siguientes permisos de acceso.
- Ejecutores autohospedados: lectura y escritura
-
-
Después de crear la GitHub App, en la página de la GitHub App, anota el valor de "Identificador de aplicación". Usarás este valor más adelante.
-
En "Claves privadas", haz clic en Generar una clave privada y guarda el archivo
.pem
. Usarás esta clave más adelante. -
En el menú de la esquina superior izquierda de la página, haz clic en Instalar aplicación y, junto a tu organización, haz clic en Instalar para instalar la aplicación en la organización.
-
Después de confirmar los permisos de instalación en la organización, anota el id. de instalación de la aplicación. Lo usará más adelante. Puedes encontrar el id. de instalación de la aplicación en la página de instalación de la aplicación, que tiene el siguiente formato de dirección URL:
https://HOSTNAME/organizations/ORGANIZATION/settings/installations/INSTALLATION_ID
-
Registra el identificador de la aplicación, el identificador de instalación y el archivo de clave privada
.pem
descargado en Kubernetes como secreto en los pasos anteriores.Para crear un secreto de Kubernetes con los valores de la GitHub App, ejecuta el comando siguiente.
Note
Crea el secreto en el mismo espacio de nombres donde está instalado el gráfico
gha-runner-scale-set
. En este ejemplo, el espacio de nombres esarc-runners
para que corresponda a la documentación de inicio rápido. Para más información, consulta Inicio rápido para Actions Runner Controller.Bash kubectl create secret generic pre-defined-secret \ --namespace=arc-runners \ --from-literal=github_app_id=123456 \ --from-literal=github_app_installation_id=654321 \ --from-literal=github_app_private_key='-----BEGIN RSA PRIVATE KEY-----********'
kubectl create secret generic pre-defined-secret \ --namespace=arc-runners \ --from-literal=github_app_id=123456 \ --from-literal=github_app_installation_id=654321 \ --from-literal=github_app_private_key='-----BEGIN RSA PRIVATE KEY-----********'
Después, usa la propiedad
githubConfigSecret
de tu copia del archivovalues.yaml
para pasar el nombre del secreto como referencia.githubConfigSecret: pre-defined-secret
Para ver más opciones de configuración de Helm, consulta values.yaml
en el repositorio de ARC.
Autenticación de ARC con un personal access token (classic)
ARC puede usar personal access tokens (classic) para registrar ejecutores autohospedados.
Note
Autenticar ARC con un personal access token (classic) es el único método de autenticación admitido para registrar ejecutores en el nivel empresarial.
-
Crea una personal access token (classic) con los ámbitos requeridos. Los ámbitos necesarios son diferentes en función de si vas a registrar ejecutores en el nivel de repositorio, la organización o la empresa. Para más información sobre cómo crear un personal access token (classic), consulta Administración de tokens de acceso personal.
A continuación se muestra la lista de los ámbitos de personal access token para los ejecutores de ARC.
- Ejecutores del repositorio:
repo
- Ejecutores de la organización:
admin:org
- Ejecutores empresariales:
manage_runners:enterprise
- Ejecutores del repositorio:
-
Para crear un secreto de Kubernetes con el valor de tu personal access token (classic), usa el comando siguiente.
Note
Crea el secreto en el mismo espacio de nombres donde está instalado el gráfico
gha-runner-scale-set
. En este ejemplo, el espacio de nombres esarc-runners
para que corresponda a la documentación de inicio rápido. Para más información, consulta Inicio rápido para Actions Runner Controller.Bash kubectl create secret generic pre-defined-secret \ --namespace=arc-runners \ --from-literal=github_token='YOUR-PAT'
kubectl create secret generic pre-defined-secret \ --namespace=arc-runners \ --from-literal=github_token='YOUR-PAT'
-
En la copia del archivo
values.yaml
, pasa el nombre del secreto como referencia.githubConfigSecret: pre-defined-secret
Para ver más opciones de configuración de Helm, consulta
values.yaml
en el repositorio de ARC.
Aviso legal
Algunas partes se han adaptado a partir de https://github.com/actions/actions-runner-controller/ con licencia Apache-2.0:
Copyright 2019 Moto Ishizawa
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.