通用知识 - git 和 svn

git & svn

一:git安装

1:Linux安装

1.1:ubuntu安装配置git

1:先检验当前的环境中是否存在git

$ git

如果提示git命令没有被找到,说明当前环境中不存在git,将进行安装git操作

  • $ sudo apt-get install git # 中途确认部分点击 Y 即可
    
    # 等待安装完成
    
    $ git --v # 安装完成后进行检验
    # git用法和常见指令
    

2:配置用户名和邮箱

$ git config --global user.name "your_username"
$ git config --global user.email "your_email"

3:生成公钥 & gitee配置

$ ssh-keygen -C 'your_email' -t rsa  # 填入上面配置的email
# 这个操作会在你的~/.ssh/下建立相应的密钥文件
# 中途要进行输入的地方直接点击回车[enter]即可
  • 进入文件
cd ~/.ssh/  # 进入指定的文件夹
gedit id_rsa.pub  # 调出相应文件,复制其中的内容
  • 将公钥添加到gitee上的公钥群中

进入设置界面

在这里插入图片描述

在左侧导航单找到ssh公钥

在这里插入图片描述

添加后点击确定按钮,会让输入gitee的密码,输入成功后即可添加秘钥成功

4:配置本地仓库及推送测试

1:创建一个本地仓库的文件夹

$ mkdir gitrepo

2:进入该文件夹后创建一个测试文件

$ cd gitrepo
$ vim Test.java
public class Test {
    public static void main(String[] args) {
        System.out.println("Hello Java")
    }
}

3:推到本地仓库

$ git add . # 将下面的所有内容都进行推送。git add *.java -> 将下面的所有的java内容都推送
$ git commit -m "提交" # 推送到本地仓库

4:推到远程仓库

  • 在gitee中新建一个仓库,点击左下角仓库旁的+

在这里插入图片描述

  • 填写仓库的指定内容即可

在这里插入图片描述

其中仓库地址为:https://gitee.com/你gitee的用户名称/仓库名称.git

  • $ git remote add origin 你的仓库地址 # 添加远程仓库地址
    
  • $ git push -u origin master  # 推到主分支
    

在这里插入图片描述

1.2:centos安装配置git

方式一:通过yum安装

# 1. 卸载旧版本
yum remove git

# 2. 安装 yum 源的 Git 版本
yum install -y git

# 3. 查看版本
git version 
# 输出 git version 1.8.3.1

方式二:通过wget安装指定版本

查看最新版本:https://github.com/git/git/tags

在这里插入图片描述

# 如果没有安装 wget 则安装
yum install -y wget
# 我这里操作时最新版本为 V2.35.1 , 以下命令版本号请根据你选择的版本号自行修改

# 1. 下载指定版本
wget https://codeload.github.com/git/git/tar.gz/v2.35.1 

# 2. 下载完成后,可以查看到有 v2.35.1 文件
# 将 v2.35.1 文件转为压缩包并解压缩成文件夹
mv v2.35.1 v2.35.1.tar.gz && tar -zxf v2.35.1.tar.gz && cd git-2.35.1

# 安装依赖
yum install -y 
	curl-devel 
	expat-devel 
	gettext-devel 
	openssl-devel 
	zlib-devel 
	gcc 
	perl-ExtUtils-MakeMaker

# 编译
make prefix=/usr/local/git all
# 安装
make prefix=/usr/local/git install

配置环境变量

# 1. 编辑配置文件
vim /etc/profile

# 2. 在 /etc/profile 文件中末尾追加以下内容(相信你肯定已熟练掌握 Vim 使用啦)
export PATH=$PATH:/usr/local/git/bin

# 3. 回到终端, 刷新配置
source /etc/profile

# 4. 查看版本
git version 
# 输出 git version 2.35.1
1.3:docker安装gitLab

在这里插入图片描述

2:windows安装git

2.1:下载安装包

我们可以在gitforwindows上下载Git的安装包

Gitforwindows的URL为:https://gitforwindows.org/,其页面如下所示:

