Ubuntu16.04 使用git进行代码管理
1、在github注册账号并创建仓库
注册账号之后创建仓库
输入github的用户名和仓库名即可
2、安装git
sudo apt-get install git
3、配置git
(1)首先在本地创建ssh key
ssh-keygen -t rsa -C "your_email@youremail.com"
后面的your_email@youremail.com改为你在github上注册的邮箱,之后会要求确认路径和输入密码,我们这使用默认的一路回车就行。成功的话会在~/下生成.ssh文件夹,进去,打开id_rsa.pub,复制里面的key。
(2)在github中添加ssh key秘钥
>回到github上,进入 Settings(配置)
>左边选择SSH and GPG Keys,然后添加新的秘钥 NEW SSH key
>Title随便填,粘贴在你电脑上生成的key。在框中粘贴秘钥
(3)验证是否成功
输入下面代码
ssh -T git@github.com
出现
Hi username! You've successfully authenticated, but GitHub does not provide shell access.
则表示连接github成功
(4)设置username和email
接下来我们要做的就是把本地仓库传到github上去,在此之前还需要设置username和email,因为github每次commit都会记录他们。
git config --global user.name "your name"
git config --global user.email "your_email@youremail.com"
4、将本地版本推送到github仓库中
(1)创建工作机上的版本库
什么是版本库呢?版本库又名仓库,英文名repository,你可以简单理解成一个目录,这个目录里面的所有文件都可以被Git管理起来,每个文件的修改、删除,Git都能跟踪,以便任何时刻都可以追踪历史,或者在将来某个时刻可以“还原”。
所以,创建一个版本库非常简单,首先,选择一个合适的地方,创建一个空目录
mkdir learngit
cd learngit
或直接使用已存在的目录,进入到需要管理的目录中后执行:
git init
瞬间Git就把仓库建好了,而且告诉你是一个空的仓库(empty Git repository),细心的读者可以发现当前目录下多了一个.git的目录(看不见的话使用ctrl+h显示隐藏文件),这个目录是Git来跟踪管理版本库的,没事千万不要手动修改这个目录里面的文件,不然改乱了,就把Git仓库给破坏了。
(2)添加新文件
我们有一个版本仓库,但什么也没有,可以使用add命令添加我们需要管理的文件。
git add filename
可以使用add… 继续添加任务文件。
(3)提交版本
现在我们已经添加了这些文件,我们希望它们能够真正被保存在Git仓库。
为此,我们将它们提交到仓库。
git commit -m "Adding files"
如果您不使用-m,会出现编辑器来让你写自己的注释信息。
当我们修改了很多文件,而不想每一个都add,想commit自动来提交本地修改,我们可以使用-a标识。
git commit -a -m "Changed some files"
git commit 命令的-a选项可将所有被修改或者已删除的且已经被git管理的文档提交到仓库中。
千万注意,-a不会造成新文件被提交,只能修改。
(4)创建Github上的仓库
现在的情景是,你已经在本地创建了一个Git仓库后,又想在GitHub创建一个Git仓库,并且让这两个仓库进行远程同步,这样,GitHub上的仓库既可以作为备份,又可以让其他人通过该仓库来协作,真是一举多得。
首先,登陆GitHub,然后,在右上角找到“+”号按钮,选择“new repository”按钮,创建一个新的仓库:
Owner自动填充,为github用户名,定义仓库名为learngit,配置好其他属性后保存设置,生成仓库
(5)发布本地版本到github仓库
目前,在GitHub上的这个learngit仓库还是空的,GitHub告诉我们,可以从这个仓库克隆出新的仓库,也可以把一个已有的本地仓库与之关联,然后,把本地仓库的内容推送到GitHub仓库。
现在,我们根据GitHub的提示,在本地的learngit仓库下运行命令:
git remote add origin git@github.com:githubUsername/learngit.git
请千万注意,把上面的githubUsername替换成你自己的GitHub账户名,否则,以后推送是推不上去的,因为SSH Key公钥不匹配。
添加后,远程库的名字就是origin,这是Git默认的叫法,也可以改成别的,但是origin这个名字一看就知道是远程库。
下一步,就可以把本地库的所有内容推送到远程库上:
第一次推送:
git push -u origin master
若出现错误
sign_and_send_pubkey: signing failed: agent refused operation
Permission denied (publickey).
fatal: Could not read from remote repository.
Please make sure you have the correct access rights
and the repository exists.
则分别运行
eval "$(ssh-agent -s)"
ssh-add
并断开FQ VPN即可解决。
把本地库的内容推送到远程,用git push命令,实际上是把当前分支master推送到远程。
由于远程库是空的,我们第一次推送master分支时,加上了-u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令:
git push origin master