首次创建仓库
1.官网创建仓库
打开giuhub官网,右上角点击你的头像,随后点击your repositories
data:image/s3,"s3://crabby-images/d6fc7/d6fc7d116f10fd6933ad8a3f7141fb8c99101ba0" alt="image-20230508153654084"
点击New开始创建仓库
data:image/s3,"s3://crabby-images/85a4a/85a4aa1de6ab07b9260108a933d75cd895968930" alt="image-20230508153900898"
如下图为创建仓库的选项解释
data:image/s3,"s3://crabby-images/091f9/091f99b8eb7e4374b982964bc361890aa4b7577b" alt="image-20230508154647110"
出现如下界面就可以进行后续的git指令操作了
data:image/s3,"s3://crabby-images/2c0dc/2c0dc95cd3c8e253ebea541f794a4f6641d59c93" alt="image-20230508155617506"
2.git上传项目
进入需上传项目的所在目录,打开git命令行,输入如下命令开始初始化git仓库,这将在你的项目文件夹中创建一个名为 “.git” 的隐藏文件夹
git init
data:image/s3,"s3://crabby-images/0eed0/0eed086d5e14fb4325023a8c5885f80e32fa86df" alt="image-20230508170422666"
data:image/s3,"s3://crabby-images/b71e0/b71e0cccd16688ec7d43e4287f8bb0d13afcdacb" alt="image-20230508170633777"
将项目的所有文件添加到 Git 仓库
git add .
data:image/s3,"s3://crabby-images/1a519/1a519929e69099c29081babdd1f1639737c71900" alt="image-20230508171141266"
提供一条提交信息,以便于跟踪更改,将 “Initial commit” 替换为你选择的提交信息,可随便填写
git commit -m "Initial commit"
data:image/s3,"s3://crabby-images/5b85e/5b85ee921225842f25cac230eec2299a934e4d0a" alt="image-20230508170652712"
首次提交会出现如上图所示报错,需要配置 Git 的全局用户名和电子邮件地址,这样 Git 就可以将你的身份关联到提交的更改
git config --global user.email "you@example.com"
git config --global user.name "Your Name"
data:image/s3,"s3://crabby-images/2d6c7/2d6c71cd692c0b0716f105a2aac948d75f4a790c" alt="image-20230508171022030"
data:image/s3,"s3://crabby-images/88ee2/88ee29f9779897fdc4acf3f0a73ea4e93221328d" alt="image-20230508171103673"
将本地仓库与 GitHub 远程仓库关联,仓库链接替换成你自己的
git remote add origin https://github.com/xf555er/MyFirstRepository.git
data:image/s3,"s3://crabby-images/84c67/84c6713ff7fe23b03cc344efb9b06e97c7b7e72d" alt="image-20230508171243452"
将本地项目推送到GitHub仓库,随后弹框要求登录github账号,至于默认分支是master还是main,可以在git命令行所示的括号里看到,例如此处我的默认分支是master
git push -u origin master
data:image/s3,"s3://crabby-images/81a5e/81a5ec2c89bbddf0bdf636ae333b4d8e7b9cc9c9" alt="image-20230508171258642"
此处我选择使用浏览器进行登录github账号
data:image/s3,"s3://crabby-images/ebc5c/ebc5c04c09554c28f68f76cca4550116bed49571" alt="image-20230508171423538"
登录完后继续上传项目:git push -u origin master
,等待项目上传成功
data:image/s3,"s3://crabby-images/2a729/2a729d4e714be1ada8a7cfafbc17267b27d1aacc" alt="image-20230508171557558"
打开仓库主页可以发现,项目全部上传了
data:image/s3,"s3://crabby-images/b78e0/b78e06cf657e9cf6ded3b9d9996974b8843ae29d" alt="image-20230508171936494"
遇到的问题
项目push失败
问题详情
当我们将要把自己本地的项目push到github的仓库时,可能会出现了如下报错,这是网络问题导致的,毕竟github是国外的
Failed to connect to github.com port 443 after 21046 ms: Couldn't connect to server
解决方法
首先你要准备一个梯子(这里我用的clash),开启梯子后自动会在系统开启一个端口代理,例如此处我的代理端口是7980
data:image/s3,"s3://crabby-images/2e460/2e460213727cbe763779c9c09646aeeb9baac48b" alt="image-20230731155350866"
进入项目的git命令行,输入如下命令设置全局代理:
git config --global http.proxy http://127.0.0.1:7890
git config --global https.proxy http://127.0.0.1:7890
data:image/s3,"s3://crabby-images/8622e/8622e421026d961a8e62993974119656b141516c" alt="image-20230731155523704"
设置完毕后就能正常推送项目至github了
data:image/s3,"s3://crabby-images/c5f8c/c5f8c0e48d5d2bee621e70681beefbcb63bb78fb" alt="image-20230731155540375"
vs项目上传失败
问题详情
若你出现如下图所示的情况,其原因是你试图上传到 GitHub 的文件大小超过了 GitHub 的文件大小限制。GitHub 允许的最大文件大小为 100 MB,但是推荐的最大文件大小是 50 MB。你可以看到,错误信息告诉你哪些文件超过了这个限制
data:image/s3,"s3://crabby-images/19163/191635bc13c20eec0a0ca39b1fb680acda9d768f" alt="image-20230524161007324"
此处我上传的是visual studio的项目,这些项目超大文件大部分在.vs
目录上,这个目录通常是由 Visual Studio 自动生成的,包含了一些编译过程中的临时文件和其他非源代码文件,这些文件通常不需要(也不应该)被上传到代码仓库中
解决方法
在你的项目根目录下创建一个 .gitignore
文件(如果还没有的话),并在里面添加以下行来忽略 .vs
目录:
.vs/
data:image/s3,"s3://crabby-images/947dd/947dd6f45b0573fa609e6953620b11a0ce16ad4f" alt="image-20230524163007036"
使用git rm --cached
从 git 索引中移除 .vs
目录
git rm -r --cached .vs/
data:image/s3,"s3://crabby-images/11041/110415db77f262d2a298f520a364dbcca854bcfb" alt="image-20230524163254718"
提交改变,并再次推送到github
git commit -m "Removed .vs directory"
git push -u origin master
data:image/s3,"s3://crabby-images/4baef/4baef89b63cfcc829254bc352a077db1d4811533" alt="image-20230524181115853"
如何项目覆盖更新
问题详情
有些时候你需要"覆盖更新"github的项目,我说的“覆盖更新”是指,Github仓库完全匹配你本地目录的文件,如果对应的本地文件不存在,那么Github仓库则需将这些文件删除掉
解决方法
1.进入你本地git仓库命令行, 使用git add.
将所有文件添加到git索引中
2.使用git add -u
命令更新已被git追踪的文件。这个命令会记录文件的移除操作,所以如果你在本地删除了某个文件,它也会被从Github仓库中删除
3.使用 git commit -m "Updated files"
命令提交你的更改。请替换 "Updated files"
为你自己的提交消息
4.最后,用 git push origin master
命令将你的更改推送到Github
在最后一步你可能会出现如下图所示的情况。你遇到的这个错误表明远程Github仓库上的某些更改还未同步到你的本地仓库,因此Git阻止了你的推送操作。这是因为Git不确定应该保留哪个版本的更改,它不希望你不小心丢失任何数据。
data:image/s3,"s3://crabby-images/d29fb/d29fbdc04a2d7c93a3ba115223f2bd929c0604d2" alt="image-20230731160743566"
这种情况的解决方法是使用强制推送,如下命令所示:
git push -f origin master
data:image/s3,"s3://crabby-images/c5f8c/c5f8c0e48d5d2bee621e70681beefbcb63bb78fb" alt="image-20230731155540375"
如何更改关联的远程仓库
问题详情
当你要更改一个已经存在的本地仓库所关联的远程仓库时,可能会出现如下报错信息:error: remote origin already exists.
data:image/s3,"s3://crabby-images/e1abf/e1abff1a1debc18c927d9975594f2c9de9a77c11" alt="image-20230801171813977"
解决方法
首先,你可以使用以下命令检查当前的远程仓库配置,这将显示所有的远程仓库和它们的UR
git remote -v
data:image/s3,"s3://crabby-images/71300/713007caa9d68cc060d2e0617f143f06d401af57" alt="image-20230801172913755"
然后,你可以使用以下命令删除当前的远程仓库(通常名为origin
git remote remove origin
data:image/s3,"s3://crabby-images/face2/face28d224388c76f5424f2519b80f462f04a281" alt="image-20230801173001570"
接下来,你可以使用以下命令添加新的远程仓库
git remote add origin your_new_repository_url
data:image/s3,"s3://crabby-images/63e6c/63e6c4a5ecf38ae2e4e5c74ca7453b5a727e36b8" alt="image-20230801173048253"
最后,你可以使用以下命令验证新的远程仓库是否已经正确设置
git remote -v
data:image/s3,"s3://crabby-images/cc572/cc5724d2a5953e4129c22a005446e9b469fdebe7" alt="image-20230801173115779"