在这里插入图片描述

进入到该页面后,直接点击页面中的“Download”,即可开始下载git的安装包。

2.2:工具安装

在下载完成后,接下来我们就可以安装git了。双击下载好的安装包,接下来会进入到安装页面

在Windows终端中添加Git的bash配置:

在这里插入图片描述

选择Git的OpenSSH客户端可执行文件未知,在这里我们选择第一个,即使用Git自带的OpenSSH客户端:

在这里插入图片描述

在Git命令安装完成后,我们打开Windows命令行页面,执行命令:

在这里插入图片描述

二:git快速入门

1:git概述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2:git工作原理

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3:git常用操作

在这里插入图片描述

3.1:新建,管理远程仓库

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3.2:克隆,更新本地仓库副本

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3.3:上传本地修改

在这里插入图片描述

3.3.1:添加文件到缓冲区

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3.3.2:打包提交

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3.3.3:提交远程仓库

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

4:git工作流

Git 最核心的一个概念就是工作流

  • 工作区(Workspace) 是电脑中实际的目录。
  • 暂存区(Index) 类似于缓存区域,临时保存你的改动。
  • 仓库区(Repository),分为本地仓库和远程仓库。

从 SVN 切换到 Git,最难理解并且最不能理解的是暂存区和本地仓库。熟练使用 Git 后,会发现这简直是神设计,由于这两者的存在,使许多工作变得易管理。

通常提交代码分为几步:

  • git add 从工作区提交到暂存区
  • git commit 从暂存区提交到本地仓库
  • git pushgit svn dcommit 从本地仓库提交到远程仓库

在这里插入图片描述

三:git详细命令介绍

1:git仓库创建

1.1:git init

Git 使用 git init 命令来初始化一个 Git 仓库

Git 的很多命令都需要在 Git 的仓库中运行,所以 git init 是使用 Git 的第一个命令。

在执行完成 git init 命令后,Git 仓库会生成一个 .git 目录

该.git目录包含了资源的所有元数据,其他的项目目录保持不变。

如果要使用当前的目录作为仓库,只需要进行相应的初始化操作即可

git init

如果要使用指定的目录作为git仓库,就要指定对应的位置

git init newrepo

初始化后,会在 newrepo 目录下会出现一个名为 .git 的目录,所有 Git 需要的数据和资源都存放在这个目录中。

# 如果当前目录下有几个文件想要纳入版本控制
# 需要先用 git add 命令告诉 Git 开始对这些文件进行跟踪,然后提交:

$ git add *.java # 将所有的c文件都加入版本控制
$ git add README # 将readme加入版本控制
$ git commit -m '初始化项目版本' # 提交到本地仓库中

⚠️ 在 Linux 系统中,commit 信息使用单引号 ',Windows 系统,commit 信息使用双引号 "。所以:

  • 在 git bash 中 git commit -m ‘提交说明’ 这样是可以的
  • 在 Windows 命令行中就要使用双引号 git commit -m “提交说明”。
1.2:git clone

该指令的作用是从现有 Git 仓库中拷贝项目,克隆仓库的命令格式为:

git clone <repo>

如果我们需要克隆到指定的目录,可以使用以下命令格式:

git clone <repo> <directory> # repo => Git的仓库 directory => 本地目录

比如,要克隆 Ruby 语言的 Git 代码仓库 Grit,可以用下面的命令:

$ git clone git://github.com/schacon/grit.git

执行该命令后,会在当前目录下创建一个名为grit的目录

其中包含一个 .git 的目录,用于保存下载下来的所有版本记录。

如果要自己定义要新建的项目目录名称,可以在上面的命令末尾指定新的名字:

$ git clone git://github.com/schacon/grit.git mygrit

设置提交代码时的用户信息:

$ git config --global user.name "xxx"
$ git config --global user.email xxx # 如果去掉 --global 参数只对当前仓库有效。

2:git基本命令

2.1:创建仓库命令

下表列出了 git 创建仓库的命令:

