当前位置:首页 > 技术分析 > 正文内容

Linux下git和github搭建使用教程

ruisui882个月前 (03-08)技术分析6

一:linux下git和github搭建

1)、注册gihub账号:

github官网: https://github.com/自行创建即可。

登录,create repository新建仓库一个测试库test,创建完成。

2)、linux安装git环境

默认情况下基本都已经存在安装的,如果没有则安装

yum -y install git

3)、生成ssh key 密钥

ssh-keygen命令生成密钥,可直接默认,也可自己选择加密方式,如选择rsa加密方式

ssh-keygen -t rsa

一直回车默认即可,生成如下!

生产的密钥在家目录生成 .ssh目录里面,查看公钥:

cat ./ssh/id_rsa.pub

4)、在github添加公钥

登录github,在选项setting >> SSH and GPG key >> add new ssh添加刚才的公钥地址即可。

title随便填写即可

添加完成,用 ssh -T git@github.com 命令可检测是否成功。

ssh -T git@github.com

出现以下信息为成功。

[root@localhost ]# ssh -T git@github.com
Hi ! You've successfully authenticated, but GitHub does not provide shell access.
[root@localhost ]#

5)、配置git参数的username,email

这是因为Git是分布式版本控制系统,所以,每个机器都必须自报家门:你的名字和Email地址。

git config --global user.name "your name" //配置用户名
git config --global user.email "your email" //配置email

配置好后,可查看相关参数

git config -l

二: Git从本地仓库上传到GitHub

1)、创建进入一个目录作为本地库

这里已 testdir 目录为例,以创建 README.md 文件为例。

mkdir testdir && cd testdir
touch README.md

初始化一个本地库

git init

初始化后,本目录会出现一个隐藏文件夹 .get

2)、添加本地库并推送代码文件

添加文件到本地仓库

git add README.md

提交到本地库并备注,此时变更仍在本地。

git commit -m "first commit"

增加一个远程服务器的别名,也是本地仓库名,格式为:

remote add 别名 git@github.com:github用户名/仓库名称.git

这里测试添加一个别名为test_readme,用户名为theonyu,仓库名为test的仓库。

git remote add test_readme git@github.com:theonyu/test.git

将本地文件(刚才别名)提交到Github的test本库中。此时才更新了本地变更到github服务上

git push -u test_readme master

提交成功:

在github查看,文件也已经上传成功

其他命令参考如下:

git add README.md #添加文件到本地仓库
git rm README.md #本地倒库内删除
git commit -m "first commit" #提交到本地库并备注,此时变更仍在本地。
git commit -a ##自动更新变化的文件,a可以理解为auto
git remote add xxx git@github.com:xxx/xxx.git #增加一个远程服务器的别名。
git remote rm xxx ##删除远程版本库的别名
git push -u remotename master #将本地文件提交到Github的remoname版本库中。此时才更新了本地变更到github服务上

三: 同步github到本地仓库

在github仓库中右边code选项,可看到有三种方式

一般在linux采用ssh的即可,如将刚才上传的README.md下载至本地

git clone git@github.com:theonlyu/test.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 ##获取并合并内容到本地

四:Git的分支管理

1)、创建分支

例子:在本地仓库目录创建一个branch.txt以分支提交。
git branch #显示当前分支是master
git branch new-txt #创建分支命名为new-txt
git checkout new-txt #切换到新分支
touch branch.txt
git add branch.txt
git commit -a -m "added branch.txt"
git push test_readme new-txt ##把分支提交到远程服务器,只是把分支结构和内容提交到远程,并没有发生和主干的合并行为。

在github左上角可看到,new-txt分支已经上传成功,文件也存在了。主master却还没有新文件,因为没合并。

2)、合并分支

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

git checkout master #切换到新主干
git merge new-txt ##把分支合并到主干
git branch #显示当前分支是master
git push test_readme master #此时主干中也合并了new-txt的代码,test_readme为别名

在github中成功合并,新文件 branch.txt 也存在了。

3)、其他命令:

#更新远程分支列表
git remote update 别名 --prune
#查看所有分支
git branch -a
#删除远程分支
git push 别名 --delete 分支名
#删除本地分支
git branch -d 分支名

扫描二维码推送至手机访问。

版权声明:本文由ruisui88发布,如需转载请注明出处。

本文链接:http://www.ruisui88.com/post/2608.html

标签: git删除commit
分享给朋友:

“Linux下git和github搭建使用教程” 的相关文章

Gitlab之间进行同步备份

目前,我们公司有两个研发团队,分别在北京和武汉,考虑到访问速度的问题,原有武汉的研发环境在近端部署。也就是北京和武汉分别有两套独立的研发管理环境,虽然这解决了近端访问速度的问题,但是管理上较为分散,比如研发环境备份和恢复就是最重要的问题之一。最近,处于对安全性和合规性的考虑,希望将北京和武汉的源代码...

Vue页面传参详解

一、两种方式方法1:name跳转页面this.$router.push({name:'anotherPage',params:{id:1}})另一页面接收参数方式:this.$route.params.id示例:控制台展示:方法2:path跳转页面this.$router.push(...

三、Uni-app + vue3 页面如何跳转及传参?

Vue 项目往往需要使用 vue-router 插件,刚开始入门 Uni-app + Vue3 项目的同学,会不会想着路由使用 vue-router V4 版本不就可以了吗?不怕大家笑话,我就是这样想的,毕竟我是第一次使用 Uni-app ,由于孕期记性贼差,所以我决定写成笔记,加深记忆。uni-a...

uni-app基于vue开发小程序与标准vue开发新增点

1、路由跳转传参uni.navigateTo({ url: `/pages/transition/spreadTextAction?t=${this.options.t}&rt=${this.options.rt}&l=${this.options.l}`});uni.navigateBack({...

慕课 SpringBoot2.X+Vue+UniAPP,全栈开发医疗小程序

本课程以业务驱动技术栈,打造业务相对完整的掌上医疗小程序,解决大家没有好的毕设项目或者求职项目的困境。本课程案例采用前后端分离架构,业务功能完善(既有WEB管理端,也有移动用户端),界面美观,无需艰涩的技术也能做出亮眼的作品。SpringBoot2.X+Vue+UniAPP,全栈开发医疗小程序 |...

首批龙芯3A6000电脑规模化应用:内置QQ、微信主流软件

6月18日消息,今日,龙芯中科宣布,近千台龙芯3A6000电脑走进福建福州某区各科室并服务于具体工作开展。据介绍,该批电脑为实现首批规模化应用的3A6000整机产品,搭载国产操作系统,内置主流办公和即时通讯等软件,可充分满足打印机利旧要求(兼容原有打印机设备)。3A6000根据官方晒出的桌面截图显示...