美文网首页
常用命令

常用命令

作者: xiaowen_2010 | 来源:发表于2018-01-06 14:09 被阅读17次
    git.png

    体验更好的浏览版式,请访问我的博客:xiaowen.ink

    习惯了图形化界面,当初接触命令操作多少还是不习惯。
    以前做java,android ,无论是git 还是SVN,eclipse 或者Android studio总有插件帮我们完成版本的控制,因此每次只需要点击提交或者同步即可。
    来到了索喜科技,以前的那些插件可就都用不上,因为代码在远程服务器,编译也得在远程服务器,只能通过ssh登录进行操作了,因此就需要接触命令来进行开发了,还有需要用 vim了。
    习惯了编辑器带来的便利,写代码也就啪啪的没一会功夫就写了一大堆,现在呢,得需要一个个单词手敲,因为没有提示...刚开始的时候心中一万只草泥马奔腾而过,什么鬼,这效率我需要多久才能上手。。。
    后来才知道,原来是可以用编辑器来干活的,比如 notepad ,vscode ,source insight,现在接触的最多的也就是这三个,做底层开发的视 vim 和 source insight 为神器,就好像做android 开发的对Android studio 或者 java开发对Intelli IDEA 的一样,不过还是有点不同,做底层开发的好像都鄙视上层开发...
    不扯了,总结下这么久来接触的命令,现在暂时就这些,以后有别的再更新,主要有:

    Git
    Linux
    Vim

    Git

    克隆

    • git clone xxx ---> 克隆项目,xxx 是项目的地址

    分支

    • git branch ---> 查看当前项目分支
    • git checkout -b xxx --->切换到分支xxx,或者不带 -b,需要注意的是,切换前记得 git pull 先更新本地项目

    查看当前状态和覆盖本地更新

    • git status --->查看当前项目的状态,比如修改了那些文件,添加了那些文件,或者已经 commit 没有 push 等
    • git status -uno ---> 查看当前 repo 文件的状态,不包含新增的文件
    • git pull ---> 更新本地,如果项目里面有多个 repo ,并且是要在根目录更新,请使用 agito pull
    • git checkout -f ---> 覆盖本地更新
    • git checkout -f xxx.file ---> 单个文件覆盖更新,只会将xxx.file文件修改的内容全部覆盖掉

    查看修改信息

    • git diff ---> 查看本地更改的更改的内容,不包含新增的文件,如果要看新增的文件,请使用 git status
    • git diff xxx.file ---> 查看xxx.file文件的更改内容,可以查看多个文件,文件之间空格隔开

    生成 patch

    • git diff --binary >xxx.patch ---> 将本地更改的内容生成xxx.patch文件,不包括新增文件
    • git diff --binary HEAD^ >xxx.patch ---> 将上一次提交的内容生成xxx.patch文件。HEAD^^表示上两次,一次类推
    • git diff HASH_PREV HASH_CURR > PATCHNAME.patch ---> 生成指定 commit 之间的 patch 命令: HASH_CURR -> 需要生成的commit 号; HASH_PREV --> HASH_CURR 之前的commit 号,比如:git diff ed0ede9ab46ade1494fd2b7a5ab7882c8cbab0e6 a1d1f770eed6a7980aafd228f9c3a76a23023fc5 > PATCHNAME.patch
    • git format-patch -1 <r1> ... <rn> --->打patch包含提交人的相关信息,多个commit 号之间用这样的方式,单个则直接带commit 号即可

    打 patch

    • patch -p1 < ~/xxxx.patch ---> 在当前目录打入 xxxx.patch,"~" 表示系统根目录,"." 表示当前目录
    • git am ~/xxxx.patch ---> 打入包含提交人信息的patch ,跟上面的 git format-patch 对应

    提交

    • git add xxx.file ---> 添加 xxx.file 关联,多个文件直接空格后面携带,如果是本地所有的文件都要提交,可以执行 git add . ,即后面带一个 ".",表示关联当前所有未添加关联的文件
    • git commit -a ---> 提交,并且填写提交信息
    • git push ---> push 上服务器

    查看 log

    • git log ---> 查看 log
    • git log xxx.file ---> 查看 xxx.file 的 log
    • git log -p ---> 查看 log 和提交的内容
    • git log -p xxx.file ---> 查看 xxx.file 的log 和提交的内容

    版本回退

    • git reset + commit ---> 已经执行 git commit ,不想执行 git push 提交 ,可以回退到上一级版本,那么你改过的东西就会重新恢复为未提交,或者执行命令 : git reset --hard HEAD^
    • git reset --hard HEAD^ ---> 版本回退1级(回退一级则是一个^号),或者执行 git reset + commit

    注意:

    • 上述的一些命令可以携带后缀,比如带 "." 表示当前目录,带文件等

    Linux

    下面的命令操作过程中如果提示没有权限,则在执行命令的前面添加 sudo

    文件操作

    • 查看文件列表 ls

      ls ---> 列出当前目录下文件和文件夹,不包括"." 开头的文件和文件夹
      la ---> 列出当前目录下的所有文件和文件夹,包含 "." 开头的文件和文件夹
      ll ---> 列出文件或者文件夹的所有信息,比如权限,文件所有者,文件大小,时间等
      pwd ---> 显示当前目录的绝对路径

    • 文件或者文件夹创建以及改名、复制和删除

      mkdir xxx ---> 创建xxx文件夹
      touch xxx.txt ---> 创建 xxx.txt 文件
      mv xxx vvvv ---> 将文件夹 xxx 重命名为 vvvv ,该命令也可以操作文件
      mv xxx /home/share xxx ---> 将 xxx 移动到 /home/share ,该命令也可以操作文件
      rm xxx.txt ---> 删除 xxx.txt 文件
      rm -rf xxx ---> 将 xxx 目录底下的内容全部删除, -r 递归, -f 强行删除,忽略不存在的文件,系统不再提示
      cp /home/share/xxx.txt . ---> 将 /home/share/xxx.txt 拷贝到当前目录
      cp /home/share/xxx.txt /home/wxf/vvv.txt ---> 将 /home/share/xxx.txt 拷贝到 /home/wxf/,并将其命名为 vvv.txt
      拷贝文件夹则在上述两条命令cp 的后面添加参数 -R ,其余的跟上述的一样,比如将share文件夹拷贝到当前目录:cp -R /home/share/ .

    搜索与查找

    • 搜索字符串

      grep -nsFR "xxx" * ---> 在当前目录下搜索字符 xxx
      grep -nsFR "xxx" * --color=auto ---> 在当前目录下搜索字符 xxx,并将匹配的关键字添加颜色

    • 查找文件

      find . -name "new_main.c" ---> 在当前目录下查找new_main.c文件,也可以使用通配符 ""进行模糊搜索,比如: find . -name "new_main." , find . -name "new*.c" 等等

    权限管理

    • sudo chown -R wxfc:wxfc commit ---> 使用户wxfc或者组wxfc拥有 commit 的读写权限

    网络连接

    • ssh user@host ---> 录远程主机host,比如 ssh wxfc@172.22.26.201 ,然后输入密码即可
    • ssh -p 66 user@host ---> 更改登录的端口,因为默认端口是 : 22
    • ifconfig ---> 查看Linux设备的IP地址

    vim

    • vim fileName ---> 打开文件 fileName
    • 搜索

      /text ---> 搜索text,按 n 键切换选中
      ?text ---> 反向搜索
      shift + * ---> 光标点中某个单词,按住 shift + * ,即可选中单词,然后按住 shift ,不断的点击 * 键即可切换当前的搜索,* 键 也可以替换成 # 键

    • u ---> 撤销修改,相当于 window 的 ctrl + z
    • i ---> 在当前位置插入
    • 复制粘贴

      yy ---> 复制当前行
      p ---> 在当前行的下一行粘贴,前提是执行了 yy

    • 删除

      dd ---> 删除当前行
      x ---> 删除当前字符

    • 退出

      Esc + : + q! ---> 退出不保存修改
      Esc + : + wq ---> 退出保存修改

    未完待续...

    相关文章

      网友评论

          本文标题:常用命令

          本文链接:https://www.haomeiwen.com/subject/jzrynxtx.html