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 push
或git 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地址/版本库
确定后弹出提示输入用户名密码的弹出框表示成功