本仓库用于维护水杉码园的使用说明,帮助刚来到水杉码园的用户更好的上手如何使用水杉码园进行协作开发与代码存储。
Non puoi selezionare più di 25 argomenti Gli argomenti devono iniziare con una lettera o un numero, possono includere trattini ('-') e possono essere lunghi fino a 35 caratteri.

397 righe
11 KiB

  1. # 水杉码园学生使用手册(进阶版)
  2. [toc]
  3. ## 一、前言
  4. 水杉码园是一个代码托管与协作平台,利用开源项目Gitea进行搭建,运行快速、使用体验良好,支持跨平台以及多种功能。
  5. 通过对开源平台Gitea的深度定制,让教育与项目协作相结合,更符合学校的教学场景,更有利于教师和学生的课外互动、学生与学生的作业协作;让教育与激励相结合,调动学生的参与热情,科学公正地评判平时成绩;让教育与数据相结合,从学生出发到学生中去,通过自有平台的数据采集与分析,重新审视现有的教育模式,更好地解决教育问题。
  6. 本文主要介绍如何在VSCode中集成使用Git,以及如何在仓库托管平台上进行代码托管与协作。
  7. ## 二、Git
  8. **1、Git是什么**
  9. Git是一个版本控制系统工具,它可以帮你管理项目,记录每一次提交的变化,以方便你在发生错误时进行回滚。它几乎所有的控制操作都可以在本地执行,不需要网络开销的好处是Git的操作十分迅速。
  10. **2、安装Git**
  11. 访问 https://git-scm.com/downloads ,根据自己的机器平台下载合适的安装包后进行安装。
  12. **3、添加到Path**
  13. 打开终端,输入git并回车。如果有git信息,则说明已经将git添加到path中,否则请找到git安装位置,然后添加到你系统的path中。各系统方式不同,请自行查阅资料。
  14. 正常情况下的反应如下:
  15. ![git1](image/git1.png)
  16. **4、详细Git教程**
  17. 参考:https://www.liaoxuefeng.com/wiki/896043488029600/
  18. **5、Git命令简介**
  19. ① 创建仓库
  20. `$ git init`
  21. 这会将当前目录创建为一个仓库,并产生一个新的名为.git的文件夹,其中存储着版本控制信息,我们不需要去在意里面具体是什么。这样,我们就创建好了一个空的仓库。
  22. ② 添加文件并查看仓库
  23. 现在让我们尝试在我们新的空仓库(就是你创建的文件夹下)中添加一个新的文件,可以是一个word,可以是一份c语言源文件,其他什么文件都可以。当你添加了一个文件后,我们使用下面的命令去查看当前的仓库情况:
  24. `$ git status`
  25. 终端会显示出你目前在master分支上还没有过提交,并且有一个文件还未被git追踪。
  26. ![](image/git8.png)
  27. ③ 追踪、提交文件
  28. 接着我们使用下面命令去追踪文件:
  29. `$ git add .`
  30. 注意add后面这个点不要漏了,这代表加入所有未被追踪的文件到git中。然后使用下面的命令去提交我们这次文件改动,顺带写上一些信息表示我们这次提交的主要内容。
  31. `$ git commit -m "my first file"`
  32. 注意使用选项-m去加上提交的信息,如果直接使用git commit会调用编辑器让你继续输入你这次提交的主要信息。
  33. ④ 查看分支
  34. 紧接着,你可以在终端中输入如下命令查看分支:
  35. `$ git branch`
  36. 结果应该如下图所示:
  37. ![](image/git9.png)
  38. 注意,如果你发现没有任何输出,那就说明上面的commit操作你还没成功,因为我们刚刚创建的仓库是空的,在Git中分支必须指向一个commit。如果还没有commit任何文件,那么就看不到分支。当我们第一次提交后就会自动将master分支作为我们的主要分支,指向你的第一次提交。然后你再使用一次git branch命令就能查看分支,并且分支名字前面带*的就是当前所处的分支。
  39. ⑤ 创建并切换分支
  40. Master分支一般更多是用来保存完整的项目内容,当你进行开发或者修改bug的时候应该切换到新的分支进行开发工作。你可以使用下面命令创建一个新的分支:
  41. `$ git branch dev`
  42. 这样,你就创建了一个名为dev的分支。
  43. 你可以使用下面命令切换分支:
  44. `$ git checkout dev`
  45. 这样你就切换回了master分支。你也可以把这两步操作合并一下,用这个命令:
  46. `$ git checkout -b dev`
  47. 这样你就会创建dev分支然后切换过去。
  48. **6、常用Git命令**
  49. - **新建代码库**
  50. ```shell
  51. # 在当前目录新建一个Git代码库
  52. $ git init
  53. # 新建一个目录,将其初始化为Git代码库
  54. $ git init [project-name]
  55. # 下载一个项目和它的整个代码历史
  56. $ git clone [url]
  57. ```
  58. - **配置**
  59. ```shell
  60. # 显示当前的Git配置
  61. $ git config --list
  62. # 编辑Git配置文件
  63. $ git config -e [--global]
  64. # 设置提交代码时的用户信息
  65. $ git config [--global] user.name "[name]"
  66. $ git config [--global] user.email "[email address]"
  67. ```
  68. - **增加/删除文件**
  69. ```shell
  70. # 添加指定文件到暂存区
  71. $ git add [file1] [file2] ...
  72. # 添加指定目录到暂存区,包括子目录
  73. $ git add [dir]
  74. # 添加当前目录的所有文件到暂存区
  75. $ git add .
  76. # 添加每个变化前,都会要求确认
  77. # 对于同一个文件的多处变化,可以实现分次提交
  78. $ git add -p
  79. # 删除工作区文件,并且将这次删除放入暂存区
  80. $ git rm [file1] [file2] ...
  81. # 停止追踪指定文件,但该文件会保留在工作区
  82. $ git rm --cached [file]
  83. # 改名文件,并且将这个改名放入暂存区
  84. $ git mv [file-original] [file-renamed]
  85. ```
  86. - **代码提交**
  87. ```shell
  88. # 提交暂存区到仓库区
  89. $ git commit -m [message]
  90. # 提交暂存区的指定文件到仓库区
  91. $ git commit [file1] [file2] ... -m [message]
  92. ```
  93. - **分支**
  94. ```shell
  95. # 列出所有本地分支
  96. $ git branch
  97. # 列出所有远程分支
  98. $ git branch -r
  99. # 列出所有本地分支和远程分支
  100. $ git branch -a
  101. # 新建一个分支,但依然停留在当前分支
  102. $ git branch [branch-name]
  103. # 新建一个分支,并切换到该分支
  104. $ git checkout -b [branch]
  105. # 切换到指定分支,并更新工作区
  106. $ git checkout [branch-name]
  107. # 建立追踪关系,在现有分支与指定的远程分支之间
  108. $ git branch --set-upstream [branch] [remote-branch]
  109. # 合并指定分支到当前分支
  110. $ git merge [branch]
  111. ```
  112. - **远程同步**
  113. ```shell
  114. # 下载远程仓库的所有变动
  115. $ git fetch [remote]
  116. # 显示所有远程仓库
  117. $ git remote -v
  118. # 显示某个远程仓库的信息
  119. $ git remote show [remote]
  120. # 增加一个新的远程仓库,并命名
  121. $ git remote add [shortname] [url]
  122. # 取回远程仓库的变化,并与本地分支合并
  123. $ git pull [remote] [branch]
  124. # 上传本地指定分支到远程仓库
  125. $ git push [remote] [branch]
  126. # 强行推送当前分支到远程仓库,即使有冲突
  127. $ git push [remote] --force
  128. # 推送所有分支到远程仓库
  129. $ git push [remote] --all
  130. ```
  131. ## 三、Visual Studio Code
  132. 1、安装VSCode
  133. 访问 https://code.visualstudio.com/Download 下载符合您机器平台的安装包后进行安装。
  134. 2、界面介绍
  135. VSCode打开后的界面如下图所示:
  136. ![VSCode 主界面](image/vscode.png)
  137. A区是侧边活动栏,B区是底部栏,C区是编辑区域,D区是面板区域,E区是状态栏,当然顶部还有一个菜单栏。VSCode区域划分的非常友好,对文件进行编辑的同时也可以在面板区域中查看终端的输出信息等。
  138. 3、插件介绍
  139. 能够让VSCode火爆的原因就是它拥有庞大的插件库,在A区的活动栏中选择插件活动,就可以在市场中搜索你想要的插件。它可以帮你实现代码高亮、自动补全、格式校验等功能,对编辑代码有着非常好的帮助。
  140. ## 四、Git SSH配置
  141. 使用SSH的方式拉取仓库中的代码或资料需要进行如下配置,使用HTTP的方式拉取仓库中的代码或资料可以本章节的配置。
  142. 两种方式的主要区别在于git clone时使用的URL不同。
  143. ![image-20210306195002341](image/image-20210306195002341.png)
  144. 1、查看邮箱,并配置Git信息
  145. 登录水杉码园,单击水杉码园首页右上角的头像,单击“个人信息”。
  146. ![](image/gitea2.png)
  147. 查看你水杉码园账户的对应邮箱,等下要用。
  148. ![](image/gitea3.png)
  149. 打开终端,输入以下命令用以设置你本地git的姓名和邮箱信息。请确保邮箱和刚刚水杉码园中查看到的邮箱相同。
  150. `$ git config --global user.name "Your Name"`
  151. `$ git config --global user.email yourmail@example.com`
  152. 设置完后可以通过下面命令查看姓名和邮箱:
  153. `$ git config user.name`
  154. `$ git config user.email`
  155. 正常情况下的输出如图所示:
  156. ![](image/git2.png)
  157. 2、在本地(你的笔记本电脑)生成SSH密钥
  158. 在命令行输入ssh-keygen -t rsa -C ‘你的邮箱地址’后回车,如下:
  159. ![](image/git3.png)
  160. 红框中是提示你要将密钥存放在哪里,括号里的是默认的存放路径,请记住这个路径,我们之后需要这个路径找到密钥。
  161. 接着直接按回车,如果你之前也按照默认的路径生成过SSH密钥,会出现如下图中的情况,询问你是否要覆盖。
  162. ![](image/git4.png)
  163. 输入y覆盖原有的密钥,或者之前没有生成过密钥,就会出现如下图中情况:
  164. ![](image/git5.png)
  165. 直接回车不用管,如下:
  166. ![](image/git6.png)
  167. 直接回车不用管,之后如下:
  168. ![](image/git7.png)
  169. 可以看到你的密钥已经创建成功。
  170. 3、上传密钥到水杉码园
  171. 登陆水杉码园后,在右上角头像的下拉框中点击设置
  172. ![](image/gitea4.png)
  173. 在标签中选择SSH/GPG密钥
  174. ![](image/gitea5.png)
  175. 在管理SSH密钥卡片右侧点击增加密钥
  176. ![](image/gitea6.png)
  177. 打开你的id_rsa.pub文件,将里面所有的内容复制到密钥内容一栏中,然后给这个密钥取一个名字,比如:我的MacBook。点击绿色的增加密钥按钮后,就成功添加了SSH密钥。
  178. ![](image/gitea7.png)
  179. 4、新建远程仓库
  180. 点击头像边上的加号,接着点击创建仓库
  181. ![](image/gitea8.png)
  182. 为仓库取一个名字后点击下面的创建仓库按钮,就可以正常创建仓库了,如果你不想让别人看到你的仓库内容,记得设置你的仓库为私有。
  183. ![](image/gitea9.png)
  184. 5、你的仓库SSH地址
  185. 当你创建完仓库后,你会跳转到仓库的主页,如下图所示:
  186. ![](image/gitea10.png)
  187. 上图红框中,选择SSH,就可以看到你仓库的SSH地址,这个之后会用到。
  188. ## 五、VS Code集成Git使用
  189. 1、拉取仓库
  190. 打开VSCode,在左边选择git活动。
  191. ![](image/vscode2.png)
  192. 点击上图红框中的按钮,然后在弹出的框中复制你刚才仓库的SSH地址,然后回车。
  193. ![](image/vscode3.png)
  194. 选择仓库的存放地址,即可将仓库拉取到本地。接着右下角会弹出一个是否打开该仓库的提示,点击open打开该仓库。
  195. 2、修改仓库文件
  196. 你可以随意修改仓库文件,只要添加了一些新的文件或者有了一些新的修改即可。
  197. ![](image/vscode4.png)
  198. 我们添加了两个源文件用于进行接下去的步骤
  199. 3、暂存修改的文件
  200. 按下图进行操作,这会将你所有的修改放入暂存区
  201. ![](image/vscode5.png)
  202. 4、提交暂存的文件
  203. 按下图进行操作,将暂存区的修改文件进行提交。这不是提交到远程仓库,是提交到本地git,产生一个新的commit。
  204. ![](image/vscode6.png)
  205. 紧接着,在弹出的框中,输入你这次提交的备注信息,用于说明你这次commit主要的内容是什么。
  206. ![](image/vscode7.png)
  207. 5、推送到水杉码园远程仓库
  208. ![](image/vscode8.png)
  209. 即可正确推送到水杉码园。
  210. 6、切换分支
  211. 通常我们不是只在一个分支上开发,master分支用来存放当前开发的稳定分支。可以按照下图产生并切换到新分支。
  212. ![](image/vscode9.png)