github建立及初步使用

注册github账户并创建仓库


安装git for Windows(Linux)

  • 以ubuntu16为例,默认选项安装完成后,打开控制台在命令行窗口下进行git 配置:
  • 创建ssh key:

$ ssh-keygen -t rsa -C "[email protected]"

 [email protected]  是注册用邮箱 ,此后会要求路径和密码,全部回车即可,成功后进入.ssh文件夹找到并打开文件 id_rsa.pub ,将文件全部内容复制, 进入github - Accont settings - SSH keys - ADD SSH keys,将内容粘贴到ADD SSH keys内 ,title可以随意填写。
  • 验证是否成功:

$ ssh -T [email protected]

   若成功则输入yes后返回You've successfully authenticated, but GitHub does not provide shell access 。
  • 设置username和email

$ git config --global user.name "Your Name"
$ git config --global user.email "[email protected]"

"Your Name"是GitHub上的用户名,"[email protected]"是GitHub注册邮箱。
  • git bush 设置
  • 添加远程地址

$ git remote add origin [email protected]:yourName/yourRepo
$ vim .git/config

yourName和yourRepo表示你再github的用户名和刚才新建的仓库,完成后进入.git/config,这里会多出一个remote "origin"内容,这就是刚才添加的远程地址,可以直接修改config来配置远程地址。 
  • 仓库初始化

$ git init

克隆仓库

git clone /path/to/repository

  • 日常仓库使用
  • 提交文件至缓存区,有三种常用命令

$ git add . //提交所有文件
$ git add readme.txt //仅仅是提交一个文件
$ git add src/ //更新一个目录

  • 将缓存区文件提交

git commit -m "代码提交注释信息"

  • 将提交文件推送到github 服务器

$ git remote add origin [email protected]:yourname/yourgit.git

首次使用这个仓库,先关联远程库,yourname是github用户名,yourgit是仓库名。关联后,使用命令将内容推送至 github 服务器

git push -u origin master

 github初次创建库时有时默认生成README.md文件,但文件不在本地代码目录中所以会出错,所以可先执行 git pull --rebase origin master 进行代码合并。

以后每次提交后,只要有必要,就可以使用命令

$ git add - $ git commit -m '代码注释信息'
$ git push origin master 推送最新修改.

  • 从远程更新至本地版本库
    即将远程仓库克隆至本地

$ git clone [email protected]:yourname/yourrepo


日常命令使用

  • 创建分支
    git checkout -b feature_x
  • 切换分支:
    git checkout 分支名
  • 删掉分支:
    git 分支名 -d feature_x
  • 除非你将分支推送到远端仓库,不然该分支就是不为他人所见的:
    git push origin <分支名>

GitHub分支管理

1、创建一个本地分支:

$ git branch <新分支名字>

2、将本地分支同步到GitHub上面:

$ git push <本地仓库名> <新分支名>

3、切换到新建立的分支:

$ git checkout <新分支名>

4、为你的分支加入一个新的远程端:

$ git remote add <远程端名字> <地址>

5、查看当前仓库有几个分支:

$ git branch

删除

1 从本地删除一个分支:

$ git branch -d <分支名称>

2 同步到GitHub上面删除这个分支:

$ git push <本地仓库名> :


报错

本地仓库为空

error: src refspec master does not match any.
error: failed to push some refs to 'https://github.com/HIT16S/MLCV.git'

  • 解决方法:在本地仓库中添加文件,添加完成后使用下面命令。

$ git commit -m "init files"

上述操作完成后继续使用push操作,将本地仓库上传。

仓库没进行初始化或本地版本管理仓库被删除

fatal: Not a git repository (or any of the parent directories)

  • 解决方法:初始化仓库,在本地仓库路径下执行命令。

$ git init

当前本地仓库已经有远端仓库连接

fatal: remote origin already exists.

  • 解决方法:
    1、先删除git仓库

$ git remote rm origin

2、再重新添加远程git仓库

$ git remote add origin [email protected]:yourname/reponame

3、如果执行删除操作报错的话,可以手动修改gitconfig文件内容,即删除【remote“origin”】及其后面内容。

$ vim .git/config

你可能感兴趣的:(github建立及初步使用)