码迷,mamicode.com
首页 > 系统相关 > 详细

Linux下使用git命令及github项目

时间:2017-08-26 18:25:35      阅读:188      评论:0      收藏:0      [点我收藏+]

标签:版本控制   git   github使用   

Linux下使用git命令及github项目

说明:于2017年8月26日测试ok(金工)

  

在linux下搭建git环境

1、注册Github账号,网站:https://github.com

2、Linux创建SSH密钥:

方法一:ssh-keygen  ##一直默认就可以了 


方法二:ssh-keygen -t rsa -C "12700696@qq.com" //生成密钥,邮箱同上

cat  ~/.ssh/id_rsa.pub //提交密钥,复制里面的密钥


方法三:非交互式生成密钥:ssh-keygen  -t rsa -N ‘‘ -f  ~/.ssh/id_rsa -C "12700696@qq.com"    


3、将公钥加入到Github账户信息Account Settings->SSH Key

方法:登录到github网页中登陆自己的账号,然后再account setting中,找到SSH KEY讲复制的密钥加入(需要再次输入github的密码)


4、测试验证是否成功。

ssh -T git@github.com     提示successfully说明成功

Hi someone! You‘ve successfully authenticated, but GitHub does not provide shell access.  


同步github到本地

1、复制项目到本地:

git clone git@github.com:rshare/docker-installer.git   ##以SSH方式克隆到本地,可以读写  

git clone https://github.com/rshare/docker-installer.git ##以https方式克隆到本地,可以读写  


git同步的其他命令:

git clone git://github.com:xxxx/test.git ##以gitreadonly方式克隆到本地,只可以读  

git clone git@github.com:xxx/test.git  ##以SSH方式克隆到本地,可以读写  

git clone https://github.com/xxx/test.git ##以https方式克隆到本地,可以读写  

git fetch git@github.com:xxx/xxx.git  ##获取到本地但不合并  

git pull git@github.com:xxx/xxx.git ##获取并合并内容到本地  


本地提交项目到github

1、本地配置

git config --global user.name ‘onovps‘   #设置用户名标识

git config --global user.email ‘onovps@onovps.com‘ #全局联系方式,可选  

git config --list    #查看git环境设置


2、新建Git项目并提交到Github。

mkdir testdir && cd testdir  

touch README.md  

git init #初始化一个本地库  

git add README.md #添加文件到本地仓库  

git rm README.md #本地倒库内删除  

git commit -m "first commit" #提交到本地库并备注,此时变更仍在本地。  

git commit -a  ##自动更新变化的文件,a可以理解为auto  

git remote add xx git@github.com:rshare/docker.git  #增加一个远程服务器的别名。  

git remote rm xx   ##删除远程版本库的别名  

git push -u remotename master #将本地文件提交到Github的remoname版本库中。此时才更新了本地变更到github服务上。  


分支版本操作

1、创建和合并分支

git branch #显示当前分支是master  

git branch new-feature  #创建分支  

git checkout new-feature  #切换到新分支  

vi  index.php  

git add  index.php  

git commit -a -m "added initial version of page cache"  

git push origin new-feature  ##把分支提交到远程服务器,只是把分支结构和内容提交到远程,并没有发生和主干的合并行为。  


2、如果new-feature分支成熟了,觉得有必要合并进master

git checkout master  #切换到新主干  

git merge new-feature  ##把分支合并到主干  

git branch #显示当前分支是master  

git push  #此时主干中也合并了new-feature的代码  


--------------------------------------------

实例:rshare个人github同步数据实战。

第1步,登录github:

1、注册Github账号,网站:https://github.com   我的账号:rshare  密码:pass000

2、Linux创建SSH密钥:

方法一:非交互式生成密钥:ssh-keygen  -t rsa -N ‘‘ -f  ~/.ssh/id_rsa -C "12700696@qq.com"    

cat  ~/.ssh/id_rsa.pub //提交密钥,复制里面的密钥(第3步要粘贴)

说明:ssh-keygen是ssh密钥生成器,-t指定算法为rsa,-N指定密码为空,-f指定私钥位置,-C指定注释信息(不指定则为主机名)。

3、将公钥加入到Github账户信息Account Settings->SSH Key

方法:登录到github网页中登陆自己的账号,然后再account setting中,找到SSH KEY讲复制的密钥加入(需要再次输入github的密码)


4、测试验证是否成功。

ssh -T git@github.com     提示successfully说明成功

Hi someone! You‘ve successfully authenticated, but GitHub does not provide shell access.  


##同步github到本地

1、复制项目到本地:

mkdir  /test

cd  /test

git clone git@github.com:rshare/mydocker.git   ##以SSH方式克隆到本地,可以读写  

git clone https://github.com/rshare/docker-installer.git ##以https方式克隆到本地,可以读写  

ls  查看文件列表


2、创建新文件,并上传到github中。

cd  /test/mydocker

ls -a

git  remote

cp  -v  /etc/{hosts,group,passwd}  ./

git  add  hosts  group  passwd

git  status

git  commit  -m  ‘3files‘

git  push  -u  origin  master

验证:在github个人网站的mydocker仓库中查看是否多了三个文件(hosts,group,passwd)。


git其他命令:

git branch   #查看分支(即目录结构) 



3、删除远程仓库中的文件。

cd  /test/mydocker

ls  -a

git rm --cached  hosts  group  passwd    #删除缓存数据,并不删除本地文件

git  status

git commit -m "hehe" 

git push origin 

验证:在github个人网站的mydocker仓库中查看是否少了三个文件(hosts,group,passwd)。

技术分享


====网络Docker  hub的使用=============

flyer520docker镜像下载和上传实例:

1,注册docker-hub账号。在https://hub.docker.com/网站注册。

注:我的账号是flyer520,邮箱12700696@qq.com

 

2步,linux登录docker测试。

我的账号:docker login --username=flyer520  --email=12700696@qq.com  (登录OK)

查看登录信息:cat  ~/.docker/config.json

 

3步,下载docker镜像。

docker  pull busybox

docker  pull nginx

docker  images

 

4步,修改标签(重设标签)

测试1:修改nginx标签,并push上传到flyer520docker-hub中。

docker  tag  nginx  flyer520/nginx

docker  push flyer520/nginx

 

测试2:修改busybox标签,并push上传到flyer520docker-hub中。

docker  tag   busybox  flyer520/busybox

docker  push flyer520/busybox

 

验证:登录到docker-hub,查看是否多了nginx镜像。

 技术分享


待续....


到此,本实验操作完毕。


本文出自 “网络技术天地” 博客,请务必保留此出处http://1364952.blog.51cto.com/1354952/1959524

Linux下使用git命令及github项目

标签:版本控制   git   github使用   

原文地址:http://1364952.blog.51cto.com/1354952/1959524

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!