Über diesen Leitfaden
In diesem Leitfaden werden die Änderungen mit den größten Auswirkungen beschrieben, die du zum Erhöhen der Kontosicherheit vornehmen kannst. In den einzelnen Abschnitten wird jeweils eine Änderung beschrieben, die du zur Verbesserung der Sicherheit an deinen Prozessen vornehmen kannst. Die Änderungen mit den größten Auswirkungen sind zuerst aufgeführt.
Welches Risiko besteht?
Kontosicherheit ist grundlegend für die Sicherheit deiner Lieferkette. Wenn es Angreifenden gelingt, dein Konto auf GitHub zu übernehmen, können sie böswillige Änderungen an deinem Code oder Buildprozess vornehmen. Ihr oberstes Ziel muss daher sein, die Übernahme Ihres Kontos und der Konten anderer Benutzer*innen in Ihrer Instanz zu erschweren.
Authentifizierung zentralisieren
Wenn Sie derdie Siteadministratorin für Ihre Instanz sind, können Sie den Anmeldevorgang für Benutzer vereinfachen, indem Sie eine Authentifizierungsmethode wählen, bei der eine Verbindung mit einem bestehenden Identitätsanbieter (IdP) wie CAS, SAML oder LDAP hergestellt wird. Das bedeutet, dass sich Benutzende kein zusätzliches Kennwort für GitHub mehr merken müssen.
Bei einigen Authentifizierungsmethoden wird auch das Übermitteln zusätzlicher Informationen an GitHub unterstützt, z. B. bei welchen Gruppen die Benutzenden Mitglied sind, oder das Synchronisieren von kryptografischen Schlüsseln für die Benutzenden. Das ist eine gute Möglichkeit, die Verwaltung bei wachsenden Organisationen zu vereinfachen.
Weitere Informationen zu Authentifizierungsmethoden für GitHub findest du unter Informationen zur Identitäts- und Zugriffsverwaltung.
Konfigurieren der zweistufigen Authentifizierung
Die beste Möglichkeit zur Verbesserung der Sicherheit Ihres Ihres persönlichen Kontos oder Ihrer Instanz ist die Konfiguration der Zwei-Faktor-Authentifizierung (2FA). Kennwörter selbst können kompromittiert werden, wenn sie erraten werden können, auf einer kompromittierten Website wiederverwendet oder durch Social Engineering wie Phishing kompromittiert werden. Mit der zweistufigen Authentifizierung wird die Kompromittierung eines Kontos deutlich erschwert, selbst wenn der Angreifer über das entsprechende Kennwort verfügt.
Um sowohl die Sicherheit als auch den zuverlässigen Zugriff auf dein Konto zu gewährleisten, solltest du immer mindestens zwei Anmeldeinformationen mit Zwei-Faktor-Authentifizierung in deinem Konto registriert haben. Zusätzliche Anmeldeinformationen stellen sicher, dass du nicht aus deinem Konto gesperrt wirst, auch wenn du den Zugriff auf eine Anmeldeinformation verlierst.
Wenn Sie derdie Siteadministratorin für Ihre Instanz sind, können Sie möglicherweise die Zwei-Faktor-Authentifizierung für alle Benutzer Ihrer Instanz konfigurieren. Die Verfügbarkeit der Zwei-Faktor Authentifizierung hängt von der verwendeten Authentifizierungsmethode ab. Weitere Informationen findest du unter Zentralisieren der Authentifizierung.
Wenn du Organisationsbesitzer bist, kannst du möglicherweise festlegen, dass alle Mitglieder der Organisation die zweistufige Authentifizierung aktivieren.
Weitere Informationen zum Aktivieren von 2FA in deinem eigenen Konto findest du unter Zwei-Faktor-Authentifizierung konfigurieren. Weitere Informationen zur Anforderung von 2FA in deiner Organisation findest du unter Erfordern der zweistufigen Authentifizierung in deiner Organisation.
Konfigurieren deines Unternehmenskontos
Unternehmensbesitzer können möglicherweise festlegen, dass alle Benutzer*innen der Instanz die zweistufige Authentifizierung verwenden. Ob Richtlinien für die zweistufige Authentifizierung für GitHub verfügbar sind, hängt davon ab, wie sich Benutzende für den Zugriff auf deine Instanz authentifizieren.
-
Wenn du dich bei GitHub Enterprise Server über einen externen Identitätsanbieter mithilfe von CAS oder SAML SSO anmeldest, kannst du die Zwei-Faktor-Authentifizierung für GitHub nicht konfigurieren. Die zweistufige Authentifizierung für den Identitätsanbieter muss von einem Benutzer mit Administratorzugriff konfiguriert werden.
-
Wenn du dich bei GitHub Enterprise Server über ein externes LDAP-Verzeichnis anmeldest, kannst du für dein Unternehmen die Zwei-Faktor-Authentifizierung für GitHub fordern. Wenn du die integrierte Authentifizierung für Benutzerinnen außerhalb deines Verzeichnisses zulässt, können einzelne Benutzerinnen die zweistufige Authentifizierung aktivieren. Es ist jedoch nicht möglich, festzulegen, dass für dein Unternehmen die zweistufige Authentifizierung verwendet werden muss.
Weitere Informationen findest du unter Erzwingen von Richtlinien für Sicherheitseinstellungen in deinem Unternehmen.
Konfigurieren eines persönlichen Kontos
Note
Je nachdem, welche Authentifizierungsmethode ein Siteadministrator konfiguriert hat, kannst du die 2FA für dein persönliches Konto möglicherweise nicht aktivieren.
GitHub unterstützt mehrere Optionen für die Zwei-Faktor-Authentifizierung, und obwohl jede von ihnen besser ist als keine, sind WebAuthn-Anmeldeinformationen die sicherste Möglichkeit. WebAuthn erfordert einen Authentifikator wie einen FIDO2-Hardware-Sicherheitsschlüssel, einen Plattformauthentifikator wie Windows Hello, ein Apple- oder Google-Telefon oder einen Kennwort-Manager. Phishing ist bei anderen Formen der zweistufigen Authentifizierung zwar schwierig, aber möglich (wenn du beispielsweise gebeten wirst, dein sechsstelliges Einmalkennwort vorzulesen). WebAuthn ist jedoch wesentlich widerstandsfähiger gegen Phishing, da in das Protokoll Domain Scoping integriert ist. Dies verhindert, dass Anmeldeinformationen von einer Website, die sich als die Anmeldeseite ausgibt, in GitHub verwendet werden können.
Wenn Sie 2FA einrichten, sollten Sie immer die Wiederherstellungscodes herunterladen und mehr als eine 2FA-Anmeldung einrichten. Dadurch wird sichergestellt, dass der Zugriff auf dein Konto nicht von einem einzelnen Gerät abhängt. Weitere Informationen findest du unter Zwei-Faktor-Authentifizierung konfigurieren und Wiederherstellungsmethoden bei der Zwei-Faktor-Authentifizierung konfigurieren.
Konfigurieren eines Organisationskontos
Note
Je nachdem, welche Authentifizierungsmethode ein Siteadministrator konfiguriert hat, kannst du die 2FA für deine Organisation möglicherweise nicht vorschreiben.
Als Organisationsinhaberin kannst du erkennen, für welche Benutzerinnen die zweistufige Authentifizierung nicht aktiviert ist. Du kannst ihnen beim Einrichten der zweistufigen Authentifizierung behilflich sein und anschließend festlegen, dass für deine Organisation die zweistufige Authentifizierung verwendet werden muss. Informationen zu dieser Vorgehensweise findest du unter:
- Überprüfen, ob die 2FA für die Benutzer*innen deiner Organisation aktiviert ist
- Vorbereiten auf die Voraussetzung der zweistufigen Authentifizierung in deiner Organisation
- Erfordern der zweistufigen Authentifizierung in deiner Organisation
Herstellen einer Verbindung mit GitHub mithilfe von SSH-Schlüsseln
Es gibt weitere Möglichkeiten, sich mit GitHub bei der Website anzumelden. Viele autorisieren den Code, den sie an GitHub pushen, mit einem privaten SSH-Schlüssel. Weitere Informationen finden Sie unter Informationen zur SSH.
Ein Angreifer, der an deinen privaten SSH-Schlüssel gelangt, kann deine Identität annehmen und böswilligen Code an alle Repositorys pushen, für die du Schreibzugriff hast. Wenn du deinen privaten SSH-Schlüssel in einem Datenträgerlaufwerk speicherst, solltest du ihn mit einer Passphrase zu schützen. Weitere Informationen finden Sie unter SSH-Schlüssel-Passphrasen verwenden.
Eine weitere Option besteht darin, SSH-Schlüssel mit einem Hardwaresicherheitsschlüssel zu generieren. Dabei kann derselbe Schlüssel wie für die zweistufige Authentifizierung verwendet werden. Die Kompromittierung von Hardwaresicherheitsschlüsseln per Fernzugriff ist schwierig, da der private SSH-Schlüssel auf der Hardware verbleibt und über die Software nicht direkt zugänglich ist Weitere Informationen finden Sie unter Generieren eines neuen SSH-Schlüssels und Hinzufügen des Schlüssels zum ssh-agent.
Hardwaregestützte SSH-Schlüssel sind recht sicher, aber die Hardwareanforderung ist für einige Organisationen möglicherweise nicht geeignet. Ein alternativer Ansatz besteht darin, SSH-Schlüssel zu verwenden, die nur für einen kurzen Zeitraum gültig sind. Auch wenn der private Schlüssel kompromittiert wird, kann er nicht lange genutzt werden. Auf diesem Konzept beruht die Unterhaltung einer eigenen SSH-Zertifizierungsstelle. Bei diesem Ansatz kannst du weitgehend festlegen, wie sich Benutzer*innen authentifizieren, jedoch bist du dafür verantwortlich, selbst eine SSH-Zertifizierungsstelle zu unterhalten. Weitere Informationen finden Sie unter Informationen zu SSH-Zertifizierungsstellen.