命令说明
git init初始化仓库
git clone拷贝一份远程仓库,也就是下载一个项目。
2.2:提交与修改

Git 的工作就是创建和保存你的项目的快照及与之后的快照进行对比。

下表列出了有关创建与提交你的项目的快照的命令:

命令说明
git add添加文件到仓库
git status查看仓库当前的状态,显示有变更的文件。
git diff比较文件的不同,即暂存区和工作区的差异。
git commit提交暂存区到本地仓库。
git reset回退版本。
git rm删除工作区文件。
git mv移动或重命名工作区文件。
2.3:提交日志
命令说明
git log查看历史提交记录
git blame <file>以列表形式查看指定文件的历史修改记录
2.4:远程操作
命令说明
git remote远程仓库操作
git fetch从远程获取最新版本到本地,不会自动合并
git pull下载远程代码并合并,等价于git fetch + git merge
git merge从指定的commit(s)合并到当前分支,用来合并两个分支;
git push上传远程代码并合并
git cherry-pick"复制"一个提交节点并在当前分支做一次完全一样的新提交。
$ git merge -b  # 指将 b 分支合并到当前分支

3:git分支管理

创建分支命令:

git branch (branchname)

切换分支命令:

git checkout (branchname)
3.1:列出分支 git branch

列出分支基本命令:

git branch

没有参数时,git branch 会列出你在本地的分支。

$ git branch
* master
  • 此例的意思就是,我们有一个叫做 master 的分支,并且该分支是当前分支。

  • 当你执行 git init 的时候,默认情况下 Git 就会为你创建 master 分支。

如果我们要手动创建一个分支。执行 git branch branchname 即可。

$ git branch testing  # 新建一个testing分支

$ git branch # 查看所有的分支,其中 * 标注的是当前的分支
* master
  testing
3.2:切换分支 git checkout

当你以此方式在上次提交更新之后创建了新分支,如果后来又有更新提交, 然后又切换到了 testing 分支,Git 将还原你的工作目录到你创建分支时候的样子。

$ ls                            # 检查当前工作目录下的文件
README

$ echo 'runoob.com' > test.txt  # 新建一个test.txt文件并写入'runoob.com'
$ git add .                     # 添加到暂存区
$ git commit -m 'add test.txt'  # 提交到本地仓库
[master 3e92c19] add test.txt
 1 file changed, 1 insertion(+)
 create mode 100644 test.txt
 
$ ls                            # 检查当前工作目录下的文件,发现多了test.txt
README        test.txt

$ git checkout testing          # 切换到testing分支
Switched to branch 'testing'

$ ls                            # 检查当前工作目录下的文件,发现没有test.txt
README

$ git checkout master           # 切换到master分支
Switched to branch 'master'
$ ls                            # 检查当前工作目录下的文件,发现又出现了test.txt
README        test.txt

我们也可以使用 git checkout -b (branchname)命令来创建新分支并立即切换到该分支下,从而在该分支中操作。

$ git checkout -b newtest  # 创建新分支并立即切换到该分支下
Switched to a new branch 'newtest'

$ git rm test.txt 
rm 'test.txt'
$ ls
README

$ touch runoob.php
$ git add .
$ git commit -am 'removed test.txt、add runoob.php'
[newtest c1501a2] removed test.txt、add runoob.php
 2 files changed, 1 deletion(-)
 create mode 100644 runoob.php
 delete mode 100644 test.txt
 
$ ls
README        runoob.php

$ git checkout master  # 在master中还是原来的样子
Switched to branch 'master'
$ ls
README        test.txt

🎉 使用分支将工作切分开来,从而让我们能够在不同开发环境中做事,并来回切换。

3.3:删除分支git branch -d

删除分支命令:

git branch -d (branchname)

例如我们要删除 testing 分支:

$ git branch # 查看当前的所有的分支
* master
  testing
  
$ git branch -d testing # 删除testing分支
Deleted branch testing (was 85fc7e7).

$ git branch # 查看当前的所有的分支
* master
3.4:合并分支git merge

