如何解决Git 密码弃用 - 是否仍支持我的用例?
我每天都在使用深度学习模型,为了有效地做到这一点,我同时通过 ssh 连接到我网络上的多台计算机。
例如:
- 计算机 A:运行训练脚本
- 计算机 B:运行推理脚本
- 计算机 C:为下一次培训课程创建合成数据。
- 主机:编码
我在计算机 A、B 和 C 上运行的代码从我的主机计算机推送到 GitHub,并在每台目标计算机上拉取。我的主机仅供我自己使用,因此在我的主机上使用令牌认证不会那么不方便。但是,计算机 A、B 和 C 都是由我团队中的几个成员共享的计算机,并且可以有多个人在任何给定时间通过 ssh 连接到任何给定计算机。
因此,每个人都需要使用自己的用户名和密码对 git 操作进行身份验证,因此在计算机 A、B 和 C 上使用凭证助手不是一种选择。 (我不希望我的团队成员之一不小心使用我的 git 帐户进行推送。)
但是,从 2021 年 8 月 13 日开始,我将被迫使用令牌身份验证。我无法在计算机 A、B 和 C 上使用凭证助手。至少,每次 git 操作都需要至少提示用户名。每次在计算机 A、B 和 C 上执行 git 操作时,是否都需要从文本文件中复制和粘贴我的令牌?由于我在任何给定时间都在使用 4 台以上的计算机,因此我每天必须多次从 GitHub 上推和拉。每次从文本文件中复制和粘贴访问令牌对我来说太不方便了。我需要一个解决方法。
解决方法
我同意在这种情况下每次都使用令牌会有点不方便,尤其是因为一旦您在界面中创建了令牌,您将再也看不到它(因为 GitHub 谨慎地不会以明文形式存储它)。
但是,您可以使用 SSH 密钥来执行此操作。如果计算机 A、B 和 C 是共享实例,本质上只是您部署代码的地方,并且使用这些计算机的任何人都应该能够提取代码,那么您可以为这些计算机中的每一个创建一个 SSH 密钥(例如,使用 ssh-keygen -t ed25519
) 并将每个设置为 GitHub 上的只读部署密钥。这是让每台机器都拥有所需访问权限的好方法,而不必担心对存储库进行未经授权的写入。
如果您需要像您的用户和其他人一样推送经过身份验证的代码,您可以在与您的帐户关联的闪存驱动器上使用 SSH 密钥。如果这些计算机可以通过 SSH 相互访问,那么您可以通过 SSH 连接到带有 -A
标志的机器来转发您的代理,并使用您自己的个人 SSH 密钥从这些机器上的 GitHub 获取数据而不会出现问题。
SSH 密钥不受禁用密码身份验证的影响,因为它们与令牌一样,不容易被猜到。
,添加到@bk2204 的答案中,当您添加远程 Github 存储库时,您可以通过 HTTPS 或 SSH 地址引用它。我相信前者默认使用密码身份验证(并且很快将需要令牌),并且我同意 bk2204 的观点,即 SSH 是一种方便的替代方案。设置 SSH:
- Set up SSH keys for Github(如果您还没有它们);
- 更改每个 Github 遥控器的地址以使用 SSH 地址样式(您只想运行下面的第一行,但我包含了 HTTPS 地址进行比较,因此您可以在需要时切换回来)。
git remote set-url origin git@github.com:USERNAME/REPOSITORY.git #Using SSH access
git remote set-url origin https://github.com/USERNAME/REPOSITORY.git #Using HTTPS access
,
但是,计算机 A、B 和 C 都是由我团队中的几个成员共享的计算机,并且可以有多个人在任何给定时间通过 ssh 连接到任何给定计算机。
因此,每个人都需要使用自己的用户名和密码对 git 操作进行身份验证,因此在计算机 A、B 和 C 上使用凭证助手不是一种选择。
这毫无意义。您可以将团队中的每个人都放入一个组中,对组拥有的文件进行组工作,并且每个人都以自己的身份登录所有这些系统。在登录到这些系统时打开代理转发,就是这样,它就可以工作了。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。