mac配置

来源:互联网 发布:软件著作权律师 编辑:程序博客网 时间:2024/05/17 04:21



1、homebrew
     在终端命令terminal中输入
    ruby -e "$(curl --insecure -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
    按照提示输入Enter 以及密码
如果此时网速不稳定可能会出现错误提示:curl: (35) Server aborted the SSL handshake。
此时需要执行卸载操作,输入如下命令进行卸载:
ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/uninstall)"

卸载完成后再次尝试安装。输入命令brew进行测试

2、Git安装

下载Git有两种方法

  • 直接下载安装包,Git下载地址
  • 用homebrew指令下载,不过首先需要安装homebrew 
    • 在终端执行后面指令安装,homebrew /usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
    • 完成后,使用以后指令安装Git,brew install git

安装好git后,配置用户名和用户邮箱,以后每次与Git的交互都会使用该信息。

git config --global user.name "your_name"  

git config --global user.email "your_email@gmail.com"

  • 1
  • 2
  • 1
  • 2

配置信息可以更改,以后想要更改使用上面指令就可以。同时可以使用git config --list指令查看Git的配置信息。

Git默认是大小写不敏感的,也就是说,将一个文件名某个字母做了大小写转换的修改Git是忽略这个改动的,导致在同步代码时候会出现错误,所以建议大小把Git设置成大小写敏感。

git config core.ignorecasefalse

  • 1
  • 1

生成密钥

Git关联远端仓库时候需要提供公钥,本地保存私钥,每次与远端仓库交互时候,远端仓库会用公钥来验证交互者身份。使用以下指令生成密钥。

ssh-keygen -t rsa -C "your_email@youremail.com"

生成密钥后,在本地的/Users/当前电脑用户/.ssh目录下会生成两个文件id_rsaid_rsa.pubid_rsa文件保存的是私钥,保存于本地,id_rsa.pub文件保存的是公钥,需要将里面内容上传到远端仓库。

获取公钥字符串具体操作如下图。


图-1 获取公钥
  • 输入cd指令,进入当前用户目录
  • 输入ls -a指令,查看当前用户目录下所有文件,包括隐藏文件
  • 输入cd .ssh指令,进入.ssh目录
  • 输入ls指令,查看.ssh目录下的文件
  • 输入cat id_rsa.pub指令,查看id_rsa.pub文件中内容

远端仓库添加密钥

以GitHub为例子,向远端仓库添加公钥,上面已经获取到了公钥,只需要将公钥添加到远端仓库就可以了。


图-1 添加公钥

在个人设置页面,左边选中SSH and GPG keys,在右边添加公钥,title是key的名称,可以随便取,可更改,key是上面我们获取到的公钥,填写完毕后点击add SSH key按钮,这样远端就添加到了密钥。

本地关联远端仓库

  • 在本地文件夹下面执行git init指令,初始化文件夹,作为本地的一个仓库。
  • 执行git remote add origin 仓库的ssh链接
  • 执行git pull指令,将远端代码拉取到本地

执行完毕后,远端仓库代码已经同步到了本地。

