From 6d0804721b858108d8a644c807173609e2ed0755 Mon Sep 17 00:00:00 2001 From: Dichgrem Date: Fri, 15 Mar 2024 20:19:31 +0800 Subject: [PATCH] Initial commit --- content/git.md | 265 +++++++++++++++ public/archive/index.html | 10 + public/atom.xml | 20 ++ public/git/index.html | 303 ++++++++++++++++++ public/index.html | 69 ++-- public/page/2/index.html | 69 ++-- public/page/3/index.html | 68 ++-- public/page/4/index.html | 69 ++-- public/page/5/index.html | 69 ++-- public/page/6/index.html | 69 ++-- public/page/7/index.html | 35 ++ public/sitemap.xml | 7 + public/tags/git/index.html | 125 ++++++++ public/tags/index.html | 6 + public/talk-bios-uefi-mbr-gpt-grub/index.html | 7 + 15 files changed, 984 insertions(+), 207 deletions(-) create mode 100644 content/git.md create mode 100644 public/git/index.html create mode 100644 public/tags/git/index.html diff --git a/content/git.md b/content/git.md new file mode 100644 index 0000000..76b15d4 --- /dev/null +++ b/content/git.md @@ -0,0 +1,265 @@ ++++ +title = "Git使用简明手册" +date = 2024-03-15 + +[taxonomies] +tags = ["Git"] ++++ + + + +前言 Git,作为现代软件开发中不可或缺的版本控制工具,常常让初学者感到困惑。本文旨在介绍 Git 的全流程安装和基本使用,希望能够帮助新手更轻松地理解和掌握 Git 的基本概念和操作。 + +## 安装git + +Windows:[https://git-scm.com/download/](https://git-scm.com/download/) + +Archlinux:`sudo pacman -S git` + +安装完成后检查版本:`git --version` + +## 创建新仓库 + +如果你的目录不是一个 Git 仓库,你需要先初始化。 + +创建新文件夹,在你的项目目录中运行以下命令: +`git init` + +设置默认仓库为main,避免因为main/master名称不同的牛马问题: + +`git init --initial-branch=main` + +## 克隆仓库 + +执行如下命令以创建一个本地仓库的克隆版本: +`git clone /path/to/repository` +如果是远端服务器上的仓库,你的命令会是这个样子: +`git clone username@host:/path/to/repository` + +## 连接远程仓库 + +生成密钥: + +`ssh-keygen -t rsa -b 4096 -C "your_email@example.com"` + +可以生成多个不同名字的密钥: + +`ssh-keygen -t rsa -b 4096 -C "your_email@example.com" -f ~/.ssh/github_key1` + +`ssh-keygen -t rsa -b 4096 -C "your_email@example.com" -f ~/.ssh/github_key2` + +使用 `ssh-add` 命令将生成的密钥添加到 SSH 代理中。 + +`ssh-add ~/.ssh/github_key1` + +`ssh-add ~/.ssh/github_key2` + +在 `~/.ssh/config` 文件中配置不同的主机别名以及相应的密钥文件。编辑该文件并添加以下内容: + +`# GitHub repository 1` + +`Host github1` + + HostName github.com + + User git + + IdentityFile ~/.ssh/github_key1 + +`# GitHub repository 2` + +`Host github2` + + HostName github.com + + User git + + IdentityFile ~/.ssh/github_key2 + +连接到github: + +`ssh -T git@github.com` + +添加远程仓库: + +`git remote add origin ` + +比如我已经在 GitHub 上创建了一个名为 `dichos` 的仓库,你可以使用以下命令将其添加为远程仓库: + +`git remote add origin git@github.com:Dichgrem/dichos.git` + +设置远程仓库 + +`git remote set-url origin git@github.com:Dichgrem/dichos.git` + + + +## 工作流 + +本地仓库由 git 维护的三棵“树”组成。第一个是你的 `工作目录`,它持有实际文件;第二个是 `暂存区(Index)`,它像个缓存区域,临时保存你的改动;最后是 `HEAD`,它指向你最后一次提交的结果。 + +## 创建一个分支 + +`git branch main` + +这将创建一个名为 main 的分支。 + +## 删除分支 + +`git branch -d master` + +使用大写强制删除 + +`git branch -D master` + + + +## 添加和提交 + +你可以提出更改(把它们添加到暂存区),使用如下命令: +`git add ` +`git add *` +这是 git 基本工作流程的第一步;使用如下命令以实际提交改动: +`git commit -m "代码提交信息"`如: + +`git commit -m "Initial commit"` +现在,你的改动已经提交到了 **HEAD**,但是还没到你的远端仓库。 + +## 推送改动 + +你的改动现在已经在本地仓库的 **HEAD** 中了。执行如下命令以将这些改动提交到远端仓库: +`git push origin master` +可以把 *master* 换成你想要推送的任何分支。 + +如果你还没有克隆现有仓库,并欲将你的仓库连接到某个远程服务器,你可以使用如下命令添加: +`git remote add origin ` +如此你就能够将你的改动推送到所添加的服务器上去了。 + +## 合并分支 + +分支是用来将特性开发绝缘开来的。在你创建仓库的时候,*master* 是“默认的”分支。在其他分支上进行开发,完成后再将它们合并到主分支上。 + +创建一个叫做“feature_x”的分支,并切换过去: +`git checkout -b feature_x` +切换回主分支: +`git checkout master` +再把新建的分支删掉: +`git branch -d feature_x` +除非你将分支推送到远端仓库,不然该分支就是 *不为他人所见的*: +`git push origin ` + +## 更新与合并 + +要更新你的本地仓库至最新改动,执行: +`git pull` +以在你的工作目录中 ***获取**(fetch)* 并 ***合并**(merge)* 远端的改动。 +要合并其他分支到你的当前分支(例如 master),执行: +`git merge ` +在这两种情况下,git 都会尝试去自动合并改动。遗憾的是,这可能并非每次都成功,并可能出现_冲突(conflicts)*。 这时候就需要你修改这些文件来手动合并这些_冲突(conflicts)*。改完之后,你需要执行如下命令以将它们标记为合并成功: +`git add ` +在合并改动之前,你可以使用如下命令预览差异: +`git diff ` + +## 标签 + +为软件发布创建标签是推荐的。这个概念早已存在,在 SVN 中也有。你可以执行如下命令创建一个叫做 *1.0.0* 的标签: +`git tag 1.0.0 1b2e1d63ff` +*1b2e1d63ff* 是你想要标记的提交 ID 的前 10 位字符。可以使用下列命令获取提交 ID: +`git log` +你也可以使用少一点的提交 ID 前几位,只要它的指向具有唯一性。 + +## 日志 + +如果你想了解本地仓库的历史记录,最简单的命令就是使用: +`git log` +你可以添加一些参数来修改他的输出,从而得到自己想要的结果。 只看某一个人的提交记录: +`git log --author=bob` +一个压缩后的每一条提交记录只占一行的输出: +`git log --pretty=oneline` +或者你想通过 ASCII 艺术的树形结构来展示所有的分支, 每个分支都标示了他的名字和标签: +`git log --graph --oneline --decorate --all` +看看哪些文件改变了: +`git log --name-status` +这些只是你可以使用的参数中很小的一部分。更多的信息,参考: +`git log --help` + +## 替换本地改动 + +假如你操作失误(当然,这最好永远不要发生),你可以使用如下命令替换掉本地改动: +`git checkout -- ` +此命令会使用 HEAD 中的最新内容替换掉你的工作目录中的文件。已添加到暂存区的改动以及新文件都不会受到影响。 + +假如你想丢弃你在本地的所有改动与提交,可以到服务器上获取最新的版本历史,并将你本地主分支指向它: +`git fetch origin` +`git reset --hard origin/master` + + + +## 修改默认分支 + +git目前默认的主分支为master,和github默认分支main不同,这使得默认配置下git往往连接失败。可以通过下两种方法改变默认分支。在本地git init时将默认分支修改成main + +```csharp +1. git --version //查看版本 +2. git config --global init.defaultBranch main //将默认分支修改成main +3. git init //本地项目文件夹内创建.git文件夹 +4. git add . //添加到暂存区 +5. git commit -a [描述的内容] //记录修改行为 +6. git pull --rebase origin main //拉github上的readme.md +7. git push origin main //上传代码 +``` + +也可以不修改git上的默认分支,而是修改github上库的默认分支。 + +## Windows下git使用代理 + +由于网络环境的差异,Git连接github需要代理,或者全局模式。Git支持四种协议,而除本地传输外,还有:git://, ssh://, 基于HTTP协议,这些协议又被分为哑协议(HTTP协议)和智能传输协议。对于这些协议,要使用代理的设置也有些差异: + +- 使用 `git协议` 时,设置代理需要配置 `core.gitproxy` + +- 使用 `HTTP协议` 时,设置代理需要配置 `http.proxy` + +- 而使用 `ssh协议` 时,代理需要配置ssh的 `ProxyCommand` 参数 + +由于个人需求仅仅是HTTP的代理(相对来说,HTTP有比较好的通适性,Windows配置git/ssh比较棘手),设置的时候,只需要针对单个设置 `http.proxy` 即可,在需要使用代理的项目下面使用 `git bash` 如下命令进行设置(你的Uri和port可能和我的不同): + +`git config http.proxy` [http://127.0.0.1:2080](http://127.0.0.1:8088) `# 也可以是uri:port形式` + +这个是不需要鉴权的代理设置,如果需要鉴权,可能需要添加用户名密码信息: + +`git config http.proxy` [http://username:password@127.0.0.1:2080](http://username:password@127.0.0.1:8088) + +如果git的所有项目都需要启用代理,那么可以直接启用全局设置: + +`git config --global http.proxy` [http://127.0.0.1:2080](http://127.0.0.1:8088) + +为了确认是否已经设置成功,可以使用 `--get` 来获取: + +`git config --get --global http.proxy` + +这样可以看到你设置在global的 `http.proxy` 值。  + +需要修改的时候,再次按照上面的方法设置即可,git默认会覆盖原有的配置值。 + +当我们的网络出现变更时,可能需要删除掉原有的代理配置,此时需要使用 `--unset` 来进行配置: + +`git config --global --unset http.proxy` + +在命令之后,指定位置的设置值将会被清空,你可以再次使用 `--get` 来查看具体的设置情况。 + +如果使用了HTTPS,肯呢个会碰到HTTPS 证书错误的情况,比如提示: `SSL certificate problem` ,此时,可以尝试将 `sslVerify` 设置为 `false` : + +`git config --global http.sslVerify false` + +恩,到此,可以试试git来获取/更改项目了,此时,项目应该是使用代理来进行通讯的。 + +## 注意 + +- 不要多次使用不同的参数来设置代理,一般使用文中两种方式酌情选用即可, `--global` , `--system` , `--local` 各级设置后,可能会给自己带来不必要的麻烦。git默认是先到git Repository的配置文件中查找配置文件,如果没有才会到 `--global` 设置的文件中查找,因此,单个项目文件中的设置会覆盖 `--global` 的设置。 +- 使用 `--global` 来配置的信息保存在当前用户的根目录下的 `.config` 文件中,而仓库中的配置保存在项目仓库的根目录下的 `.git/config` 文件中。 +- 如果是Linux的用户,建议全局代理。 + + + + + diff --git a/public/archive/index.html b/public/archive/index.html index 93f8c83..fd026f1 100644 --- a/public/archive/index.html +++ b/public/archive/index.html @@ -79,6 +79,16 @@
  • + + + :: Git使用简明手册 + + + +
  • +
  • :: BIOS-UEFI-MBR-GPT-GRUB diff --git a/public/atom.xml b/public/atom.xml index 099e1a6..4e373bd 100644 --- a/public/atom.xml +++ b/public/atom.xml @@ -7,6 +7,26 @@ Zola 2024-03-15T00:00:00+00:00 https://blog.dich.ink/atom.xml + + Git使用简明手册 + 2024-03-15T00:00:00+00:00 + 2024-03-15T00:00:00+00:00 + + + + + Unknown + + + + + + https://blog.dich.ink/git/ + + <p>前言 Git,作为现代软件开发中不可或缺的版本控制工具,常常让初学者感到困惑。本文旨在介绍 Git 的全流程安装和基本使用,希望能够帮助新手更轻松地理解和掌握 Git 的基本概念和操作。</p> + + + BIOS-UEFI-MBR-GPT-GRUB 2024-03-15T00:00:00+00:00 diff --git a/public/git/index.html b/public/git/index.html new file mode 100644 index 0000000..f741107 --- /dev/null +++ b/public/git/index.html @@ -0,0 +1,303 @@ + + + + + Dich'blog + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + +
    + + + + + + + + +
    + + +
    + +
    + +

    Git使用简明手册

    + + + + + + +
    +

    前言 Git,作为现代软件开发中不可或缺的版本控制工具,常常让初学者感到困惑。本文旨在介绍 Git 的全流程安装和基本使用,希望能够帮助新手更轻松地理解和掌握 Git 的基本概念和操作。

    +

    安装git

    +

    Windows:https://git-scm.com/download/

    +

    Archlinux:sudo pacman -S git

    +

    安装完成后检查版本:git --version

    +

    创建新仓库

    +

    如果你的目录不是一个 Git 仓库,你需要先初始化。

    +

    创建新文件夹,在你的项目目录中运行以下命令:
    +git init

    +

    设置默认仓库为main,避免因为main/master名称不同的牛马问题:

    +

    git init --initial-branch=main

    +

    克隆仓库

    +

    执行如下命令以创建一个本地仓库的克隆版本:
    +git clone /path/to/repository
    +如果是远端服务器上的仓库,你的命令会是这个样子:
    +git clone username@host:/path/to/repository

    +

    连接远程仓库

    +

    生成密钥:

    +

    ssh-keygen -t rsa -b 4096 -C "your_email@example.com"

    +

    可以生成多个不同名字的密钥:

    +

    ssh-keygen -t rsa -b 4096 -C "your_email@example.com" -f ~/.ssh/github_key1

    +

    ssh-keygen -t rsa -b 4096 -C "your_email@example.com" -f ~/.ssh/github_key2

    +

    使用 ssh-add 命令将生成的密钥添加到 SSH 代理中。

    +

    ssh-add ~/.ssh/github_key1

    +

    ssh-add ~/.ssh/github_key2

    +

    ~/.ssh/config 文件中配置不同的主机别名以及相应的密钥文件。编辑该文件并添加以下内容:

    +

    # GitHub repository 1

    +

    Host github1

    +
    HostName github.com
    +
    +User git
    +
    +IdentityFile ~/.ssh/github_key1
    +
    +

    # GitHub repository 2

    +

    Host github2

    +
    HostName github.com
    +
    +User git
    +
    +IdentityFile ~/.ssh/github_key2
    +
    +

    连接到github:

    +

    ssh -T git@github.com

    +

    添加远程仓库:

    +

    git remote add origin <remote_repository_url>

    +

    比如我已经在 GitHub 上创建了一个名为 dichos 的仓库,你可以使用以下命令将其添加为远程仓库:

    +

    git remote add origin git@github.com:Dichgrem/dichos.git

    +

    设置远程仓库

    +

    git remote set-url origin git@github.com:Dichgrem/dichos.git

    +

    工作流

    +

    本地仓库由 git 维护的三棵“树”组成。第一个是你的 工作目录,它持有实际文件;第二个是 暂存区(Index),它像个缓存区域,临时保存你的改动;最后是 HEAD,它指向你最后一次提交的结果。

    +

    创建一个分支

    +

    git branch main

    +

    这将创建一个名为 main 的分支。

    +

    删除分支

    +

    git branch -d master

    +

    使用大写强制删除

    +

    git branch -D master

    +

    添加和提交

    +

    你可以提出更改(把它们添加到暂存区),使用如下命令:
    +git add <filename>
    +git add *
    +这是 git 基本工作流程的第一步;使用如下命令以实际提交改动:
    +git commit -m "代码提交信息"如:

    +

    git commit -m "Initial commit"
    +现在,你的改动已经提交到了 HEAD,但是还没到你的远端仓库。

    +

    推送改动

    +

    你的改动现在已经在本地仓库的 HEAD 中了。执行如下命令以将这些改动提交到远端仓库:
    +git push origin master
    +可以把 master 换成你想要推送的任何分支。

    +

    如果你还没有克隆现有仓库,并欲将你的仓库连接到某个远程服务器,你可以使用如下命令添加:
    +git remote add origin <server>
    +如此你就能够将你的改动推送到所添加的服务器上去了。

    +

    合并分支

    +

    分支是用来将特性开发绝缘开来的。在你创建仓库的时候,master 是“默认的”分支。在其他分支上进行开发,完成后再将它们合并到主分支上。

    +

    创建一个叫做“feature_x”的分支,并切换过去:
    +git checkout -b feature_x
    +切换回主分支:
    +git checkout master
    +再把新建的分支删掉:
    +git branch -d feature_x
    +除非你将分支推送到远端仓库,不然该分支就是 不为他人所见的
    +git push origin <branch>

    +

    更新与合并

    +

    要更新你的本地仓库至最新改动,执行:
    +git pull
    +以在你的工作目录中 获取(fetch)合并(merge) 远端的改动。
    +要合并其他分支到你的当前分支(例如 master),执行:
    +git merge <branch>
    +在这两种情况下,git 都会尝试去自动合并改动。遗憾的是,这可能并非每次都成功,并可能出现_冲突(conflicts)。 这时候就需要你修改这些文件来手动合并这些_冲突(conflicts)。改完之后,你需要执行如下命令以将它们标记为合并成功:
    +git add <filename>
    +在合并改动之前,你可以使用如下命令预览差异:
    +git diff <source_branch> <target_branch>

    +

    标签

    +

    为软件发布创建标签是推荐的。这个概念早已存在,在 SVN 中也有。你可以执行如下命令创建一个叫做 1.0.0 的标签:
    +git tag 1.0.0 1b2e1d63ff
    +1b2e1d63ff 是你想要标记的提交 ID 的前 10 位字符。可以使用下列命令获取提交 ID:
    +git log
    +你也可以使用少一点的提交 ID 前几位,只要它的指向具有唯一性。

    +

    日志

    +

    如果你想了解本地仓库的历史记录,最简单的命令就是使用:
    +git log
    +你可以添加一些参数来修改他的输出,从而得到自己想要的结果。 只看某一个人的提交记录:
    +git log --author=bob
    +一个压缩后的每一条提交记录只占一行的输出:
    +git log --pretty=oneline
    +或者你想通过 ASCII 艺术的树形结构来展示所有的分支, 每个分支都标示了他的名字和标签:
    +git log --graph --oneline --decorate --all
    +看看哪些文件改变了:
    +git log --name-status
    +这些只是你可以使用的参数中很小的一部分。更多的信息,参考:
    +git log --help

    +

    替换本地改动

    +

    假如你操作失误(当然,这最好永远不要发生),你可以使用如下命令替换掉本地改动:
    +git checkout -- <filename>
    +此命令会使用 HEAD 中的最新内容替换掉你的工作目录中的文件。已添加到暂存区的改动以及新文件都不会受到影响。

    +

    假如你想丢弃你在本地的所有改动与提交,可以到服务器上获取最新的版本历史,并将你本地主分支指向它:
    +git fetch origin
    +git reset --hard origin/master

    +

    修改默认分支

    +

    git目前默认的主分支为master,和github默认分支main不同,这使得默认配置下git往往连接失败。可以通过下两种方法改变默认分支。在本地git init时将默认分支修改成main

    +
    1. git --version  //查看版本
    +2. git config --global init.defaultBranch main  //将默认分支修改成main
    +3. git init //本地项目文件夹内创建.git文件夹
    +4. git add . //添加到暂存区
    +5. git commit -a [描述的内容]  //记录修改行为
    +6. git pull --rebase origin main  //拉github上的readme.md
    +7. git push origin main   //上传代码
    +
    +

    也可以不修改git上的默认分支,而是修改github上库的默认分支。

    +

    Windows下git使用代理

    +

    由于网络环境的差异,Git连接github需要代理,或者全局模式。Git支持四种协议,而除本地传输外,还有:git://, ssh://, 基于HTTP协议,这些协议又被分为哑协议(HTTP协议)和智能传输协议。对于这些协议,要使用代理的设置也有些差异:

    +
      +
    • +

      使用 git协议 时,设置代理需要配置 core.gitproxy

      +
    • +
    • +

      使用 HTTP协议 时,设置代理需要配置 http.proxy

      +
    • +
    • +

      而使用 ssh协议 时,代理需要配置ssh的 ProxyCommand 参数

      +
    • +
    +

    由于个人需求仅仅是HTTP的代理(相对来说,HTTP有比较好的通适性,Windows配置git/ssh比较棘手),设置的时候,只需要针对单个设置 http.proxy 即可,在需要使用代理的项目下面使用 git bash 如下命令进行设置(你的Uri和port可能和我的不同):

    +

    git config http.proxy http://127.0.0.1:2080 # 也可以是uri:port形式

    +

    这个是不需要鉴权的代理设置,如果需要鉴权,可能需要添加用户名密码信息:

    +

    git config http.proxy http://username:password@127.0.0.1:2080

    +

    如果git的所有项目都需要启用代理,那么可以直接启用全局设置:

    +

    git config --global http.proxy http://127.0.0.1:2080

    +

    为了确认是否已经设置成功,可以使用 --get 来获取:

    +

    git config --get --global http.proxy

    +

    这样可以看到你设置在global的 http.proxy 值。 

    +

    需要修改的时候,再次按照上面的方法设置即可,git默认会覆盖原有的配置值。

    +

    当我们的网络出现变更时,可能需要删除掉原有的代理配置,此时需要使用 --unset 来进行配置:

    +

    git config --global --unset http.proxy

    +

    在命令之后,指定位置的设置值将会被清空,你可以再次使用 --get 来查看具体的设置情况。

    +

    如果使用了HTTPS,肯呢个会碰到HTTPS 证书错误的情况,比如提示: SSL certificate problem ,此时,可以尝试将 sslVerify 设置为 false

    +

    git config --global http.sslVerify false

    +

    恩,到此,可以试试git来获取/更改项目了,此时,项目应该是使用代理来进行通讯的。

    +

    注意

    +
      +
    • 不要多次使用不同的参数来设置代理,一般使用文中两种方式酌情选用即可, --global--system--local 各级设置后,可能会给自己带来不必要的麻烦。git默认是先到git Repository的配置文件中查找配置文件,如果没有才会到 --global 设置的文件中查找,因此,单个项目文件中的设置会覆盖 --global 的设置。
    • +
    • 使用 --global 来配置的信息保存在当前用户的根目录下的 .config 文件中,而仓库中的配置保存在项目仓库的根目录下的 .git/config 文件中。
    • +
    • 如果是Linux的用户,建议全局代理。
    • +
    + +
    + + + + +
    + +
    + + +
    + +
    + + +
    + + + diff --git a/public/index.html b/public/index.html index 450cb39..cc3bed1 100644 --- a/public/index.html +++ b/public/index.html @@ -76,6 +76,40 @@
    +

    Git使用简明手册

    + + + + + + + + +
    +

    前言 Git,作为现代软件开发中不可或缺的版本控制工具,常常让初学者感到困惑。本文旨在介绍 Git 的全流程安装和基本使用,希望能够帮助新手更轻松地理解和掌握 Git 的基本概念和操作。

    + +
    + + + +
    + +
    +

    BIOS-UEFI-MBR-GPT-GRUB

    -
    - -
    - -

    Personal Blog

    - - - - - - - - -
    -

    前言 个人博客的搭建有诸多框架的选择。本文以Zola框架为例,介绍如何部署该静态站点,并将其托管到Paas平台上。

    - -
    - - -
  • +
  • + + Git (1 post) + +
  • +
  • GRUB (1 post) diff --git a/public/talk-bios-uefi-mbr-gpt-grub/index.html b/public/talk-bios-uefi-mbr-gpt-grub/index.html index 7148e9f..1a39a78 100644 --- a/public/talk-bios-uefi-mbr-gpt-grub/index.html +++ b/public/talk-bios-uefi-mbr-gpt-grub/index.html @@ -184,6 +184,13 @@ + + + + Git使用简明手册  + + +