Meervoudige verificatie voor SSH-toegang inschakelen

Voor extra beveiliging biedt Adobe Commerce op cloudinfrastructuur multifactorverificatie (MFA)-handhaving om de verificatievereisten voor SSH-toegang tot cloudomgevingen te beheren.

Wanneer MFA op een project wordt toegelaten, vereisen alle gebruikersrekeningen met de toegang van SSH of een twee-factor authentificatie (TFA) code of een API teken en het certificaat van SSH om tot het milieu toegang te hebben.

NOTE
MFA is niet standaard ingeschakeld voor Cloud-projecten. De eigenaar van de Rekening voor Adobe Commerce op het project van de wolkeninfrastructuur moet een kaartje van de Steun van Adobe Commercevoorleggen om het toe te laten. Wanneer MFA wordt toegelaten, moeten alle gebruikers dubbel-factor authentificatie (TFA) hebben die op hun Adobe Commerce op de rekening van de wolkeninfrastructuur voor de toegang van SSH tot de projectmilieu's wordt toegelaten.

Certificaten voor SSH-toegang

Met MFA kunnen gebruikers een OAUTH-toegangstoken uitwisselen met een kortstondig SSH-certificaat dat is gegenereerd door de Adobe Cloud Certifier API. Als de gebruiker de rol Admin of Medewerker, een geldige SSH-sleutel en een geldige TFA-code of API-token heeft, gebruikt Adobe Commerce op de cloud-infrastructuur deze referenties om het tijdelijke SSH-certificaat te genereren. De vervaldatum van het certificaat wordt ingesteld op één uur, maar wordt tijdens de huidige sessie automatisch vernieuwd.

Na het registreren in een project met MFA, moeten de gebruikers magento-cloud CLI gebruiken om het certificaat van SSH te produceren:

magento-cloud ssh-cert:load

Met de opdracht ssh-cert:load wordt het SSH-certificaat gegenereerd en geïnstalleerd in de SSH-agent van de lokale gebruiker.

Certificaat automatisch genereren bij aanmelden

U kunt uw lokale milieu vormen om het certificaat van SSH automatisch te produceren wanneer u aan magento-cloud CLI voor authentiek verklaart.

om het certificaat van SSH auto-generatie aan uw magento-cloud CLI configuratie toe te voegen:

  1. Maak op uw lokale werkstation een bestand met de naam config.yaml in de map .magento-cloud in uw thuismap als dit niet bestaat.

    code language-bash
    touch ~/.magento-cloud/config.yaml
    
  2. Voeg de volgende configuratie toe aan het config.yaml dossier.

    code language-yaml
    api:
       auto_load_ssh_cert: true
    
  3. Gebruik de CLI magento-cloud om opnieuw te verifiëren:

    Afmelden:

    code language-bash
    magento-cloud logout
    

    Aanmelden:

    code language-bash
    magento-cloud login
    

    Volg het antwoord:

    code language-none
    Please open the following URL in a browser and log in:
    http://127.0.0.1:5000
    
    Help:
      Leave this command running during login.
      If you need to quit, use Ctrl+C.
    
      To log in using an API token, run: magento-cloud auth:api-token-login
    
    Login information received. Verifying...
    You are logged in.
    
    Generating SSH certificate...
    A new SSH certificate has been generated.
    It will be automatically refreshed when necessary.
    The certificate is included in your SSH configuration: /Users/<user-name>/.ssh/config
    

Verbinding maken met een omgeving die SSH gebruikt met TFA

Wanneer MFA op een project wordt toegelaten, moet u TFA op uw rekening worden toegelaten alvorens u met een verre milieu kunt verbinden gebruikend SSH. Zie TFAtoelaten.

recommendation-more-help

Eerste vereisten:

Voor projecten die met MFA handhaving worden toegelaten, vereist de toegang van SSH de volgende toestemmingen en rekeningsmontages:

om het gebruiken van SSH met de geloofsbrieven van de gebruikersrekening van TFA te verbinden:

  1. Login aan uw rekening.

  2. Op uw lokale werkstation, gebruik magento-cloud CLI om het certificaat van SSH te produceren.

    code language-bash
    magento-cloud ssh-cert:load
    

    Monsterrespons:

    code language-none
    Generating SSH certificate...
      Expires at: 2020-07-13T15:28:13-04:00
      Multi-factor authentication: verified
      Mode: interactive
    The certificate will be automatically refreshed when necessary.
    Checking SSH configuration file: /Users/<user-name>/.ssh/config
    Do you want to update the file automatically? [Y/n] Y
    Configuration file updated successfully: /Users/<user-name>/.ssh/config
    
  3. Gebruik een SSH om verbinding te maken met de externe omgeving.

    code language-bash
    ssh abcdef7uyxabce-master-7rqtwti--mymagento@ssh.us-5.magento.cloud
    
    code language-none
     __  __                   _          ___ _             _
    |  \/  |__ _ __ _ ___ _ _| |_ ___   / __| |___ _  _ __| |
    | |\/| / _` / _` / -_) ' \  _/ _ \ | (__| / _ \ || / _` |
    |_|  |_\__,_\__, \___|_||_\__\___/  \___|_\___/\_,_\__,_|
                |___/
    
     Welcome to Magento Cloud.
    
     This is environment master-7rqtwti
     of project abcdef7uyxabce.
    
    web@mymagento.0:~$
    

Broncode beheren met behulp van SSH met TFA

Wanneer u broncode voor Adobe Commerce beheert voor cloud-infrastructuurprojecten, gebruikt u SSH om te verifiëren bij de Git-opslagplaats voor het project. Als voor uw project de MFA-handhaving is ingeschakeld, moet u een SSH-certificaat genereren voordat u opdrachtregelbewerkingen kunt uitvoeren met behulp van de Git-gegevensopslagruimte.

om het gebruiken van SSH met de geloofsbrieven van de gebruikersrekening van TFA te verbinden:

  1. Login aan uw rekeningen voor authentiek verklaren gebruikend TFA.

    note note
    NOTE
    Als u geen TFA hebt toegelaten op uw rekening, moet u het toelaten. Zie TFA op wolkenrekeningentoelaten.
  2. Op uw lokale werkstation, gebruik magento-cloud CLI om het certificaat van SSH te produceren.

    code language-bash
    magento-cloud ssh-cert:load
    

    Monsterrespons:

    code language-none
    Generating SSH certificate...
      Expires at: 2020-07-13T15:28:13-04:00
      Multi-factor authentication: verified
      Mode: interactive
    The certificate will be automatically refreshed when necessary.
    Checking SSH configuration file: /Users/<user-name>/.ssh/config
    Do you want to update the file automatically? [Y/n] Y
    Configuration file updated successfully: /Users/<user-name>/.ssh/config
    
  3. Kloont de Git-opslagplaats voor uw projectomgeving:

    code language-bash
    git clone --branch integration abcdef7uyxabce@git.us-3.magento.cloud:abcdef7uyxabce.git myproject
    

    Monsterrespons:

    code language-none
    Cloning into 'myproject'...
    Connection to git.us-3.magento.cloud port 22 [tcp/ssh] succeeded!
    remote: counting objects: 22, done.
    Receiving objects: 100% (22/22), 82.42 KiB | 16.48 MiB/s, done.
    

Verbinding maken met een omgeving die SSH gebruikt met een API-token

Wanneer MFA op een project wordt toegelaten, vereisen de geautomatiseerde processen die de toegang van SSH tot een milieu van de Wolk vereisen een API teken. U kunt het token genereren via een Adobe Commerce op een cloud-infrastructuuraccount met toegang tot Admin of Contributor voor het project.

Voor verificatie met een API-token moet nog steeds een SSH-certificaat worden gegenereerd. Geautomatiseerde processen moeten ook de productie van een SSH-certificaat automatiseren.

Eerste vereisten:

om het gebruiken van SSH met een API symbolische referentie te verbinden:

  1. Meld u aan bij het Cloud-project met API-sleutelverificatie.

    code language-bash
    magento-cloud auth:api-token
    
  2. Voer bij de prompt de waarde voor een geldig API-token in.

    code language-none
    Please enter an API token:
    >
    
    The API token is valid.
    You are logged in.
    

Voorbeeld: geautomatiseerd SSH-script

Er zijn twee opties voor het opslaan van de API-token.

NOTE
Als een API-token wordt opgeslagen, wordt de CLI van magento-cloud automatisch geverifieerd en hoeft de opdracht magento-cloud login niet te worden uitgevoerd.

Optie 1: Creeer een milieuvariabele om het API teken op te slaan

Schrijf de token naar uw bash_profile

echo "export MAGENTO_CLOUD_CLI_TOKEN=<your api token>" >> ~/.bash_profile

