• day-2 如何搭建一个github代码库


      最近在听尤瓦尔·赫拉利代写的两本书《人类简史》和《未来简史》两本书评,一部描述人类从哪里来,一部描述人类将往哪里去,书中阐述以前我们经历的饥饿、疾病和战争已经渐渐逝去,未来我们所追求的,也是我们不敢想象的:长生不死、幸福快乐和化身为神。书中阐述:在未来技术将让99%的人变得无用,少数人升级为超人甚至人神。

      再想想自己,会不会就是这99%中的一员,莫名有一丝丝焦虑。三年没碰代码,作为一个IT男,实在不好意思跟别人说我是搞IT的,趁人未30,赶紧武装下自己也许还来得及。
      和一些前辈沟通,要成为一个菜鸟级码农,首先得有点自己的逼格,比如有个代码库啥的,普遍推荐github,花了一个晚上时间,汇总记录下来。

    1、Git和GitHub的区别

      Git是一个分布式的版本控制系统,与SVN类似;最初由Linus Torvalds编写,用作Linux内核代码的管理。在推出后,Git在其它项目中也取得了很大成功,尤其是在Ruby社区中,所以目前有很多著名的项目都使用Git进行版本控制;

      而GitHub是托管各种git库,并提供一个web界面的一个网站(官方地址是https://www.github.com/),可以通过本地的git客户端将自己的代码上传至GitHub;可以在GitHub上建立公共库,作为开源软件或个人使用,也可以付费建立私有库,这样就可以作为公司内部软件的代码管理工具;

    2、GitHub术语解析

     1 Blame
     2 Git中的“blame”特性描述了文件的每一行的最近一次修改信息,包括修改内容、作者和时间等;可用于追踪某软件新特性的添加及引起bug的提交操作;
     3 Repository
     4 库是GitHub的最基本元素,可想象成本地的项目文件夹;一个库包含所有的项目文件(包括帮助文档),并保存每个文件的修改历史;库可以有多个合作开发者,也可以作为公共库或私有库的形式开发;
     5 Private Repository
     6 私有库,是指只能被库的创建者或者合作开发者查看并编辑的库,需要付费使用;
     7 Branch
     8 分支是一个库的并行版本,包含在库内,允许独立的开发而不影响现有主分支(primary or master)的运行;当在分支的修改需要发布时,就可以将分支合并(merge)至主分支(master branch),这样利于多人的分布式开发;
     9 ==============================术语分类解析分割线==================================
    10 Pull Request
    11 即代码合并请求,由其它开发者或用户向项目的collaborators提议的修改请求,collaborators觉得修改信息合理有效即接受,否则拒绝;
    12 Merge
    13 将一个分支中的修改内容应用到另一个分支的操作就做合并;若两个分支内的修改内容无冲突,则可以通过合并请求(a Pull Request)或命令行(the command line)完成合并操作;
    14 Clone
    15 克隆,是将GitHub上的库文件整个复制到本地主机上,可以实现离线修改,等上线后再同步至Github上的库即可;
    16 Commit
    17 提交信息,或者称为修改信息,是个人提交的对文件的修改记录;
    18 Fork
    19 对其它开发者的库的个人复制,复制的库存在你自己的账户上,你可以自行修改项目内容而不会影响原始的库,也可以将自己的修改通过合并请求(a pull request)的方式请求原始库的开发者更新你的修改;
    20 Fetch
    21 取回,表示从在线的库上获取最新的修改信息而不需要合并代码,取回的代码可以与你本地的分支代码进行比较;
    22 Push
    23 推送,表示将本地的修改内容推送至线上的库,这样其它的开发者就可以通过GitHub网站访问到你的修改内容了;
    24 Remote
    25 远端版本,即类似于GitHub.com的非本地主机的项目版本,可以连接至本地克隆的版本以实现内容同步;
    26 ==============================术语分类解析分割线==================================
    27 User
    28 用户,指个人注册的GitHub账户,每个用户都可以拥有多个公共库或私有库,也可被邀请加入organizations或称为collaborates;
    29 SSH Key
    30 私钥,是GitHub用以验证你本地主机的身份的,并用此密钥加密传输GitHub网站和你本地主机的数据传输,以保证安全性;这个是需要在“Set up Git”步骤中配置的;
    31 Organizations
    32 组织,即多个开发者组成的团体,可包含众多的库和开发团队;
    33 Collaborator
    34 合作开发者,被库的所有者邀请共同开发某一项目,拥有对库的读写权限;
    35 Contributor
    36 贡献者,对项目有所贡献(如提交代码,修复bug等)的开发者,但不具备合作开发者的访问权限;
    37 ==============================术语分类解析分割线==================================
    38 Diff
    39 差异,指2个commit或保存的改变间的差异,可以很直观的看出一个文件自上次commit后增加或删除的内容;
    40 Open Source
    41 开源,原指可自由使用、修改和传播的软件,现扩展为一种超越软件的合作哲学,即工件(working materials)在线可用,可被任何人复制(fork)、修改(modify)、讨论(discuss)、并提出修改意见(contribute to);
    42 Markdown
    43 一种轻量级的标记语言,书写简单,不同于html,无需大量的<tag>就可以实现内容的格式化;GitHub上的众多库中的帮助文档就是这种格式,如README.md;
    44 Upstream
    45 上游,对于一个branch或者fork来说,源库的主分支即是其它修改信息的源头,被称为upstream,相对的其它branch或fork就被称为downstream了;
    View Code

     3、如何本地搭建一个github库

    1、注册账户和下载客户端
    https://github.com/join

    2、配置Git和配置SSH key

    ssh-keygen -t rsa -C "594796557@qq.com"
    ssh -T git@github.com

    cat /c/users/Administrator/.ssh/id_rsa.pub

    git config --global user.name "Toby2019"
    git config --global user.email "594796557@qq.com"
    cd d:/github/python_study/

    3、拷贝代码到d:/github/python_study/目录

    4、上传代码到主分支master
    git remote add origin git@github.com:Toby2019/python_study.git
    git add *
    git commit -m "first commit"
    git push origin master

     

    其它参考命令:
    1、切换到主分支
    git checkout master
    2、更新本地仓库至最新改动
    git pull
    3、合并分支
    git merge <branch>
    4、预览分支差异
    git diff <source_branch> <target_branch>
    5、添加标签
    git tag 1.0.0 1b2e1d63ff
    6、查看历史提交记录
    git log --oneline --abbrev-commit --all --graph --decorate --color
    7、丢弃本地所有改动与提交,获取服务器最新版本
    git fetch origin
    git reset --hard origin/master

    参考链接:

    http://www.cnblogs.com/xiaocen/p/3727324.html

    http://www.runoob.com/w3cnote/git-guide.html

  • 相关阅读:
    80后
    搞了 2 周性能优化,QPS 终于翻倍了!
    Spring Boot 实现各种参数校验,写得太好了,建议收藏!
    为什么编程语言社区没那么多初创公司呢?
    利用 Fastjson 注入 Spring 内存马,太秀了~!
    44 个神仙注释,太有才了……
    MySQL 中的 INSERT 是怎么加锁的?
    接了个变态需求:生成 Excel + PDF 导出,用 Java 怎么实现?
    重磅!Spring Boot 2.6 正式发布,一大波新特性,看完我彻底躺平了。。
    安装php xdebug扩展
  • 原文地址:https://www.cnblogs.com/python-frog/p/8635663.html
Copyright © 2020-2023  润新知