终端上传本地文件到Github/Gitlab

本文章参考文章:https://www.jianshu.com/p/c74ae40b5127

第一步:新建项目

Github/Gitlab上新建项目:

 

第二步:配置密钥

1.打开终端:首先输入

$ git config --global user.name "用户"
$ git config --global user.email "邮箱"

2.生成SSH key

   首先检查是否生成密钥

   cd ~/.ssh   如果返回的ls有3个文件,则密钥已经生成

   如果没有密钥,则通过下列方式

$ ssh-keygen -t rsa -C "邮箱"

   生成,生成过程中一路按3次回车键就好了。(默认路径,默认没有密码登录)
生成成功后,去对应目录C:\Users\hyt.ssh里用记事本打开id_rsa.pub,得到ssh key公钥。

3.将公钥复制到SSH Keys

   首先找到settings 点击进去之后,找到SSH keys 点击之后将公钥复制到key中,添加Title之后点击Add key,复制完成

第三步:建立本地仓库

1. 初始化本地仓库,更改路径到需要发布的文件夹下,让后执行下列命令

git init  //初始化本地仓库

2. 将本地所有文件添加到暂存区,执行下列命令,“.”代表所有文件,也可一个一个添加

git add .   //将本地项目的所有文件添加到暂存区

3.  将暂存区文件提交到本地仓库,并添加说明信息

git commit -m "说明信息"   

第四步:将本地仓库代码推送到Github/Gitlab远端仓库

 1. 建立本地仓库和Github/Gitlab远端仓库的关联,执行下列命令,git remote add origin 后面部分去自己项目下复制

git remote add origin  git@gitlab***************.git

在这一步时如果出现错误:fatal:remote origin already exists,先清除一下关联关系:

git remote rm origin

再重新关联: 

git remote add origin  git@gitlab***************.git

 2. 检查关联是否建立且正确,执行下列命令(可忽略这一步)

git remote -v

3.  将代码由本地仓库上传到 GitLab 远端仓库,依次执行下列命令

     获取远程与本地同步合并:

git pull --rebase origin master

     如果远程库不为空必须做这一步,否则后面的提交会失败,不加这句可能报错,原因是 GitLab中的 README.md 文件不在本地仓库中,可以通过该命令进行代码合并。

     把当前分支master推送到远程:

git push -u origin master

     执行完之后如果无错误就上传成功了,需要提示的是这里的 master 是 GitLab默认的分支,如果你本地的当前分支不是 master,就用git checkout master命令切换到master分支,如果你想用本地当前分支上传代码,则把上面两条命令里的 master 切换成你的当前分支名即可。

    如果推送不成功,先pull一下,如果报错fatal: refusing to merge unrelated histories,说明本地和远端的git库是两个 根本不相干的 git 库, 然后本地要去推送到远端, 远端觉得这个本地库跟自己不相干, 所以告知无法合并。解决方法:强制合并:

git pull origin master --allow-unrelated-histories

    后面加上 --allow-unrelated-histories ,意思是把两段不相干的分支进行强行合并,然后再将代码推送到远端。 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: GitHubGitLab和Gitee都是基于Git的代码托管平台,但它们之间有以下区别: 1. 托管服务商不同:GitHub是由美国GitHub公司提供的,GitLab是由GitLab公司提供的,Gitee是由中国的码云公司提供的。 2. 功能和特性不同:GitHubGitLab都提供了完整的代码托管、版本控制、协作开发、CI/CD等功能,而Gitee则更加注重国内用户的需求,提供了更多的中文化、社交化、企业级服务等特性。 3. 安全性不同:GitHubGitLab都有较高的安全性,包括代码加密、访问控制、漏洞修复等,而Gitee则因为在国内,可能会受到政策和法律的限制,安全性可能会受到影响。 4. 社区和用户群不同:GitHubGitLab都有全球性的用户群,社区活跃度高,开源项目数量多,而Gitee则更多地聚焦于国内用户,社区规模相对较小。 总的来说,GitHubGitLab更适合全球范围内的开发者和企业使用,而Gitee则更适合国内用户和企业使用。 ### 回答2: GitHubGitLab和Gitee都是常见的代码托管平台,它们都使用Git作为版本控制工具。下面是对它们的区别和特点的详细分析: 1. 背景和出品公司 GitHub是全球最大的代码托管平台,由美国GitHub公司推出,拥有全球活跃用户最多、最活跃的开源社区,用户可以将代码存储在GitHub上,并与其他用户分享和交流。 GitLab也是一款Git仓库管理工具,由本土且开源的GitLab公司(现已被美国招标在Nvidia旗下)开发。它不仅提供代码托管服务,还包括项目管理、自动化构建、CI/CD等功能。 Gitee是国内优秀的代码托管平台,由国内技术公司OSCHINA开发,主要服务国内开发者,拥有较为完善的中文文档,以及国内优秀的自动化开发流程构建服务语音机器人。 2. 私有仓库限制 GitHub是一个完全公开的平台,只支持开放源代码仓库,如果需要使用私有仓库,需要购买付费账户。而GitLab和Gitee则提供私有代码仓库的免费服务,不需要支付额外费用。 3. 功能和扩展性 三个平台都支持Git作为版本控制工具,支持Webhook、issue跟踪等基本的工具,但GitLab除此之外,还具备代码质量分析、自动化集成、CI/CD等高级功能,非常适合团队协作和支持DevOps实践。而Gitee则针对国内开发者的需求,进行了一些本地化的优化,提供了一些集成环节,支持常见的开发语言和常用工具的使用,听说还提供了基于web IDE的代码开发调试能力。 4. 社区和使用者 GitHub是全球领先的开源社区,拥有众多的优秀开源项目和活跃的开发者社区,吸引了全球众多的开发者和组织加入其中。GitLab虽然不如GitHub知名度高,但也是一个活跃度很高的Git社区。在国内,Gitee和码云有很好的口碑,得到了很多开发者的青睐,也聚集了不少高质量的开源项目。 总之,GitHubGitLab和Gitee在代码管理上都提供了优秀的服务,但是它们的目标用户和产品定位都有所不同。开发者可以根据自己的需求和技术栈来选择适合自己的平台。 ### 回答3: GitHubGitLab和Gitee都是目前比较知名的代码托管平台,它们的主要功能都是为开发者提供一个代码的版本控制和协作的平台。它们之间的区别主要从以下几个方面来看: 1. 托管服务商不同 GitHub是由美国公司GitHub Inc.进行维护,GitLab是由瑞典的GitLab Inc. 维护,而Gitee是由中国广州山月网络科技股份有限公司维护。 2. 提供的服务不同 虽然都是提供代码托管服务,但GitHubGitLab还提供了一些其他的服务,比如项目管理、CI/CD工具等。 3. 用户群体不同 虽然三个平台都是全球性公司,但GitHubGitLab的用户主要集中在欧美,而Gitee的用户主要在中国。 4. 费用不同 三个平台都提供了免费的代码托管服务,不过付费服务差异较大。GitHub提供了更多的功能,但收费也更高,而GitLab提供更多的免费功能,但是其托管服务较慢。Gitee则是提供了相对较便宜的付费方案,且服务质量相对稳定。 综上述,虽然三个平台都是代码托管平台,但在自身的特点和重点上会有所不同。GitHub的最大的功能是构建协作社区类似程序,其他则如 CI/CD、移动应用发布、企业级和数据中心级的代码托管等,GitLab则更适合企业使用。对于中国用户来说,Gitee可能会更适合,因为在国内的网络环境下,访问速度会更快。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值