linux终端链接仓库_linux链接终端 - CSDN
  • Linux内核版本: linux-3.0  安装配置:GIT 邮箱:leiyuxing205@gmail.com ——————————————————————————————————————— 一GIT简介 Git是一个开源的分布式版本控制系统,用...

    ———————————————————————————————————————

    主机操作系统:Centos 6.7

    安装配置:GIT
    邮箱:leiyuxing205@gmail.com

    ———————————————————————————————————————

    一GIT简介

    Git是一个开源的分布式版本控制系统,用以有效、高速的处理从很小到非常大的项目版本管理。

    Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码版本控制软件

    Torvalds 开始着手开发 Git 是为了作为一种过渡方案来替代 BitKeeper,后者之前一直是 Linux 内核开发人员在全球使用的主要源代码工具。开放源码社区中的有些人觉得 BitKeeper 的许可证并不适合开放源码社区的工作,因此 Torvalds 决定着手研究许可证更为灵活的版本控制系统。尽管最初 Git 的开发是为了辅助 Linux 内核开发的过程,但是我们已经发现在很多其他自由软件项目中也使用了 Git。例如最近就迁移到 Git 上来了,很多 Freedesktop 的项目也迁移到了 Git 上。

    二.特点

    分布式和集中式的最大区别在于开发者可以本地提交。每个开发者机器上都有一个服务器的数据库。

    下图是经典的git开发过程。

    Git的功能特性:

    从一般开发者的角度来看git有以下功能:

    1:从服务器上克隆数据库(包括代码和版本信息)到单机上。

    2:在自己的机器上创建分支,修改代码。

    3:在单机上自己创建的分支上提交代码。

    4:在单机上合并分支。

    5:新建一个分支,把服务器上最新版的代码fetch下来,然后跟自己的主分支合并。

    6:生成补丁(patch),把补丁发送给主开发者。

    7:看主开发者的反馈,如果主开发者发现两个一般开发者之间有冲突(他们之间可以合作解决的冲突),就会要求他们先解决冲突,然后再由其中一个人提交。如果主开发者可以自己解决,或者没有冲突,就通过。

    8:一般开发者之间解决冲突的方法,开发者之间可以使用pull 命令解决冲突,解决完冲突之后再向主开发者提交补丁。

    三.功能

    从主开发者的角度(假设主开发者不用开发代码)看,git有以下功能:

    1:查看邮件或者通过其它方式查看一般开发者的提交状态。

    2:打上补丁,解决冲突(可以自己解决,也可以要求开发者之间解决以后再重新提交,如果是开源项目,还要决定哪些补丁有用,哪些不用)。

    3:向公共服务器提交结果,然后通知所有开发人员。

    优点:

    适合分布式开发,强调个体。

    公共服务器压力和数据量都不会太大。

    速度快、灵活。

    任意两个开发者之间可以很容易的解决冲突。

    离线工作。

    缺点:

    资料少(起码中文资料很少)。

    学习周期相对而言比较长。

    不符合常规思维

    代码保密性差,一旦开发者把整个库克隆下来就可以完全公开所有代码和版本信息。

    新加用户git,该用户将作为所有代码仓库和用户权限的管理者:

    [leiyuxing@centos6 ~]$ sudo useradd -m git

    [leiyuxing@centos6 ~]$ sudo passwd git

    更改用户 git 的密码 。

    新的 密码:

    重新输入新的 密码:

    passwd: 所有的身份验证令牌已经成功更新。

    五.切换到git用户,并初始化git帐户信息:

    [leiyuxing@centos6 ~]$ su git

    密码:

    [git@centos6 leiyuxing]$cd

    [git@centos6 ~]$ git config --global user.name "git"

    [git@centos6 ~]$ git config --global user.email "git@email.com"

    六.修改/etc/sudoers文件,把git用户添加到sudo里去,方便使用sudo管理:

    [leiyuxing@centos6 ~]$ sudo vim /etc/sudoers

    ****

    git   ALL= NOPASSWD: ALL

    ****

    七. 配置ssh公钥访问oschina:

    oschina简介:

    开源中国社区成立于2008年8月,其目的是为中国的IT技术人员提供一个全面的、快捷更新的用来检索开源软件以及交流使用开源经验的平台,目前开源中国社区已收录超过两万多款开源软件。 经过不断的改进,目前开源中国社区已经形成了由开源软件库、代码分享、资讯、讨论区和博客等几大频道内容。
    中文名
    开源中国社区
    外文名
    oschina.net
    成    立
    2008年8月
    目    的
    提供检索开源软件及交流
    频    道
    开源软件库、代码分享、资讯
    对    象
    中国的IT技术人员






    ssh公钥:

    ---------------------------------------

    大多数 Git 服务器都会选择使用 SSH 公钥来进行授权。系统中的每个用户都必须提供

    一个公钥用于授权,没有的话就要生成一个。生成公钥的过程在所有操作系统上都差不多。

    首先先确认一下是否已经有一个公钥了。SSH 公钥默认储存在账户的主目录下的 ~/.ssh

    目录。关键是看有没有用 something 和 something.pub 来命名的一对文件,这个 something

    通常就是 id_dsa 或 id_rsa。有 .pub 后缀的文件就是公钥,另一个文件则是密钥。假如没有这些文件,或者干脆连 .ssh 目录都没有,可以用 ssh-keygen 来创建。该程序在

    ---------------------------------------

     转到.ssh目录下(若没有则新建一个),生成的公钥将放到该目录下

    [leiyuxing@centos6 git]$ cd ~/.ssh/

    使用ssh-kengen工具生成公钥(public key):
    [leiyuxing@centos6 .ssh]$ ssh-keygen -t rsa -C"674116231@qq.com"  //Creates a new ssh key using the provided email,"674116231@qq.com"是您注册时使用的邮箱名,注意会弹出要输入文件名及密码等,直接敲Enter即可。

    Generating public/private rsa key pair.
    Enter file in which to save the key (/home/leiyuxing/.ssh/id_rsa): 
    Enter passphrase (empty for no passphrase): 
    Enter same passphrase again: 
    Your identification has been saved in /home/leiyuxing/.ssh/id_rsa.
    Your public key has been saved in /home/leiyuxing/.ssh/id_rsa.pub.
    The key fingerprint is:
    99:7b:20:40:dc:d4:09:4a:68:a3:88:87:d2:ca:da:d7 674116231@qq.com
    The key's randomart image is:
    +--[ RSA 2048]----+
    |   ooooo .       |
    |  +o... o        |
    |o= .o            |
    |* o  .   o       |
    |oo    . S        |
    |..     . o       |
    |..   .  . .      |
    |. . . E  .       |
    |   .             |
    +-----------------+

    查看生成的公钥,并将公钥内容拷贝添加到Git @ OSC http://git.oschina.net/keys


    [leiyuxing@centos6 .ssh]$ cat ~/.ssh/id_rsa.pub
    ssh-rsa AAAAB3NzaC1yc2EAAAABIwAAAQ..........................................................................................................................................................................................................

    PzARbyLiutwEAblSx4zy01WT8Xjdxz0jAPSZo3vGppLb1P0o2GpGfHOhuU5SAaoBVsA/30s5X9MbvLxuznyUqAf7WckX34ztT9thMgw== 674116231@qq.com
    [leiyuxing@centos6 .ssh]$ ls
    id_rsa  id_rsa.pub  known_hosts

    注意拷贝过程中不能多一个空格,也不能少一个空格,格式等必须和生成的公钥一致(不要用Windows自带的记事本打开复制)。

    通过如下的命令可以查看是否设置公钥成功:

    [leiyuxing@centos6 .ssh]$ ssh -T git@git.oschina.net
    Welcome to Git@OSC, leiyuxing!

    八.创建git存放代码的仓库:

    如图我用osc托管的,我就先在那上面建立了一个新的项目,里面除了一个readme什么都没有。


     其中以下网址是用来连接的:


    接下来就回到我们虚拟机上:

    [leiyuxing@centos6 ~]$ mkdir git

    [leiyuxing@centos6 ~]$ cd git/

    [leiyuxing@centos6 git]$ git init

    Initialized empty Git repository in /home/leiyuxing/git/.git/

    首先是建立我们本地一个git目录,然后git init使它真正成为一个仓库,会出现一个.git目前,仓库的属性都在里面,它就是一个标志,有它就是一个git仓库

    建立联系:

    [leiyuxing@centos6 ~]$ git remote add origin git@git.oschina.net:LYX_WIN/OV9650.git

    [leiyuxing@centos6 ~]$ git remote -v

    origin  git@git.oschina.net:LYX_WIN/OV9650.git (fetch)

    origin  git@git.oschina.net:LYX_WIN/OV9650.git (push)

    可以用pull把我们远处仓库的文件下下来(刚才我们上面建立了联系,所示我们可以用这个命令:git pull origin master)

    [leiyuxing@centos6 git]$ git pull git@git.oschina.net:LYX_WIN/OV9650.git

    remote: Counting objects: 3, done.
    remote: Total 3 (delta 0), reused 0 (delta 0)
    Unpacking objects: 100% (3/3), done.
    From git.oschina.net:LYX_WIN/OV9650
     * branch            HEAD       -> FETCH_HEAD

    [leiyuxing@centos6 git]$ ls

    README.md

    我们想做的是如何把自己仓库的文件放到远程仓库中呢?

    首先我创建一个文件,然后用命令加入到我本地的仓库中去

    [leiyuxing@centos6 git]$ vim a.txt

    [leiyuxing@centos6 git]$ cat a.txt

    aaa

    [leiyuxing@centos6 git]$ git status

    # On branch master
    # Untracked files:
    #   (use "git add <file>..." to include in what will be committed)
    #
    #       .a.txt.swp
    #       a.txt
    nothing added to commit but untracked files present (use "git add" to track)

    这时会提示我们有一个未追踪的文件,叫a.txt。我们要把这个文件加入到版本控制中,于是,我们运行如下命令:

    [leiyuxing@centos6 git]$ git add a.txt

    这个命令表示把我们指定的a.txt加入到git控制之下。add命令可以没有参数(在windows下可以没有参数,在mac下需要指定当前目录即“.”),如果没有参数,则表示把目录下的所有文件都加入到git仓库中。这个时候,我们再运行下“git status”:

    [leiyuxing@centos6 git]$ git status

    # On branch master
    # Changes to be committed:
    #   (use "git reset HEAD <file>..." to unstage)
    #
    #       new file:   a.txt
    #
    # Untracked files:
    #   (use "git add <file>..." to include in what will be committed)
    #
    #       .a.txt.swp

    提示我们有改变需要被提交。这个时候,a.txt这个文件就存在于所谓的“暂存区”中,暂存区中的文件可以被真正提交到git仓库。有同学可能说,如果我不想提交这个文件了,那怎么把刚才的文件从暂存区移除呢?其实答案就在刚才的提示中:
    use "git rm --cached ..." to unstage。
    那么,我们运行下这个命令:

    [leiyuxing@centos6 git]$ git rm --cached a.txt

    rm 'a.txt'
    再运行git status时就可以发现,又回到文件没有被提交时的状态了。

     

    当我们的文件已经通过“git add”加入到暂存区后,就可以把文件真正提交到git仓库了。如下:

    [leiyuxing@centos6 git]$ git commit -m "add a file"

    [master 284a63b] add a file
     1 files changed, 1 insertions(+), 0 deletions(-)
     create mode 100644 a.txt

    [leiyuxing@centos6 git]$ git push -f git@git.oschina.net:LYX_WIN/OV9650.git
    Counting objects: 4, done.
    Compressing objects: 100% (2/2), done.
    Writing objects: 100% (3/3), 271 bytes, done.
    Total 3 (delta 0), reused 0 (delta 0)
    To git@git.oschina.net:LYX_WIN/OV9650.git
       a97700d..284a63b  master -> master

    发现已经可以提交成功了,提示一个文件被修改(就是我们的a.txt),一行被插入(就是我们唯一的一行“aaa”)。

    我们再运行下git status:

    [leiyuxing@centos6 git]$ git status

    # On branch master

    nothing to commit (working directory clean)

    提示我们当前没有东西要提交,当前工作目录是干净的,因为我们都提交到git了。
    好了,到这步后,git就可以完全跟踪已经被提交的文件了,以后,这个文件的任何修改,它都可以记录下来。比如某个人对项目私自修改了一些东西,项目管理者根据git的版本记录是一定可以找到是谁修改了哪些文件的。
    现在我们就可以把文件提交到远程服务器了。

    我们也可以刷新网页,在我们的osc上看到了:


    九.这次我们尝试不用自己创建仓库了,直接用 clone命令

    [leiyuxing@centos6 git]$ git clone git@git.oschina.net:LYX_WIN/OV9650.git
    Initialized empty Git repository in /home/leiyuxing/git/OV9650/.git/
    remote: Counting objects: 6, done.
    remote: Compressing objects: 100% (3/3), done.
    remote: Total 6 (delta 0), reused 0 (delta 0)
    Receiving objects: 100% (6/6), done.
    [leiyuxing@centos6 git]$ ls
    a.txt  OV9650  README.md

    我们进去ov9650这个目录可以看见.git这个目录:

    [leiyuxing@centos6 OV9650]$ ls ../  .git
    ../:
    a.txt  OV9650  README.md
    .git:
    branches  description  hooks  info  objects      refs
    config    HEAD         index  logs  packed-refs
    我们git log可以看见我们在1.3服务器上做的事情,说明就是那个仓库:

    [leiyuxing@centos6 OV9650]$ git log
    commit 284a63b496f11bd7949bcf3a1d3d0ee70b716409
    Author: leiyuxing <674116231@qq.com>
    Date:   Thu Aug 18 08:34:06 2016 +0800
       add a file
    commit a97700d366d8703cbfbcc109862c0b9781733834
    Author: leiyuxing <674116231@qq.com>
    Date:   Wed Aug 17 10:42:17 2016 +0800
           Initial commit

    然后可以测试一下,创建一个1.c文件然后上传:

    [leiyuxing@centos6 OV9650]$ touch 1.c
    [leiyuxing@centos6 OV9650]$ git status

    # On branch master
    # Your branch is ahead of 'origin/master' by 2 commits.
    #
    # Untracked files:
    #   (use "git add <file>..." to include in what will be committed)
    #
    #       1.c
    nothing added to commit but untracked files present (use "git add" to track)
    [leiyuxing@centos6 OV9650]$ git add 1.c 
    [leiyuxing@centos6 OV9650]$ git status

    # On branch master
    # Your branch is ahead of 'origin/master' by 2 commits.
    #
    # Changes to be committed:
    #   (use "git reset HEAD <file>..." to unstage)
    #
    #       new file:   1.c
    #
    [leiyuxing@centos6 OV9650]$ git commit -m "add a file"
    [master 8ce8431] add a file
     0 files changed, 0 insertions(+), 0 deletions(-)
     create mode 100644 1.c
    [leiyuxing@centos6 OV9650]$ git push -f git@git.oschina.net:LYX_WIN/OV9650.git
    Counting objects: 8, done.
    Compressing objects: 100% (5/5), done.
    Writing objects: 100% (7/7), 708 bytes, done.
    Total 7 (delta 0), reused 0 (delta 0)
    To git@git.oschina.net:LYX_WIN/OV9650.git
       284a63b..8ce8431  master -> master

    我们可以再一次刷新网页,在我们的osc上看到了:



     

    展开全文
  • 命令 功能说明 线上查询及帮助命令 man ... 查看命令帮助,命令... 查看Linux内置命令的帮助,比如cd命令。 文件和目录操作命令 ls 全拼list,功能...

    命令

    功能说明

    线上查询及帮助命令

    man

    查看命令帮助,命令的词典,更复杂的还有info,但不常用。

    help

    查看Linux内置命令的帮助,比如cd命令。

    文件和目录操作命令

    ls

    全拼list,功能是列出目录的内容及其内容属性信息。

    示例:

    ls -F 查看目录中的文件 
    ls -l 显示文件和目录的详细资料 
    ls -a 显示隐藏文件 
    ls *[0-9]* 显示包含数字的文件名和目录名 

    ls -lSr |more 以尺寸大小排列文件和目录 

    ls -lh 显示权限 
    ls /tmp | pr -T5 -W$COLUMNS 将终端划分成5栏显示 

    cd

    全拼change directory,功能是从当前工作目录切换到指定的工作目录。

    示例:

    cd /home 进入 '/ home' 目录' 
    cd .. 返回上一级目录 
    cd ../.. 返回上两级目录 
    cd 进入个人的主目录 
    cd ~user1 进入个人的主目录 
    cd - 返回上次所在的目录 

    cp

    全拼copy,其功能为复制文件或目录。

    示例:

    cp file1 file2 复制一个文件 
    cp dir/* . 复制一个目录下的所有文件到当前工作目录 
    cp -a /tmp/dir1 . 复制一个目录到当前工作目录 
    cp -a dir1 dir2 复制一个目录 

    find

    查找的意思,用于查找目录及目录下的文件。

    示例:

    find / -name file1 从 '/' 开始进入根文件系统搜索文件和目录 
    find / -user user1 搜索属于用户 'user1' 的文件和目录 
    find /home/user1 -name \*.bin 在目录 '/ home/user1' 中搜索带有'.bin' 结尾的文件 
    find /usr/bin -type f -atime +100 搜索在过去100天内未被使用过的执行文件 
    find /usr/bin -type f -mtime -10 搜索在10天内被创建或者修改过的文件 
    find / -name \*.rpm -exec chmod 755 '{}' \; 搜索以 '.rpm' 结尾的文件并定义其权限 
    find / -xdev -name \*.rpm 搜索以 '.rpm' 结尾的文件,忽略光驱、捷盘等可移动设备 

    mkdir

    全拼make directories,其功能是创建目录。

    示例:

    mkdir dir1 创建一个叫做 'dir1' 的目录' 
    mkdir dir1 dir2 同时创建两个目录 
    mkdir -p /tmp/dir1/dir2 创建一个目录树 

    mv

    全拼move,其功能是移动或重命名文件。

    示例:

    mv dir1 new_dir 重命名/移动 一个目录 

    pwd

    全拼print working directory,其功能是显示当前工作目录的绝对路径。

    rename

    用于重命名文件。

    rm

    全拼remove,其功能是删除一个或多个文件或目录。

    rmdir

    全拼remove empty directories,功能是删除空目录。

    示例:

    rm -f file1 删除一个叫做 'file1' 的文件' 
    rmdir dir1 删除一个叫做 'dir1' 的目录' 
    rm -rf dir1 删除一个叫做 'dir1' 的目录并同时删除其内容 
    rm -rf dir1 dir2 同时删除两个目录及它们的内容 

    touch

    创建新的空文件,改变已有文件的时间戳属性。

    示例:

    touch -t 0712250000 file1 修改一个文件或目录的时间戳 - (YYMMDDhhmm) 

    tree

    功能是以树形结构显示目录下的内容。

    basename

    显示文件名或目录名。

    dirname

    显示文件或目录路径。

    chattr

    全拼change attribution,改变文件的扩展属性。

    示例:

    chattr +a file1 只允许以追加方式读写文件 
    chattr +c file1 允许这个文件能被内核自动压缩/解压 
    chattr +d file1 在进行文件系统备份时,dump程序将忽略这个文件 
    chattr +i file1 设置成不可变的文件,不能被删除、修改、重命名或者链接 
    chattr +s file1 允许一个文件被安全地删除 
    chattr +S file1 一旦应用程序对这个文件执行了写操作,使系统立刻把修改的结果写到磁盘 
    chattr +u file1 若文件被删除,系统会允许你在以后恢复这个被删除的文件

    lsattr

    全拼list attribution,查看文件扩展属性。

    类似示例:

    lspci -tv 罗列 PCI 设备 
    lsusb -tv 显示 USB 设备 

    file

    显示文件的类型。

    md5sum

    计算和校验文件的MD5值。

    查看文件及内容处理命令

    cat

    全拼concatenate,功能是用于连接多个文件并且打印到屏幕输出或重定向到指定文件中。

    示例:

    cat /proc/cpuinfo 显示CPU info的信息 
    cat /proc/interrupts 显示中断 
    cat /proc/meminfo 校验内存使用 
    cat /proc/swaps 显示哪些swap被使用 
    cat /proc/version 显示内核的版本 
    cat /proc/net/dev 显示网络适配器及统计 
    cat /proc/mounts 显示已加载的文件系统 

    tac

    tac是cat的反向拼写,因此命令的功能为反向显示文件内容。

    more

    分页显示文件内容。

    less

    分页显示文件内容,more命令的相反用法。

    head

    显示文件内容的头部。

    tail

    显示文件内容的尾部。

    cut

    将文件的每一行按指定分隔符分割并输出。

    split

    分割文件为不同的小片段。

    paste

    按行合并文件内容。

    sort

    对文件的文本内容排序。

    uniq

    去除重复行。

    wc

    统计文件的行数、单词数或字节数。

    iconv

    转换文件的编码格式。

    示例:

    iconv -l 列出已知的编码 
    iconv -f fromEncoding -t toEncoding inputFile > outputFile creates a new from the given input file by assuming it is encoded in fromEncoding and converting it to toEncoding. 

    dos2unix

    将DOS格式文件转换成UNIX格式。

    示例:

    dos2unix filedos.txt fileunix.txt 将一个文本文件的格式从MSDOS转换成UNIX 
    unix2dos fileunix.txt filedos.txt 将一个文本文件的格式从UNIX转换成MSDOS 
    recode ..HTML < page.txt > page.html 将一个文本文件转换成html 
    recode -l | more 显示所有允许的转换格式 

    diff

    全拼difference,比较文件的差异,常用于文本文件。

    vimdiff

    命令行可视化文件比较工具,常用于文本文件。

    rev

    反向输出文件内容。

    grep/egrep

    过滤字符串,三剑客老三。

    join

    按两个文件的相同字段合并。

    tr

    替换或删除字符。

    vi/vim

    命令行文本编辑器。

    示例

    cat file1 从第一个字节开始正向查看文件的内容 
    tac file1 从最后一行开始反向查看一个文件的内容 
    more file1 查看一个长文件的内容 
    less file1 类似于 'more' 命令,但是它允许在文件中和正向操作一样的反向操作 
    head -2 file1 查看一个文件的前两行 
    tail -2 file1 查看一个文件的最后两行 
    tail -f /var/log/messages 实时查看被添加到一个文件中的内容 

     

    文本处理大类:

    cat file1 file2 ... | command <> file1_in.txt_or_file1_out.txt general syntax for text manipulation using PIPE, STDIN and STDOUT 
    cat file1 | command( sed, grep, awk, grep, etc...) > result.txt 合并一个文件的详细说明文本,并将简介写入一个新文件中 
    cat file1 | command( sed, grep, awk, grep, etc...) >> result.txt 合并一个文件的详细说明文本,并将简介写入一个已有的文件中 
    grep Aug /var/log/messages 在文件 '/var/log/messages'中查找关键词"Aug" 
    grep ^Aug /var/log/messages 在文件 '/var/log/messages'中查找以"Aug"开始的词汇 
    grep [0-9] /var/log/messages 选择 '/var/log/messages' 文件中所有包含数字的行 
    grep Aug -R /var/log/* 在目录 '/var/log' 及随后的目录中搜索字符串"Aug" 
    sed 's/stringa1/stringa2/g' example.txt 将example.txt文件中的 "string1" 替换成 "string2" 
    sed '/^$/d' example.txt 从example.txt文件中删除所有空白行 
    sed '/ *#/d; /^$/d' example.txt 从example.txt文件中删除所有注释和空白行 
    echo 'esempio' | tr '[:lower:]' '[:upper:]' 合并上下单元格内容 
    sed -e '1d' result.txt 从文件example.txt 中排除第一行 
    sed -n '/stringa1/p' 查看只包含词汇 "string1"的行 
    sed -e 's/ *$//' example.txt 删除每一行最后的空白字符 
    sed -e 's/stringa1//g' example.txt 从文档中只删除词汇 "string1" 并保留剩余全部 
    sed -n '1,5p;5q' example.txt 查看从第一行到第5行内容 
    sed -n '5p;5q' example.txt 查看第5行 
    sed -e 's/00*/0/g' example.txt 用单个零替换多个零 
    cat -n file1 标示文件的行数 
    cat example.txt | awk 'NR%2==1' 删除example.txt文件中的所有偶数行 
    echo a b c | awk '{print $1}' 查看一行第一栏 
    echo a b c | awk '{print $1,$3}' 查看一行的第一和第三栏 
    paste file1 file2 合并两个文件或两栏的内容 
    paste -d '+' file1 file2 合并两个文件或两栏的内容,中间用"+"区分 
    sort file1 file2 排序两个文件的内容 
    sort file1 file2 | uniq 取出两个文件的并集(重复的行只保留一份) 
    sort file1 file2 | uniq -u 删除交集,留下其他的行 
    sort file1 file2 | uniq -d 取出两个文件的交集(只留下同时存在于两个文件中的文件) 
    comm -1 file1 file2 比较两个文件的内容只删除 'file1' 所包含的内容 
    comm -2 file1 file2 比较两个文件的内容只删除 'file2' 所包含的内容 
    comm -3 file1 file2 比较两个文件的内容只删除两个文件共有的部分 

    文件压缩及解压缩命令

    tar

    打包压缩。

    unzip

    解压文件。

    gzip

    gzip压缩工具。

    zip

    压缩工具。

    示例 bunzip2 file1.bz2 解压一个叫做 'file1.bz2'的文件 
    bzip2 file1 压缩一个叫做 'file1' 的文件 
    gunzip file1.gz 解压一个叫做 'file1.gz'的文件 
    gzip file1 压缩一个叫做 'file1'的文件 
    gzip -9 file1 最大程度压缩 
    rar a file1.rar test_file 创建一个叫做 'file1.rar' 的包 
    rar a file1.rar file1 file2 dir1 同时压缩 'file1', 'file2' 以及目录 'dir1' 
    rar x file1.rar 解压rar包 
    unrar x file1.rar 解压rar包 
    tar -cvf archive.tar file1 创建一个非压缩的 tarball 
    tar -cvf archive.tar file1 file2 dir1 创建一个包含了 'file1', 'file2' 以及 'dir1'的档案文件 
    tar -tf archive.tar 显示一个包中的内容 
    tar -xvf archive.tar 释放一个包 
    tar -xvf archive.tar -C /tmp 将压缩包释放到 /tmp目录下 
    tar -cvfj archive.tar.bz2 dir1 创建一个bzip2格式的压缩包 
    tar -xvfj archive.tar.bz2 解压一个bzip2格式的压缩包 
    tar -cvfz archive.tar.gz dir1 创建一个gzip格式的压缩包 
    tar -xvfz archive.tar.gz 解压一个gzip格式的压缩包 
    zip file1.zip file1 创建一个zip格式的压缩包 
    zip -r file1.zip file1 file2 dir1 将几个文件和目录同时压缩成一个zip格式的压缩包 
    unzip file1.zip 解压一个zip格式压缩包

    信息显示命令

    uname

    显示操作系统相关信息的命令。

    示例:

    uname -m 显示机器的处理器架构    与“arch 显示机器的处理器架构 ”一致
    uname -r 显示正在使用的内核版本

    hostname

    显示或者设置当前系统的主机名。

    dmesg

    显示开机信息,用于诊断系统故障。

    uptime

    显示系统运行时间及负载。

    stat

    显示文件或文件系统的状态。

    du

    计算磁盘空间使用情况。

    示例:

    du -sh dir1 估算目录 'dir1' 已经使用的磁盘空间' 
    du -sk * | sort -rn 以容量大小为依据依次显示文件和目录的大小 

    df

    报告文件系统磁盘空间的使用情况。

    示例:

    df -h 显示已经挂载的分区列表 

    top

    实时显示系统资源使用情况。

    free

    查看系统内存。

    date

    显示与设置系统时间。

    示例:

    date 041217002007.00 设置日期和时间 - 月日时分年.秒

    clock -w 将时间修改保存到 BIOS 

    cal

    查看日历等时间信息。

    示例:

    cal 2007 显示2007年的日历表

    搜索文件命令

    which

    查找二进制命令,按环境变量PATH路径查找。

    which halt 显示一个二进制文件或可执行文件的完整路径 

    find

    从磁盘遍历查找文件或目录。

    whereis

    查找二进制命令,按环境变量PATH路径查找。

    whereis halt 显示一个二进制文件、源码或man的位置

    locate

    从数据库 (/var/lib/mlocate/mlocate.db) 查找命令,使用updatedb更新库。

    locate \*.ps 寻找以 '.ps' 结尾的文件 - 先运行 'updatedb' 命令 

    用户管理命令

    useradd

    添加用户。

    示例:

    useradd -c "Name Surname " -g admin -d /home/user1 -s /bin/bash user1 创建一个属于 "admin" 用户组的用户 
    useradd user1 创建一个新用户 
    userdel -r user1 删除一个用户 ( '-r' 排除主目录) 
    usermod -c "User FTP" -g system -d /ftp/user1 -s /bin/nologin user1 修改用户属性 

    usermod

    修改系统已经存在的用户属性。

    userdel

    删除用户。

    groupadd

    添加用户组。

    示例:

    groupadd group_name 创建一个新用户组 
    groupdel group_name 删除一个用户组 
    groupmod -n new_group_name old_group_name 重命名一个用户组 

     

    pwck 检查 '/etc/passwd' 的文件格式和语法修正以及存在的用户 
    grpck 检查 '/etc/passwd' 的文件格式和语法修正以及存在的群组 
    newgrp group_name 登陆进一个新的群组以改变新创建文件的预设群组 

    passwd

    修改用户密码。

    示例:

    passwd user1 修改一个用户的口令 (只允许root执行) 

    chage

    修改用户密码有效期限。

    示例:

    chage -E 2005-12-31 user1 设置用户口令的失效期限 

    id

    查看用户的uid,gid及归属的用户组。

    su

    切换用户身份。

    visudo

    编辑/etc/sudoers文件的专属命令。

    sudo

    以另外一个用户身份(默认root用户)执行事先在sudoers文件允许的命令。

    基础网络操作命令

    telnet

    使用TELNET协议远程登录。

    ssh

    使用SSH加密协议远程登录。

    scp

    全拼secure copy,用于不同主机之间复制文件。

    wget

    命令行下载文件。

    ping

    测试主机之间网络的连通性。

    route

    显示和设置linux系统的路由表。

    示例:

    dhclient eth0 以dhcp模式启用 'eth0' 
    route -n show routing table 
    route add -net 0/0 gw IP_Gateway configura default gateway 
    route add -net 192.168.0.0 netmask 255.255.0.0 gw 192.168.1.1 configure static route to reach network '192.168.0.0/16' 
    route del 0/0 gw IP_gateway remove static route 

    ifconfig

    查看、配置、启用或禁用网络接口的命令。

    示例:

    ifconfig eth0 显示一个以太网卡的配置 

    ifconfig eth0 192.168.1.1 netmask 255.255.255.0 控制IP地址 
    ifconfig eth0 promisc 设置 'eth0' 成混杂模式以嗅探数据包 (sniffing) 

    ifup

    启动网卡。

    示例:ifup eth0 启用一个 'eth0' 网络设备 

    ifdown

    关闭网卡。

    示例:ifdown eth0 禁用一个 'eth0' 网络设备

    netstat

    查看网络状态。

    示例:

    netstat -tup show all active network connections and their PID 
    netstat -tupl show all network services listening on the system and their PID 

    ss

    查看网络状态。

    深入网络操作命令

    nmap

    网络扫描命令。

    lsof

    全名list open files,也就是列举系统中已经被打开的文件。

    mail

    发送和接收邮件。

    mutt

    邮件管理命令。

    nslookup

    交互式查询互联网DNS服务器的命令。

    dig

    查找DNS解析过程。

    host

    查询DNS的命令。

    示例:

     

    traceroute

    追踪数据传输路由状况。

    tcpdump

    命令行的抓包工具。

    示例:

    tcpdump tcp port 80 show all HTTP traffic 

    有关磁盘与文件系统的命令

    mount

    挂载文件系统。

    umount

    卸载文件系统。

    fsck

    检查并修复Linux文件系统。

    示例:

    badblocks -v /dev/hda1 检查磁盘hda1上的坏磁块 
    fsck /dev/hda1 修复/检查hda1磁盘上linux文件系统的完整性 
    fsck.ext2 /dev/hda1 修复/检查hda1磁盘上ext2文件系统的完整性 

    fsck.ext3 /dev/hda1 修复/检查hda1磁盘上ext3文件系统的完整性 
    fsck.vfat /dev/hda1 修复/检查hda1磁盘上fat文件系统的完整性 
    fsck.msdos /dev/hda1 修复/检查hda1磁盘上dos文件系统的完整性 
    dosfsck /dev/hda1 修复/检查hda1磁盘上dos文件系统的完整性 

    dd

    转换或复制文件。

    dumpe2fs

    导出ext2/ext3/ext4文件系统信息。

    dump

    ext2/3/4文件系统备份工具。

    fdisk

    磁盘分区命令,适用于2TB以下磁盘分区。

    parted

    磁盘分区命令,没有磁盘大小限制,常用于2TB以下磁盘分区。

    mkfs

    格式化创建Linux文件系统。

    示例:

    mkfs /dev/hda1 在hda1分区创建一个文件系统 

    mke2fs /dev/hda1 在hda1分区创建一个linux ext2的文件系统 
    mke2fs -j /dev/hda1 在hda1分区创建一个linux ext3(日志型)的文件系统 
    mkfs -t vfat 32 -F /dev/hda1 创建一个 FAT32 文件系统 

    partprobe

    更新内核的硬盘分区表信息。

    e2fsck

    检查ext2/ext3/ext4类型文件系统。

    示例:

    e2fsck /dev/hda1 修复/检查hda1磁盘上ext2文件系统的完整性 
    e2fsck -j /dev/hda1 修复/检查hda1磁盘上ext3文件系统的完整性 

    mkswap

    创建Linux交换分区。

    示例:

    mkswap /dev/hda3 创建一个swap文件系统 

    fdformat -n /dev/fd0 格式化一个软盘

    swapon

    启用交换分区。

    示例:

    swapon /dev/hda3 启用一个新的swap文件系统 
    swapon /dev/hda2 /dev/hdb3 启用两个swap分区

    swapoff

    关闭交换分区。

    sync

    将内存缓冲区内的数据写入磁盘。

    resize2fs

    调整ext2/ext3/ext4文件系统大小。

    示例

    备份:

    dump -0aj -f /tmp/home0.bak /home 制作一个 '/home' 目录的完整备份 
    dump -1aj -f /tmp/home0.bak /home 制作一个 '/home' 目录的交互式备份 
    restore -if /tmp/home0.bak 还原一个交互式备份 
    rsync -rogpav --delete /home /tmp 同步两边的目录 
    rsync -rogpav -e ssh --delete /home ip_address:/tmp 通过SSH通道rsync 
    rsync -az -e ssh --delete ip_addr:/home/public /home/local 通过ssh和压缩将一个远程目录同步到本地目录 
    rsync -az -e ssh --delete /home/local ip_addr:/home/public 通过ssh和压缩将本地目录同步到远程目录 
    dd bs=1M if=/dev/hda | gzip | ssh user@ip_addr 'dd of=hda.gz' 通过ssh在远程主机上执行一次备份本地磁盘的操作 
    dd if=/dev/sda of=/tmp/file1 备份磁盘内容到一个文件 
    tar -Puf backup.tar /home/user 执行一次对 '/home/user' 目录的交互式备份操作 
    ( cd /tmp/local/ && tar c . ) | ssh -C user@ip_addr 'cd /home/share/ && tar x -p' 通过ssh在远程目录中复制一个目录内容 
    ( tar c /home ) | ssh -C user@ip_addr 'cd /home/backup-home && tar x -p' 通过ssh在远程目录中复制一个本地目录 
    tar cf - . | (cd /tmp/backup ; tar xf - ) 本地将一个目录复制到另一个地方,保留原有权限及链接 
    find /home/user1 -name '*.txt' | xargs cp -av --target-directory=/home/backup/ --parents 从一个目录查找并复制所有以 '.txt' 结尾的文件到另一个目录 
    find /var/log -name '*.log' | tar cv --files-from=- | bzip2 > log.tar.bz2 查找所有以 '.log' 结尾的文件并做成一个bzip包 
    dd if=/dev/hda of=/dev/fd0 bs=512 count=1 做一个将 MBR (Master Boot Record)内容复制到软盘的动作 
    dd if=/dev/fd0 of=/dev/hda bs=512 count=1 从已经保存到软盘的备份中恢复MBR内容 

     

    光盘:

    cdrecord -v gracetime=2 dev=/dev/cdrom -eject blank=fast -force 清空一个可复写的光盘内容 
    mkisofs /dev/cdrom > cd.iso 在磁盘上创建一个光盘的iso镜像文件 
    mkisofs /dev/cdrom | gzip > cd_iso.gz 在磁盘上创建一个压缩了的光盘iso镜像文件 
    mkisofs -J -allow-leading-dots -R -V "Label CD" -iso-level 4 -o ./cd.iso data_cd 创建一个目录的iso镜像文件 
    cdrecord -v dev=/dev/cdrom cd.iso 刻录一个ISO镜像文件 
    gzip -dc cd_iso.gz | cdrecord dev=/dev/cdrom - 刻录一个压缩了的ISO镜像文件 
    mount -o loop cd.iso /mnt/iso 挂载一个ISO镜像文件 
    cd-paranoia -B 从一个CD光盘转录音轨到 wav 文件中 
    cd-paranoia -- "-3" 从一个CD光盘转录音轨到 wav 文件中(参数-3) 
    cdrecord --scanbus 扫描总线以识别scsi通道 
    dd if=/dev/hdc | md5sum 校验一个设备的md5sum编码,例如一张 CD

    系统权限及用户授权相关命令

    chmod

    改变文件或目录权限。

    示例:

    chmod ugo+rwx directory1 设置目录的所有人(u)、群组(g)以及其他人(o)以读(r )、写(w)和执行(x)的权限 
    chmod go-rwx directory1 删除群组(g)与其他人(o)对目录的读写执行权限 
    chown user1 file1 改变一个文件的所有人属性 
    chown -R user1 directory1 改变一个目录的所有人属性并同时改变改目录下所有文件的属性 
    chgrp group1 file1 改变文件的群组 
    chown user1:group1 file1 改变一个文件的所有人和群组属性 
    find / -perm -u+s 罗列一个系统中所有使用了SUID控制的文件 
    chmod u+s /bin/file1 设置一个二进制文件的 SUID 位 - 运行该文件的用户也被赋予和所有者同样的权限 
    chmod u-s /bin/file1 禁用一个二进制文件的 SUID位 
    chmod g+s /home/public 设置一个目录的SGID 位 - 类似SUID ,不过这是针对目录的 
    chmod g-s /home/public 禁用一个目录的 SGID 位 
    chmod o+t /home/public 设置一个文件的 STIKY 位 - 只允许合法所有人删除文件 
    chmod o-t /home/public 禁用一个目录的 STIKY 位 

    chown

    改变文件或目录的属主和属组。

    chgrp

    更改文件用户组。

    umask

    显示或设置权限掩码。

    查看系统用户登陆信息的命令

    whoami

    显示当前有效的用户名称,相当于执行id -un命令。

    who

    显示目前登录系统的用户信息。

    w

    显示已经登陆系统的用户列表,并显示用户正在执行的指令。

    last

    显示登入系统的用户。

    lastlog

    显示系统中所有用户最近一次登录信息。

    users

    显示当前登录系统的所有用户的用户列表。

    finger

    查找并显示用户信息。

    内置命令及其它

    apt

    APT 软件工具 (Debian, Ubuntu 以及类似系统) 

    示例:

    apt-get install package_name 安装/更新一个 deb 包 
    apt-cdrom install package_name 从光盘安装/更新一个 deb 包 
    apt-get update 升级列表中的软件包 
    apt-get upgrade 升级所有已安装的软件 
    apt-get remove package_name 从系统删除一个deb包 
    apt-get check 确认依赖的软件仓库正确 
    apt-get clean 从下载的软件包中清理缓存 
    apt-cache search searched-package 返回包含所要搜索字符串的软件包名称 

    echo

    打印变量,或直接输出指定的字符串

    printf

    将结果格式化输出到标准输出。

    rpm

    管理rpm包的命令。

    示例:(Fedora, Redhat及类似系统) 

    rpm -ivh package.rpm 安装一个rpm包 
    rpm -ivh --nodeeps package.rpm 安装一个rpm包而忽略依赖关系警告 
    rpm -U package.rpm 更新一个rpm包但不改变其配置文件 
    rpm -F package.rpm 更新一个确定已经安装的rpm包 
    rpm -e package_name.rpm 删除一个rpm包 
    rpm -qa 显示系统中所有已经安装的rpm包 
    rpm -qa | grep httpd 显示所有名称中包含 "httpd" 字样的rpm包 
    rpm -qi package_name 获取一个已安装包的特殊信息 
    rpm -qg "System Environment/Daemons" 显示一个组件的rpm包 
    rpm -ql package_name 显示一个已经安装的rpm包提供的文件列表 
    rpm -qc package_name 显示一个已经安装的rpm包提供的配置文件列表 
    rpm -q package_name --whatrequires 显示与一个rpm包存在依赖关系的列表 
    rpm -q package_name --whatprovides 显示一个rpm包所占的体积 
    rpm -q package_name --scripts 显示在安装/删除期间所执行的脚本l 
    rpm -q package_name --changelog 显示一个rpm包的修改历史 
    rpm -qf /etc/httpd/conf/httpd.conf 确认所给的文件由哪个rpm包所提供 
    rpm -qp package.rpm -l 显示由一个尚未安装的rpm包提供的文件列表 
    rpm --import /media/cdrom/RPM-GPG-KEY 导入公钥数字证书 
    rpm --checksig package.rpm 确认一个rpm包的完整性 
    rpm -qa gpg-pubkey 确认已安装的所有rpm包的完整性 
    rpm -V package_name 检查文件尺寸、 许可、类型、所有者、群组、MD5检查以及最后修改时间 
    rpm -Va 检查系统中所有已安装的rpm包- 小心使用 
    rpm -Vp package.rpm 确认一个rpm包还未安装 
    rpm2cpio package.rpm | cpio --extract --make-directories *bin* 从一个rpm包运行可执行文件 
    rpm -ivh /usr/src/redhat/RPMS/`arch`/package.rpm 从一个rpm源码安装一个构建好的包 
    rpmbuild --rebuild package_name.src.rpm 从一个rpm源码构建一个 rpm 包

    yum

    自动化简单化地管理rpm包的命令。

    示例:YUM 软件包升级器 - (Fedora, RedHat及类似系统) 

    yum install package_name 下载并安装一个rpm包 
    yum localinstall package_name.rpm 将安装一个rpm包,使用你自己的软件仓库为你解决所有依赖关系 
    yum update package_name.rpm 更新当前系统中所有安装的rpm包 
    yum update package_name 更新一个rpm包 
    yum remove package_name 删除一个rpm包 
    yum list 列出当前系统中安装的所有包 
    yum search package_name 在rpm仓库中搜寻软件包 
    yum clean packages 清理rpm缓存删除下载的包 
    yum clean headers 删除所有头文件 
    yum clean all 删除所有缓存的包和头文件 

    watch

    周期性的执行给定的命令,并将命令的输出以全屏方式显示。

    alias

    设置系统别名。

    unalias

    取消系统别名。

    date

    查看或设置系统时间。

    clear

    清除屏幕,简称清屏。

    history

    查看命令执行的历史纪录。

    eject

    弹出光驱。

    time

    计算命令执行时间。

    nc

    功能强大的网络工具。

    xargs

    将标准输入转换成命令行参数。

    exec

    调用并执行指令的命令。

    export

    设置或者显示环境变量。

    unset

    删除变量或函数。

    type

    用于判断另外一个命令是否是内置命令。

    bc

    命令行科学计算器

    系统管理与性能监视命令

    chkconfig

    管理Linux系统开机启动项。

    vmstat

    虚拟内存统计。

    mpstat

    显示各个可用CPU的状态统计。

    iostat

    统计系统IO。

    sar

    全面地获取系统的CPU、运行队列、磁盘 I/O、分页(交换区)、内存、 CPU中断和网络等性能数据。

    ipcs

    用于报告Linux中进程间通信设施的状态,显示的信息包括消息列表、共享内存和信号量的信息。

    ipcrm

    用来删除一个或更多的消息队列、信号量集或者共享内存标识。

    strace

    用于诊断、调试Linux用户空间跟踪器。我们用它来监控用户空间进程和内核的交互,比如系统调用、信号传递、进程状态变更等。

    ltrace

    命令会跟踪进程的库函数调用,它会显现出哪个库函数被调用。

    关机/重启/注销和查看系统信息的命令

    shutdown

    关机。

    示例:

    shutdown -h now 关闭系统(1) 
    init 0 关闭系统(2) 
    telinit 0 关闭系统(3) 
    shutdown -h hours:minutes & 按预定时间关闭系统 
    shutdown -c 取消按预定时间关闭系统 
    shutdown -r now 重启(1) 

    halt

    关机。

    reboot 重启。

    poweroff

    关闭电源。

    logout

    注销,退出当前登录的Shell。

    exit

    退出当前登录的Shell。

    Ctrl+d

    退出当前登录的Shell的快捷键。

    进程管理相关命令

    bg

    将一个在后台暂停的命令,变成继续执行  (在后台执行)。

    fg

    将后台中的命令调至前台继续运行。

    jobs

    查看当前有多少在后台运行的命令。

    kill

    终止进程。

    killall

    通过进程名终止进程。

    pkill

    通过进程名终止进程。

    crontab

    定时任务命令。

    ps

    显示进程的快照。

    pstree

    树形显示进程。

    nice/renice

    调整程序运行的优先级。

    nohup

    忽略挂起信号运行指定的命令。

    pgrep

    查找匹配条件的进程。

    runlevel

    查看系统当前运行级别。

    init

    切换运行级别。

    service

    启动、停止、重新启动和关闭系统服务,还可以显示所有系统服务的当前状态。

    展开全文
  • 乍拿到命令行操作起来还是不那么习惯,但是大佬们黑客们喜欢他自是有他的原因的,在此总结一下linux常用命令和终端的一些快捷键:<hr noshade size=5 align=center width=50%>linux终端快捷键Ctrl+Alt+T 打开终端Ctrl...

        最近在学习linux,习惯了可视化窗口界面的人机交互,乍拿到命令行操作起来还是不那么习惯,但是大佬们黑客们喜欢他自是有他的原因的,在此总结一下linux常用命令和终端的一些快捷键:


    linux终端快捷键

    Ctrl+Alt+T 打开终端
    Ctrl+L 清空屏幕(功能相当于命令clear)
    Ctrl+U 剪切文本直到行的起始(可以用于清空行)
    Ctrl+K 剪切文本直到行的末尾
    Ctrl+Y 粘贴最近剪切的文本
    Ctrl+C 杀死当前进程(也可以用来清空当前行)
    Ctrl+D 退出当前Shell(功能相当于命令exit) 或者 删除当前的字符
    Ctrl+A 行首
    Ctrl+E 行尾
    Home/End 行首/行尾
    Ctrl+F 向前移动一个字符
    Ctrl+B 向后移动一个字符
    Ctrl+P 或 Ctrl+N 上下历史记录
    上下方向键 上下历史记录
    Ctrl+Shift+C 复制
    Ctrl+Shift+V 粘贴
    还有Tab补全,按住Ctrl键进行块选择.
    鼠标中键:粘贴(在gnome-terminal中使用"菜单键+P"也是可以粘贴的)


    Ctrl + d        删除一个字符,相当于通常的Delete键(命令行若无所有字符,则相当于exit;处理多行标准输入时也表示eof)
    Ctrl + h        退格删除一个字符,相当于通常的Backspace键
    Ctrl + u        删除光标之前到行首的字符
    Ctrl + k        删除光标之前到行尾的字符
    Ctrl + c        取消当前行输入的命令,相当于Ctrl + Break
    Ctrl + a        光标移动到行首(Ahead of line),相当于通常的Home键
    Ctrl + e        光标移动到行尾(End of line)
    Ctrl + f        光标向前(Forward)移动一个字符位置
    Ctrl + b        光标往回(Backward)移动一个字符位置
    Ctrl + l        清屏,相当于执行clear命令
    Ctrl + p        调出命令历史中的前一条(Previous)命令,相当于通常的上箭头
    Ctrl + n        调出命令历史中的下一条(Next)命令,相当于通常的上箭头
    Ctrl + r        显示:号提示,根据用户输入查找相关历史命令(reverse-i-search)


    Alt + f         光标向前(Forward)移动到下一个单词
    Alt + b         光标往回(Backward)移动到前一个单词
    Ctrl + w        删除从光标位置前到当前所处单词(Word)的开头
    Alt + d         删除从光标位置到当前所处单词的末尾

    Ctrl + y        粘贴最后一次被删除的单词

    系统相关

    arch 显示机器的处理器架构(1) 
    uname -m 显示机器的处理器架构(2) 
    uname -r 显示正在使用的内核版本 
    dmidecode -q 显示硬件系统部件 - (SMBIOS / DMI) 
    hdparm -i /dev/hda 罗列一个磁盘的架构特性 
    hdparm -tT /dev/sda 在磁盘上执行测试性读取操作 
    cat /proc/cpuinfo 显示CPU info的信息 
    cat /proc/interrupts 显示中断 
    cat /proc/meminfo 校验内存使用 
    cat /proc/swaps 显示哪些swap被使用 
    cat /proc/version 显示内核的版本 
    cat /proc/net/dev 显示网络适配器及统计 
    cat /proc/mounts 显示已加载的文件系统 
    lspci -tv 罗列 PCI 设备 
    lsusb -tv 显示 USB 设备 
    date 显示系统日期 
    cal 2007 显示2007年的日历表 
    date 041217002007.00 设置日期和时间 - 月日时分年.秒 
    clock -w 将时间修改保存到 BIOS 
    关机 (系统的关机、重启以及登出 ) 
    shutdown -h now 关闭系统(1) 
    init 0 关闭系统(2) 
    telinit 0 关闭系统(3) 
    shutdown -h hours:minutes & 按预定时间关闭系统 
    shutdown -c 取消按预定时间关闭系统 
    shutdown -r now 重启(1) 
    reboot 重启(2) 
    logout 注销 

    文件和目录操作

    cd /home 进入 '/ home' 目录' 
    cd .. 返回上一级目录 
    cd ../.. 返回上两级目录 
    cd 进入个人的主目录 
    cd ~user1 进入个人的主目录 
    cd - 返回上次所在的目录 
    pwd 显示工作路径 
    ls 查看目录中的文件 
    ls -F 查看目录中的文件 
    ls -l 显示文件和目录的详细资料 
    ls -a 显示隐藏文件 
    ls *[0-9]* 显示包含数字的文件名和目录名 
    tree 显示文件和目录由根目录开始的树形结构(1) 
    lstree 显示文件和目录由根目录开始的树形结构(2) 
    mkdir dir1 创建一个叫做 'dir1' 的目录' 
    mkdir dir1 dir2 同时创建两个目录 
    mkdir -p /tmp/dir1/dir2 创建一个目录树 
    rm -f file1 删除一个叫做 'file1' 的文件' 
    rmdir dir1 删除一个叫做 'dir1' 的目录' 
    rm -rf dir1 删除一个叫做 'dir1' 的目录并同时删除其内容 
    rm -rf dir1 dir2 同时删除两个目录及它们的内容 
    mv dir1 new_dir 重命名/移动 一个目录 
    cp file1 file2 复制一个文件 
    cp dir/* . 复制一个目录下的所有文件到当前工作目录 
    cp -a /tmp/dir1 . 复制一个目录到当前工作目录 
    cp -a dir1 dir2 复制一个目录 
    ln -s file1 lnk1 创建一个指向文件或目录的软链接 
    ln file1 lnk1 创建一个指向文件或目录的物理链接 
    touch -t 0712250000 file1 修改一个文件或目录的时间戳 - (YYMMDDhhmm) 
    file file1 outputs the mime type of the file as text 
    iconv -l 列出已知的编码 
    iconv -f fromEncoding -t toEncoding inputFile > outputFile creates a new from the given input file by assuming it is encoded in fromEncoding and converting it to toEncoding. 
    find . -maxdepth 1 -name *.jpg -print -exec convert "{}" -resize 80x60 "thumbs/{}" \; batch resize files in the current directory and send them to a thumbnails directory (requires convert from Imagemagick) 

    文件搜索 

    find / -name file1 从 '/' 开始进入根文件系统搜索文件和目录 
    find / -user user1 搜索属于用户 'user1' 的文件和目录 
    find /home/user1 -name \*.bin 在目录 '/ home/user1' 中搜索带有'.bin' 结尾的文件 
    find /usr/bin -type f -atime +100 搜索在过去100天内未被使用过的执行文件 
    find /usr/bin -type f -mtime -10 搜索在10天内被创建或者修改过的文件 
    find / -name \*.rpm -exec chmod 755 '{}' \; 搜索以 '.rpm' 结尾的文件并定义其权限 
    find / -xdev -name \*.rpm 搜索以 '.rpm' 结尾的文件,忽略光驱、捷盘等可移动设备 
    locate \*.ps 寻找以 '.ps' 结尾的文件 - 先运行 'updatedb' 命令 
    whereis halt 显示一个二进制文件、源码或man的位置 
    which halt 显示一个二进制文件或可执行文件的完整路径 

    挂载一个文件系统 

    mount /dev/hda2 /mnt/hda2 挂载一个叫做hda2的盘 - 确定目录 '/ mnt/hda2' 已经存在 
    umount /dev/hda2 卸载一个叫做hda2的盘 - 先从挂载点 '/ mnt/hda2' 退出 
    fuser -km /mnt/hda2 当设备繁忙时强制卸载 
    umount -n /mnt/hda2 运行卸载操作而不写入 /etc/mtab 文件- 当文件为只读或当磁盘写满时非常有用 
    mount /dev/fd0 /mnt/floppy 挂载一个软盘 
    mount /dev/cdrom /mnt/cdrom 挂载一个cdrom或dvdrom 
    mount /dev/hdc /mnt/cdrecorder 挂载一个cdrw或dvdrom 
    mount /dev/hdb /mnt/cdrecorder 挂载一个cdrw或dvdrom 
    mount -o loop file.iso /mnt/cdrom 挂载一个文件或ISO镜像文件 
    mount -t vfat /dev/hda5 /mnt/hda5 挂载一个Windows FAT32文件系统 
    mount /dev/sda1 /mnt/usbdisk 挂载一个usb 捷盘或闪存设备 
    mount -t smbfs -o username=user,password=pass //WinClient/share /mnt/share 挂载一个windows网络共享 

    磁盘空间 

    df -h 显示已经挂载的分区列表 
    ls -lSr |more 以尺寸大小排列文件和目录 
    du -sh dir1 估算目录 'dir1' 已经使用的磁盘空间' 
    du -sk * | sort -rn 以容量大小为依据依次显示文件和目录的大小 
    rpm -q -a --qf '%10{SIZE}t%{NAME}n' | sort -k1,1n 以大小为依据依次显示已安装的rpm包所使用的空间 (fedora, redhat类系统) 
    dpkg-query -W -f='${Installed-Size;10}t${Package}n' | sort -k1,1n 以大小为依据显示已安装的deb包所使用的空间 (ubuntu, debian类系统) 

    用户和群组 

    groupadd group_name 创建一个新用户组 
    groupdel group_name 删除一个用户组 
    groupmod -n new_group_name old_group_name 重命名一个用户组 
    useradd -c "Name Surname " -g admin -d /home/user1 -s /bin/bash user1 创建一个属于 "admin" 用户组的用户 
    useradd user1 创建一个新用户 
    userdel -r user1 删除一个用户 ( '-r' 排除主目录) 
    usermod -c "User FTP" -g system -d /ftp/user1 -s /bin/nologin user1 修改用户属性 
    passwd 修改口令 
    passwd user1 修改一个用户的口令 (只允许root执行) 
    chage -E 2005-12-31 user1 设置用户口令的失效期限 
    pwck 检查 '/etc/passwd' 的文件格式和语法修正以及存在的用户 
    grpck 检查 '/etc/passwd' 的文件格式和语法修正以及存在的群组 
    newgrp group_name 登陆进一个新的群组以改变新创建文件的预设群组 

    文件的权限 - 使用 "+" 设置权限,使用 "-" 用于取消 

    ls -lh 显示权限 
    ls /tmp | pr -T5 -W$COLUMNS 将终端划分成5栏显示 
    chmod ugo+rwx directory1 设置目录的所有人(u)、群组(g)以及其他人(o)以读(r )、写(w)和执行(x)的权限 
    chmod go-rwx directory1 删除群组(g)与其他人(o)对目录的读写执行权限 
    chown user1 file1 改变一个文件的所有人属性 
    chown -R user1 directory1 改变一个目录的所有人属性并同时改变改目录下所有文件的属性 
    chgrp group1 file1 改变文件的群组 
    chown user1:group1 file1 改变一个文件的所有人和群组属性 
    find / -perm -u+s 罗列一个系统中所有使用了SUID控制的文件 
    chmod u+s /bin/file1 设置一个二进制文件的 SUID 位 - 运行该文件的用户也被赋予和所有者同样的权限 
    chmod u-s /bin/file1 禁用一个二进制文件的 SUID位 
    chmod g+s /home/public 设置一个目录的SGID 位 - 类似SUID ,不过这是针对目录的 
    chmod g-s /home/public 禁用一个目录的 SGID 位 
    chmod o+t /home/public 设置一个文件的 STIKY 位 - 只允许合法所有人删除文件 
    chmod o-t /home/public 禁用一个目录的 STIKY 位 

    文件属性 - 使用 "+" 设置权限,使用 "-" 用于取消 

    chattr +a file1 只允许以追加方式读写文件 
    chattr +c file1 允许这个文件能被内核自动压缩/解压 
    chattr +d file1 在进行文件系统备份时,dump程序将忽略这个文件 
    chattr +i file1 设置成不可变的文件,不能被删除、修改、重命名或者链接 
    chattr +s file1 允许一个文件被安全地删除 
    chattr +S file1 一旦应用程序对这个文件执行了写操作,使系统立刻把修改的结果写到磁盘 
    chattr +u file1 若文件被删除,系统会允许你在以后恢复这个被删除的文件 
    lsattr 显示特殊的属性 


    打包和压缩文件 

    bunzip2 file1.bz2 解压一个叫做 'file1.bz2'的文件 
    bzip2 file1 压缩一个叫做 'file1' 的文件 
    gunzip file1.gz 解压一个叫做 'file1.gz'的文件 
    gzip file1 压缩一个叫做 'file1'的文件 
    gzip -9 file1 最大程度压缩 
    rar a file1.rar test_file 创建一个叫做 'file1.rar' 的包 
    rar a file1.rar file1 file2 dir1 同时压缩 'file1', 'file2' 以及目录 'dir1' 
    rar x file1.rar 解压rar包 
    unrar x file1.rar 解压rar包 
    tar -cvf archive.tar file1 创建一个非压缩的 tarball 
    tar -cvf archive.tar file1 file2 dir1 创建一个包含了 'file1', 'file2' 以及 'dir1'的档案文件 
    tar -tf archive.tar 显示一个包中的内容 
    tar -xvf archive.tar 释放一个包 
    tar -xvf archive.tar -C /tmp 将压缩包释放到 /tmp目录下 
    tar -cvfj archive.tar.bz2 dir1 创建一个bzip2格式的压缩包 
    tar -xvfj archive.tar.bz2 解压一个bzip2格式的压缩包 
    tar -cvfz archive.tar.gz dir1 创建一个gzip格式的压缩包 
    tar -xvfz archive.tar.gz 解压一个gzip格式的压缩包 
    zip file1.zip file1 创建一个zip格式的压缩包 
    zip -r file1.zip file1 file2 dir1 将几个文件和目录同时压缩成一个zip格式的压缩包 
    unzip file1.zip 解压一个zip格式压缩包 


    RPM 包 - (Fedora, Redhat及类似系统) 

    rpm -ivh package.rpm 安装一个rpm包 
    rpm -ivh --nodeeps package.rpm 安装一个rpm包而忽略依赖关系警告 
    rpm -U package.rpm 更新一个rpm包但不改变其配置文件 
    rpm -F package.rpm 更新一个确定已经安装的rpm包 
    rpm -e package_name.rpm 删除一个rpm包 
    rpm -qa 显示系统中所有已经安装的rpm包 
    rpm -qa | grep httpd 显示所有名称中包含 "httpd" 字样的rpm包 
    rpm -qi package_name 获取一个已安装包的特殊信息 
    rpm -qg "System Environment/Daemons" 显示一个组件的rpm包 
    rpm -ql package_name 显示一个已经安装的rpm包提供的文件列表 
    rpm -qc package_name 显示一个已经安装的rpm包提供的配置文件列表 
    rpm -q package_name --whatrequires 显示与一个rpm包存在依赖关系的列表 
    rpm -q package_name --whatprovides 显示一个rpm包所占的体积 
    rpm -q package_name --scripts 显示在安装/删除期间所执行的脚本l 
    rpm -q package_name --changelog 显示一个rpm包的修改历史 
    rpm -qf /etc/httpd/conf/httpd.conf 确认所给的文件由哪个rpm包所提供 
    rpm -qp package.rpm -l 显示由一个尚未安装的rpm包提供的文件列表 
    rpm --import /media/cdrom/RPM-GPG-KEY 导入公钥数字证书 
    rpm --checksig package.rpm 确认一个rpm包的完整性 
    rpm -qa gpg-pubkey 确认已安装的所有rpm包的完整性 
    rpm -V package_name 检查文件尺寸、 许可、类型、所有者、群组、MD5检查以及最后修改时间 
    rpm -Va 检查系统中所有已安装的rpm包- 小心使用 
    rpm -Vp package.rpm 确认一个rpm包还未安装 
    rpm2cpio package.rpm | cpio --extract --make-directories *bin* 从一个rpm包运行可执行文件 
    rpm -ivh /usr/src/redhat/RPMS/`arch`/package.rpm 从一个rpm源码安装一个构建好的包 
    rpmbuild --rebuild package_name.src.rpm 从一个rpm源码构建一个 rpm 包 

    YUM 软件包升级器 - (Fedora, RedHat及类似系统) 

    yum install package_name 下载并安装一个rpm包 
    yum localinstall package_name.rpm 将安装一个rpm包,使用你自己的软件仓库为你解决所有依赖关系 
    yum update package_name.rpm 更新当前系统中所有安装的rpm包 
    yum update package_name 更新一个rpm包 
    yum remove package_name 删除一个rpm包 
    yum list 列出当前系统中安装的所有包 
    yum search package_name 在rpm仓库中搜寻软件包 
    yum clean packages 清理rpm缓存删除下载的包 
    yum clean headers 删除所有头文件 
    yum clean all 删除所有缓存的包和头文件 

    DEB 包 (Debian, Ubuntu 以及类似系统) 

    dpkg -i package.deb 安装/更新一个 deb 包 
    dpkg -r package_name 从系统删除一个 deb 包 
    dpkg -l 显示系统中所有已经安装的 deb 包 
    dpkg -l | grep httpd 显示所有名称中包含 "httpd" 字样的deb包 
    dpkg -s package_name 获得已经安装在系统中一个特殊包的信息 
    dpkg -L package_name 显示系统中已经安装的一个deb包所提供的文件列表 
    dpkg --contents package.deb 显示尚未安装的一个包所提供的文件列表 
    dpkg -S /bin/ping 确认所给的文件由哪个deb包提供 

    APT 软件工具 (Debian, Ubuntu 以及类似系统) 

    apt-get install package_name 安装/更新一个 deb 包 
    apt-cdrom install package_name 从光盘安装/更新一个 deb 包 
    apt-get update 升级列表中的软件包 
    apt-get upgrade 升级所有已安装的软件 
    apt-get remove package_name 从系统删除一个deb包 
    apt-get check 确认依赖的软件仓库正确 
    apt-get clean 从下载的软件包中清理缓存 
    apt-cache search searched-package 返回包含所要搜索字符串的软件包名称 

    查看文件内容 

    cat file1 从第一个字节开始正向查看文件的内容 
    tac file1 从最后一行开始反向查看一个文件的内容 
    more file1 查看一个长文件的内容 
    less file1 类似于 'more' 命令,但是它允许在文件中和正向操作一样的反向操作 
    head -2 file1 查看一个文件的前两行 
    tail -2 file1 查看一个文件的最后两行 
    tail -f /var/log/messages 实时查看被添加到一个文件中的内容 

    文本处理 

    cat file1 file2 ... | command <> file1_in.txt_or_file1_out.txt general syntax for text manipulation using PIPE, STDIN and STDOUT 
    cat file1 | command( sed, grep, awk, grep, etc...) > result.txt 合并一个文件的详细说明文本,并将简介写入一个新文件中 
    cat file1 | command( sed, grep, awk, grep, etc...) >> result.txt 合并一个文件的详细说明文本,并将简介写入一个已有的文件中 
    grep Aug /var/log/messages 在文件 '/var/log/messages'中查找关键词"Aug" 
    grep ^Aug /var/log/messages 在文件 '/var/log/messages'中查找以"Aug"开始的词汇 
    grep [0-9] /var/log/messages 选择 '/var/log/messages' 文件中所有包含数字的行 
    grep Aug -R /var/log/* 在目录 '/var/log' 及随后的目录中搜索字符串"Aug" 
    sed 's/stringa1/stringa2/g' example.txt 将example.txt文件中的 "string1" 替换成 "string2" 
    sed '/^$/d' example.txt 从example.txt文件中删除所有空白行 
    sed '/ *#/d; /^$/d' example.txt 从example.txt文件中删除所有注释和空白行 
    echo 'esempio' | tr '[:lower:]' '[:upper:]' 合并上下单元格内容 
    sed -e '1d' result.txt 从文件example.txt 中排除第一行 
    sed -n '/stringa1/p' 查看只包含词汇 "string1"的行 
    sed -e 's/ *$//' example.txt 删除每一行最后的空白字符 
    sed -e 's/stringa1//g' example.txt 从文档中只删除词汇 "string1" 并保留剩余全部 
    sed -n '1,5p;5q' example.txt 查看从第一行到第5行内容 
    sed -n '5p;5q' example.txt 查看第5行 
    sed -e 's/00*/0/g' example.txt 用单个零替换多个零 
    cat -n file1 标示文件的行数 
    cat example.txt | awk 'NR%2==1' 删除example.txt文件中的所有偶数行 
    echo a b c | awk '{print $1}' 查看一行第一栏 
    echo a b c | awk '{print $1,$3}' 查看一行的第一和第三栏 
    paste file1 file2 合并两个文件或两栏的内容 
    paste -d '+' file1 file2 合并两个文件或两栏的内容,中间用"+"区分 
    sort file1 file2 排序两个文件的内容 
    sort file1 file2 | uniq 取出两个文件的并集(重复的行只保留一份) 
    sort file1 file2 | uniq -u 删除交集,留下其他的行 
    sort file1 file2 | uniq -d 取出两个文件的交集(只留下同时存在于两个文件中的文件) 
    comm -1 file1 file2 比较两个文件的内容只删除 'file1' 所包含的内容 
    comm -2 file1 file2 比较两个文件的内容只删除 'file2' 所包含的内容 
    comm -3 file1 file2 比较两个文件的内容只删除两个文件共有的部分 

    字符设置和文件格式转换 

    dos2unix filedos.txt fileunix.txt 将一个文本文件的格式从MSDOS转换成UNIX 
    unix2dos fileunix.txt filedos.txt 将一个文本文件的格式从UNIX转换成MSDOS 
    recode ..HTML < page.txt > page.html 将一个文本文件转换成html 
    recode -l | more 显示所有允许的转换格式 

    文件系统分析 

    badblocks -v /dev/hda1 检查磁盘hda1上的坏磁块 
    fsck /dev/hda1 修复/检查hda1磁盘上linux文件系统的完整性 
    fsck.ext2 /dev/hda1 修复/检查hda1磁盘上ext2文件系统的完整性 
    e2fsck /dev/hda1 修复/检查hda1磁盘上ext2文件系统的完整性 
    e2fsck -j /dev/hda1 修复/检查hda1磁盘上ext3文件系统的完整性 
    fsck.ext3 /dev/hda1 修复/检查hda1磁盘上ext3文件系统的完整性 
    fsck.vfat /dev/hda1 修复/检查hda1磁盘上fat文件系统的完整性 
    fsck.msdos /dev/hda1 修复/检查hda1磁盘上dos文件系统的完整性 
    dosfsck /dev/hda1 修复/检查hda1磁盘上dos文件系统的完整性 

    初始化一个文件系统 

    mkfs /dev/hda1 在hda1分区创建一个文件系统 
    mke2fs /dev/hda1 在hda1分区创建一个linux ext2的文件系统 
    mke2fs -j /dev/hda1 在hda1分区创建一个linux ext3(日志型)的文件系统 
    mkfs -t vfat 32 -F /dev/hda1 创建一个 FAT32 文件系统 
    fdformat -n /dev/fd0 格式化一个软盘 
    mkswap /dev/hda3 创建一个swap文件系统 

    SWAP文件系统 

    mkswap /dev/hda3 创建一个swap文件系统 
    swapon /dev/hda3 启用一个新的swap文件系统 
    swapon /dev/hda2 /dev/hdb3 启用两个swap分区 

    备份 

    dump -0aj -f /tmp/home0.bak /home 制作一个 '/home' 目录的完整备份 
    dump -1aj -f /tmp/home0.bak /home 制作一个 '/home' 目录的交互式备份 
    restore -if /tmp/home0.bak 还原一个交互式备份 
    rsync -rogpav --delete /home /tmp 同步两边的目录 
    rsync -rogpav -e ssh --delete /home ip_address:/tmp 通过SSH通道rsync 
    rsync -az -e ssh --delete ip_addr:/home/public /home/local 通过ssh和压缩将一个远程目录同步到本地目录 
    rsync -az -e ssh --delete /home/local ip_addr:/home/public 通过ssh和压缩将本地目录同步到远程目录 
    dd bs=1M if=/dev/hda | gzip | ssh user@ip_addr 'dd of=hda.gz' 通过ssh在远程主机上执行一次备份本地磁盘的操作 
    dd if=/dev/sda of=/tmp/file1 备份磁盘内容到一个文件 
    tar -Puf backup.tar /home/user 执行一次对 '/home/user' 目录的交互式备份操作 
    ( cd /tmp/local/ && tar c . ) | ssh -C user@ip_addr 'cd /home/share/ && tar x -p' 通过ssh在远程目录中复制一个目录内容 
    ( tar c /home ) | ssh -C user@ip_addr 'cd /home/backup-home && tar x -p' 通过ssh在远程目录中复制一个本地目录 
    tar cf - . | (cd /tmp/backup ; tar xf - ) 本地将一个目录复制到另一个地方,保留原有权限及链接 
    find /home/user1 -name '*.txt' | xargs cp -av --target-directory=/home/backup/ --parents 从一个目录查找并复制所有以 '.txt' 结尾的文件到另一个目录 
    find /var/log -name '*.log' | tar cv --files-from=- | bzip2 > log.tar.bz2 查找所有以 '.log' 结尾的文件并做成一个bzip包 
    dd if=/dev/hda of=/dev/fd0 bs=512 count=1 做一个将 MBR (Master Boot Record)内容复制到软盘的动作 
    dd if=/dev/fd0 of=/dev/hda bs=512 count=1 从已经保存到软盘的备份中恢复MBR内容 

    光盘 

    cdrecord -v gracetime=2 dev=/dev/cdrom -eject blank=fast -force 清空一个可复写的光盘内容 
    mkisofs /dev/cdrom > cd.iso 在磁盘上创建一个光盘的iso镜像文件 
    mkisofs /dev/cdrom | gzip > cd_iso.gz 在磁盘上创建一个压缩了的光盘iso镜像文件 
    mkisofs -J -allow-leading-dots -R -V "Label CD" -iso-level 4 -o ./cd.iso data_cd 创建一个目录的iso镜像文件 
    cdrecord -v dev=/dev/cdrom cd.iso 刻录一个ISO镜像文件 
    gzip -dc cd_iso.gz | cdrecord dev=/dev/cdrom - 刻录一个压缩了的ISO镜像文件 
    mount -o loop cd.iso /mnt/iso 挂载一个ISO镜像文件 
    cd-paranoia -B 从一个CD光盘转录音轨到 wav 文件中 
    cd-paranoia -- "-3" 从一个CD光盘转录音轨到 wav 文件中(参数-3) 
    cdrecord --scanbus 扫描总线以识别scsi通道 
    dd if=/dev/hdc | md5sum 校验一个设备的md5sum编码,例如一张 CD 

    网络相关- (以太网和WIFI无线) 

    ifconfig eth0 显示一个以太网卡的配置 
    ifup eth0 启用一个 'eth0' 网络设备 
    ifdown eth0 禁用一个 'eth0' 网络设备 
    ifconfig eth0 192.168.1.1 netmask 255.255.255.0 控制IP地址 
    ifconfig eth0 promisc 设置 'eth0' 成混杂模式以嗅探数据包 (sniffing) 
    dhclient eth0 以dhcp模式启用 'eth0' 
    route -n show routing table 
    route add -net 0/0 gw IP_Gateway configura default gateway 
    route add -net 192.168.0.0 netmask 255.255.0.0 gw 192.168.1.1 configure static route to reach network '192.168.0.0/16' 
    route del 0/0 gw IP_gateway remove static route 
    echo "1" > /proc/sys/net/ipv4/ip_forward activate ip routing 
    hostname show hostname of system 
    host www.example.com lookup hostname to resolve name to ip address and viceversa(1) 
    nslookup www.example.com lookup hostname to resolve name to ip address and viceversa(2) 
    ip link show show link status of all interfaces 
    mii-tool eth0 show link status of 'eth0' 
    ethtool eth0 show statistics of network card 'eth0' 
    netstat -tup show all active network connections and their PID 
    netstat -tupl show all network services listening on the system and their PID 
    tcpdump tcp port 80 show all HTTP traffic 
    iwlist scan show wireless networks 
    iwconfig eth1 show configuration of a wireless network card 
    hostname show hostname 
    host www.example.com lookup hostname to resolve name to ip address and viceversa 
    nslookup www.example.com lookup hostname to resolve name to ip address and viceversa 
    whois www.example.com lookup on Whois database 


    展开全文
  • Linux终端上的github

    2018-07-20 13:34:47
    经过之前的学习,相信大家现在已经能够进入Linux系统了! 恭喜你们,现在有了一个比Windows好些的开发平台。 接下来我的这篇博客的目的是教你们使用开发者手中的利器–github.com 什么是Github 简单而非学术的说...

    欢迎各位来到木犀团队后端组星计划Github部分

    经过之前的学习,相信大家现在已经能够进入Linux系统了!
    恭喜你们,现在有了一个比Windows好些的开发平台。
    接下来我的这篇博客的目的是教你们使用开发者手中的利器–github.com

    什么是Github

    简单而非学术的说:就是大家放代码的地方。
    你可以放自己的练习代码。
    也可以和别人一起开发。
    当然别人的代码是可以公开的,而你的代码也可以是公开的。

    这是一个开源网站,是属于开发人员的圣地–github


    首先我们应该拥有一个账户!

    不要以为纯英文界面都会被墙!
    github是使用国内的网络就可以访问的!
    网址:https://github.com
    或者百度github

    这里写图片描述

    这里是首页,如果心细的话可以去看看首页的话都是什么意思www
    我们点击右上角的Sign Up(注册

    这里写图片描述

    在下面填写个人信息,注意不能使用重复的用户名和邮箱。
    这里要注意用户名使用英文的,以免带来不必要的麻烦。
    密码设置要有一定的复杂度!
    我们点击create an account

    这里写图片描述

    第二步这里不要更改,直接点击continue

    这里写图片描述

    第三步,这里是让你写一些问题的答案。
    第一个问题是问你写代码的水平,如果你是小白的话就选第一个咯。
    第二个问题是问你为什么注册,我们选择Project Management.
    第三个问题是问你什么职业,显然是第一个。

    然后你就创建成功了!
    这里写图片描述

    这里有人发现不会验证邮箱对不对,但是千万不要大意,这个邮箱非常的重要的!!


    下载安装git-core

    Ubuntu系统的终端使用快捷键:Ctrl+Alt+T开启(T代表terminal)

    然后会出现一个很酷酷的命令行界面:

    这里写图片描述

    你会发现命令行界面总有一串字符串:(以我自己的为例)

    shiina@shiina-Inspiron-7559:~$
    

    在@前面是你这个Linux下的用户,默认是你进入系统的用户。但是在某些状态下,我们需要使用超级用户权限。

    我们使用

    sudo su
    

    这个命令,然后键入你的密码,就可以切换为超级管理员,此时你发现你的身份从shiina变成了root,root就是根用户,是超级用户(super user)

    然后使用快捷键Ctrl+D退回,我们回到shiina这个用户的状态。

    虽然超级用户是一个很方便的东西,但是要注意不要乱用。超级用户时创建更改的所有文件都对于普通用户是只读状态。如果要修改要递归更改权限。
    谨慎使用。
    

    然后我们使用

    sudo apt-get update
    
    sudo apt-get install git-core
    

    sudo就是使用super user的权限去do,可以使单独的命令具有超级用户权限。

    apt-get暂时可以看作是手机上的应用商店。update是更新的意思,我们先更新一下自己系统中的”应用商店”。

    install是安装的意思。git-core就是我们要安装的应用名称。怎么样,是不是简单明了?

    安装成功之后,输入

    git --help
    

    来查看git这个”应用”的一些功能。

    这里写图片描述


    把你之前注册的账户绑定到本地

    使用命令:

    git config --global user.name "your_name"
    git config --global user.email "your_email"
    

    这两个命令的作用是告知git这个”应用”你的身份信息。

    ps:your_name和your_email务必要填写正确
    

    创建一个仓库叭w

    使用浏览器之前的github官网页面,右上角进入个人主页:

    这里写图片描述

    然后点击到仓库(repository)的选项:

    这里写图片描述

    有一个很瞩目的NEW按钮,我们点击:
    这里写图片描述

    然后填写相关信息,包括仓库名称,描述信息等等

    这里写图片描述

    然后点击Create Repository

    出现了!是一堆看不懂的东西!

    这个页面代表你已经在github网站上创建了一个你自己的仓库。什么是仓库呢?就是集中放一类代码的地方。

    我们现在有仓库了,但是仓库里空空如也,如果使用浏览器页面进行交互,不仅上传文件太慢,而且没有逼格。


    使用终端进行文件上传!

    wa怎么这么长啊这个博客(抱怨)
    但是不要担心,这是最后一步了!

    还记得刚才的那个全是看不懂语句的页面吗?不要关掉!我们来分析这个页面。
    (当然关掉也无所谓啦~

    这里写图片描述

    在被蓝色高亮的部分,有一个链接在框框里,这个框框里的链接就是你的仓库的URL(统一资源定位符)

    https://github.com/YOUR_NAME/REPOSITORY_NAME.git
    

    这么一种格式↑很好记的,记住的话就可以自然而然写出这个链接。

    视线向下移动,有一句话叫做:

    ...or create a new repository on the command line
    。。。或者用命令行创建一个新的仓库
    

    下面的命令挨个输入到命令行就好了…但是需要一些事先准备:

    仓库在电脑本机上的出现形式是:文件夹
    所以我们要用命令行创建新文件夹ww
    和视图界面不同。。我们不需要 鼠标

    mkdir REPOSITORY_NAME
    //REPOSITORY_NAME是你仓库的名字
    cd REPOSITORY_NAME
    //进入文件夹
    

    然后就可以执行网页给你的命令了,但是我要更改一下顺序:

    git init
    //把这个文件夹变成本地的一个仓库
    git remote add origin https://github.com/YOUR_NAME/REPOSITORY_NAME.git
    //把本地仓库和github上的仓库对接起来
    

    此时,我们已经把本地仓库和远程仓库对接起来了w,接下来我们新建一个文件,然后上传!

    echo "# REPOSITORY_NAME" >> README.md
    //新建一个名为README.md的文件,其内容为:"REPOSITORY_NAME"
    git add README.md
    //将文件README.md 加入即将上传的空间
    git status
    //你可以看到这个文件的状态
    git commit -m "my first commit"
    //确认添加完了,我们提交即将上传的文件到缓冲区
    git push origin master
    //推上远程仓库,在这之后会让你输入用户名和密码,在这里的origin就是之前使用git remote语句链接到的远程仓库的链接地址。
    

    到现在你应该就完成了基本任务。但是git博大精深,所以暂时的放松之后。记得看我在后面写的其余知识点。


    其他

    展开全文
  • 说到 Git,对于开发人员来说一定不会陌生,在使用之前我们需要明白几个问题: 什么是 Git ? ...如果你是一名软件开发人员,那么你必须熟悉Git。 Git极大地方便开发人员对软件开发源代码版本或版本控制。...
  • 一个小问题:你每天做什么事?...现在,如果你是一位 Linux 用户(我猜你也是),这里有另外一个问题:如果你甚至不用离开终端就可以进行 Google 搜索那岂不是相当棒?甚至不用打开一个浏览器窗口? ...
  • 使用 sl 命令,你可以让自己驾驶火车,带来一个有趣的命令行体验。-- Jason Baker有用的原文链接请访问文末的“原文链接”获得可点击的文内链接、全尺寸原图和相关...
  • 系统信息&amp;nbsp; arch 显示机器的处理器架构(1)&amp;nbsp; uname -m 显示机器的处理器架构(2)&amp;...uname -r 显示正在使用的内核版本&...dmidecode -q 显示硬件系统部件 - (SMBIOS / DMI)&...
  • PuTTY是一个Telnet、SSH、rlogin、纯TCP以及串行接口连接软件。较早的版本仅支持Windows平台,现在的...1、安装:Linux各发行版因软件管理方式不同而不同,先通过软件管理从自己的软件仓库进行搜索安装如果有就进...
  • 了解一下 DomTerm,这是一款终端模拟器和复用器,带有 HTML 图形和其它不多见的功能。-- Per BothnerDomTerm是一款现代化的终端模拟器,它使用...
  • MPlayer 是一个多功能的开源媒体播放器,它在 Linux 命令行中非常有用。-- Jason Baker有用的原文链接请访问文末的“原文链接”获得可点击的文内链接、...
  • 之前, 我们展示了一些有关有趣的 Linux 命令行命令的文章, 这些文章告诉我们, Linux ...Linux命令及Linux终端的20个趣事Linux终端的乐趣之把玩字词计数 前者包含了20个有趣的 Linux 命令/脚本(和子命令), 得到了读者的
  • 了解一下 DomTerm,这是一款终端模拟器和复用器,带有 HTML 图形和其它不多见的功能。...除此以外,它看起来感觉就像一个功能完整、独立的终端模拟器,有着出色 xterm 兼容性(包括鼠标处理和 24 位色)和恰...
  • Linux美化终端

    2019-10-09 07:36:13
    终端美化 不管你是Kali 还是 Centos 还是Ubuntu... 请先用你的安装器安装 zsh 这里以Ubuntu 为例: 终端美化使用的on-my-zsh 首先先介绍一下什么是zsh,zsh是一款强大的终端软件,既可以作为一个交互式终端,也...
  • 它是一个守护程序,可以帮助你配置 Linux 虚拟控制台的鼠标支持。-- Sk有用的原文链接请访问文末的“原文链接”获得可点击的文内链接、全尺寸原图和相关文章。致谢编译自...
  • Linux远程访问全解析

    2020-07-08 17:06:54
    同样,Linux终端要访问其它终端,也会被其它终端所访问。远程访问协议主要有RDP、SSH和VNC等,不同系统间的访问矩阵总结如下。 远程访问:协议与工具 远程访问协议与服务 远程访问服务常用的有RDP、SSH、VNC等...
  • 这是一个简单的小工具,可以把你的 Linux 终端变为好莱坞风格的黑客入侵的实时画面。-- Abhishek Prakash本文导航◈ 如何安装 Hollywood 入侵终端Linux 之上33%编译自 | ...
  • Linux常用命令大全(非常全!!!) 最近都在和Linux打交道,感觉还不错。我觉得Linux相比windows比较麻烦的就是很多东西都要用命令来控制,当然,这也是很多人喜欢linux的原因,比较短小但却功能强大。我将我了解...
  • linux运行多个终端并行 Taskz是Node.js的库,Node.js是终端的简单顺序和并行任务列表运行程序。 入门 通过npm i taskz安装它。 在任何脚本文件中创建任务序列,然后运行它。 const taskz = require ( "taskz" ...
1 2 3 4 5 ... 20
收藏数 12,374
精华内容 4,949
关键字:

linux终端链接仓库