Optie 2: Voeg het teken aan het config.yaml dossier toe

  1. Maak op uw lokale werkstation een bestand met de naam config.yaml in de map .magento-cloud in uw thuismap als dit niet bestaat.

    code language-bash
    touch ~/.magento-cloud/config.yaml
    
  2. Voeg de volgende configuratie toe aan het config.yaml dossier.

    code language-yaml
    api:
       token: <your api token>
    

Voorbeeld-basscript

#!/bin/bash
magento-cloud ssh-cert:load
ssh abcdef7uyxabce-master-7rqtabc--mymagento@ssh.us-3.magento.cloud "tail -n 10 ~/var/log/cloud.log"

Problemen oplossen

Gebruik de volgende informatie om fouten in SSH-verbindingsaanvragen door verificatiefouten zoals access requires MFA of permission denied op te lossen.

Uw aanvraag bevat geen geldig certificaat

Als uw verzoek geen geldig certificaat oplevert, wordt een bericht weergegeven dat lijkt op het volgende:

to Hello user-test (UUID: abaacca12-5cd1-4b123-9096-411add578998), you successfully
authenticated, but could not connect to service abcdef7uyxabce-master-7rqtabc--mymagento@ssh.us-3.magento.cloud:>
(reason: access requires MFA)

Probeer de volgende het oplossen van problemenprocedures om de verbindingskwestie op te lossen:

  • De TFA-configuratie van de account verifiëren
  • Verifieer opnieuw, en laad dan het certificaat opnieuw

om de configuratie en de authentificatie van TFA te verifiëren:

  1. Login aan uw rekening.

  2. Klik op My Profile in het accountmenu rechtsboven.

  3. Voor de Mijn pagina van het Profiel, klik het Security lusje.

    Als TFA wordt toegelaten, verstrekt de sectie van de Veiligheid opties om de configuratie van TFA te beheren.

  4. Als TFA niet is ingesteld, klikt u op Set up application en volgt u de instructies om deze in te schakelen. Zie TFAtoelaten.

  5. Als TFA wordt gevormd, probeer opnieuw voor authentiek te verklaren.

om het certificaat van SSH voor authentiek te verklaren en opnieuw te laden:

  1. Gebruik de CLI magento-cloud om opnieuw te verifiëren:

    code language-bash
    magento-cloud logout
    
    code language-bash
    magento-cloud login
    
  2. Laad het SSH-certificaat opnieuw:

    code language-bash
    magento-cloud ssh-cert:load
    

Toestemming geweigerd

Als de SSH-sleutel ontbreekt of ongeldig is, retourneert de SSH-verbindingsaanvraag een Permission denied (publickey) -fout.

Hello user-test (UUID: abaacca12-5cd1-4b123-9096-411add578998), you successfully authenticated, but could not connect to service oh2wi6klp5ytk-mc-35985-integration-nnulm4a--mymagento (reason: service doesn't exist or you do not have access to it)
oh2wi6klp5ytk-mc-35985-integration-nnulm4a--mymagento@ssh.eu-3.magento.cloud: Permission denied (publickey).

Om het probleem te bevestigen, voeg de sleutel van SSH aan uw huidige zitting toe, of werk het de configuratiedossier van SSH bij om uw sleutels van SSH automatisch te laden. Zie een openbare sleutel van SSHtoevoegen.

Kan geen toegang krijgen tot projecten zonder MFB

Als u aan een project met toegelaten multi-factor authentificatie (MFA) voor authentiek verklaart, zou u de volgende fout kunnen ontvangen wanneer het verbinden met andere projecten die geen MFA vereisen:

ssh abcdef7uyxabce-master-7rqtabc--mymagento@ssh.us-3.magento.cloud

Monsterrespons:

abcdef7uyxabce-master-7rqtabc--mymagento@ssh.us-3.magento.cloud: Permission denied (publickey).

Tijdens het genereren van het SSH-certificaat voegt de magento-cloud CLI een extra SSH-sleutel toe aan uw lokale omgeving. Die sleutel wordt gebruikt door gebrek als uw lokale configuratie SSH niet de sleutel van SSH voor projecttoegang omvat.

om uw sleutel van SSH aan de lokale configuratie toe te voegen:

  1. Maak het config -bestand als dit niet bestaat.

    code language-bash
    touch ~/.ssh/config
    
  2. Voeg een IdentityFile configuratie toe.

    code language-yaml
    Host *
      IdentityFile ~/.ssh/id_rsa
    
NOTE
U kunt meerdere SSH-toetsen opgeven door meerdere IdentityFile -items aan uw configuratie toe te voegen.
05f2f56e-ac5d-4931-8cdb-764e60e16f26