常用Git指令

  • 初始化配置

    git config —global user.name “XXX"

    git config --global user.email “XXXX"

    • 1
    • 2
    • 1
    • 2
  • 设置大小写敏感

    git config core.ignorecasefalse

    • 1
    • 1
  • 生成密钥

    ssh-keygen-t rsa-C “your_email”

    • 1
    • 1
  • 将远端代码clone到本地目录

    git clone<远端git><本地目录>

    • 1
    • 1
  • 提交修改

    gitadd <文件> // 将有修改的文件添加到本地缓存中 git add . 是添加所有修改

    git commit -m"本次修改信息" // 提交本次修改,一般是在git add之后操作

    git reset . // 撤销add

    git rm--cached . // 撤销add

    • 1
    • 2
    • 3
    • 4
    • 1
    • 2
    • 3
    • 4
  • 切换分支

    git checkout<branch_name>

    • 1
    • 1
  • 以当前分支为蓝本新建分支并切换到新分支

    git checkout -b<branch_name>

    • 1
    • 1
  • 当前分支合并其他分支

    git merge<branch_name>

    • 1
    • 1
  • 远端新建分支,其实就是将本地分支推送至远端

    git push origin <local_branch_name>:<remote_branch_name>

    • 1
    • 1
  • 删除远端分支,其实就是推送了一个空的分支到远端覆盖了原来的远端分支

    git push origin:<remote_branch_name>

    • 1
    • 1
  • 从远端拉取分支,并建立对应关系

    git checkout -b<local_branch_name> origin/<remote_branch_name>

    // 或者

    git branch —track<local_branch_name> origin/<remote_branch_name>

    • 1
    • 2
    • 3
    • 1
    • 2
    • 3
  • 本地已经存在的分支和远端分支建立对应关系

    git branch —set-upstream<local_branch_name> origin/<remote_branch_name>

    • 1
    • 1
  • 添加远端库

    git remote add<远端库代称><远端库地址>

    git clone<远端库地址><目录> //不需要git init

    • 1
    • 2
    • 1
    • 2
  • 回滚到某一个提交版本

    git reset --hard/soft <commit_id> // 回滚到某一个版本

    git reset --hard/soft HEAD~<num> // 回滚num个提交

    git revert <merge_commit_id> -m number// 撤销某一次merge

    • 1
    • 2
    • 3
    • 1
    • 2
    • 3
  • 强制远端覆盖本地

    gitfetch--all

    gitreset--hardorigin/<remote_branch_name>

    • 1
    • 2
    • 1
    • 2
  • 提交日志查看方式

    gitlog -p 每一次提交具体差异

    gitlogstat 显示文件修改差异,没显示具体修改

    gitlog —graph 树形状提交记录,可查看分支合并信息

    • 1
    • 2
    • 3
    • 1
    • 2
    • 3
  • git pull —rebase有冲突后,解决冲突,使用 git add .然后使用git rebase --continue

  • 切换到某个分支,将其他分支的某次提交应用到该分支

    git checkout<branch_name>

    git cherry-pick<commitid>

    • 1
    • 2
    • 1
    • 2
  • 前者表示把到之间(左开右闭,不包含start-commit-id)的提交cherry-pick到当前分支;后者表示把到之间(闭区间,包含start-commit-id)的提交cherry-pick到当前分支。

    git cherry-pick<start-commit-id>..<end-commit-id>

    git cherry-pick<start-commit-id>^..<end-commit-id>

    • 1
    • 2
    • 1
    • 2
  • tag

    • 新建tag

      gittag<tag_name>//轻量标签

      gittag-a<tag_name>-m"tag_msg"// 附注标签

      gittag-a<tag_name><commint_id>// 给某次提交添加标签

      • 1
      • 2
      • 3
      • 1
      • 2
      • 3
    • 删除tag

      gittag-d<tag_name>

      • 1
      • 1
    • 查看tag

      gittag// 查看所有tag

      git show<tag_name>// 查看某条tag

      • 1
      • 2
      • 1
      • 2
    • 提交到远端

      git push origin<tag_name>// 将某个tag提交到远端

      git push origin –tags// 将所有tag提交到远端

      • 1
      • 2
      • 1
      • 2
  • branch相关指令

    git branch-d<branch_name>// 删除某个分支

    git branch-D<branch_name>// 强制删除某个分支

    git branch-avv// 查看本地分支与远端分支关系,并且显示分支最新一次提交信息

    git remote show origin// 查看远端分支间关系

    • 1
    • 2
    • 3
    • 4
    • 1
    • 2
    • 3
    • 4

结束语

本篇粗略的介绍了Git的使用,但是对于Git内部的实现和一些具体的使用方法,还是需要自己去深入的了解。关于Git的详细介绍和工作原理,可以查看以下连篇文章。

Git教程,里面有介绍到Git的工作原理,可以仔细阅读。

Git Community Book 中文版介绍了Git具体使用,这本书也是关于Git的一本好书。

Git练习,实战练习Git的各种指令。

    

3、go

    brew install go

   go version