一旦某分支有了独立内容,你终究会希望将它合并回到你的主分支。

你可以使用以下命令将任何分支合并到当前分支中去:

$ git branch
* master
  newtest
  
$ ls
README        test.txt

$ git merge newtest # 将 newtest 分支合并到当前分支【标有*的那个分支】去,test.txt 文件被删除。
Updating 3e92c19..c1501a2
Fast-forward
 runoob.php | 0
 test.txt   | 1 -
 2 files changed, 1 deletion(-)
 create mode 100644 runoob.php
 delete mode 100644 test.txt
 
$ ls
README        runoob.php
  • 合并完后就可以删除分支:
$ git branch -d newtest
Deleted branch newtest (was c1501a2).
  • 删除后, 就只剩下 master 分支了:
$ git branch
* master
  • 使用git diff查看分支中文件的冲突,在修改完成冲突后,可以使用git add进行提交
$ git status -s
UU runoob.php
$ git add runoob.php
$ git status -s
M  runoob.php
$ git commit
[master 88afe0e] Merge branch 'change_site'

4:历史查看

Git 提交历史一般常用两个命令:

  • git log - 查看历史提交记录。

  • git blame <file> - 以列表形式查看指定文件的历史修改记录。

5:git沙盒

git沙盒网站:https://learngitbranching.js.org/?locale=zh_CN

四:Linux配置SVN

在这里插入图片描述

1:svn安装和版本库的创建

1.1:检查并安装
rpm -qa subversion
yum -y remove subversion # 移除旧版本

yum -y install subversion
svn --version # 安装完成后查看svn版本,如果可以正确显示版本说明安装成功
1.2:创建SVN和版本库
mkdir -p /home/svn/svnku
svnadmin create /home/svn/svnku # 在指定路径

创建后,进入svnku,里面目录如下

在这里插入图片描述

2:配置用户和权限(核心)

进入conf目录,发现里面有三个文件

在这里插入图片描述

2.1:设置有哪些用户名和密码
vi passwd

在这里插入图片描述

2.2:设置文件夹权限
vi auth

在这里插入图片描述
*表示其他,*=r表示其他人对于此目录只有读的权限

⚠️ !![]中的路径要有,否则拉取检出的时候会报错

2.3:服务配置
anon-access = none #禁止匿名用户访问
auth-access = write #授权用户可写
password-db = passwd #使用哪个文件作为账号文件
authz-db = authz #使用哪个文件作为权限文件
realm = /home/svn/svnku #认证空间名,版本库所在目录

在这里插入图片描述

2.4:服务启动,结束指令
svnserve -d -r /home/svn/svnku # 版本库的位置
ps -ef | grep svnserve # 可以查看服务的启动情况
# 对于服务的停止,可以使用kill命令强行杀死进程
kill -9 xxx # svnserve的进程号

开机自启动的设置

进入/etc/sysconfig 路径下修改svnserve文件为版本库路径

cd /etc/sysconfig # 进入/etc/sysconfig目录
vi svnserve # 进入svnserve文件准备进行修改

在这里插入图片描述

systemctl enable svnserve.service # svnserve.service生效
systemctl start svnserve.service # 启动
systemctl status svnserve.service # 查看状态

在这里插入图片描述
⚠️ 更新authz和password之后也要重启

systemctl stop svnserve.service # 停止
systemctl start svnserve.service # 启动
2.5:防火墙设置

由于svn的端口号是3690,所以需要对防火墙开放这个端口

# 开放指定的端口
firewall-cmd --zone=public --add-port=3690/tcp --permanent # 开放3690端口

firewall-cmd --reload # 重新加载,使得刚才的生效

# 或者可以直接禁用防火墙
systemctl stop firewalld.service #关闭firewall
systemctl disable firewalld.service #禁止firewall开机启动
2.6:检验是否成功

本地连接服务器的svn的指定版本库

svn://ip地址/版本库 

在这里插入图片描述
确定后弹出提示输入用户名密码的弹出框表示成功

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值