zoukankan      html  css  js  c++  java
  • Linux下的一些常用命令(一)

           在Linux环境下敲各种命令是再正常不过了,尤其是现在大多少服务器均为Linux系统,但是我又记不住这么多命令,只是偶尔在项目做完发布到服务器上的时候会涉及到,所以在网上找了一些命令,在此记录一下~

       (内容是转载过来的,原创在http://www.oschina.net/translate/useful-linux-commands-for-newbies

    1. ls命令

    ls命令是列出目录内容(List Directory Contents)的意思。运行它就是列出文件夹里的内容,可能是文件也可能是文件夹。

    root@tecmint:~# ls


    “ls -l”命令以详情模式(long listing fashion)列出文件夹的内容。

    root@tecmint:~# ls -l
    total 0
    drwxr-xr-x@  9 harvey  staff  306 10 19 13:16 meteortutorial
    drwxr-xr-x  10 harvey  staff  340 10 19 13:19 simple-todos

    "ls -a"命令会列出文件夹里的所有内容,包括以"."开头的隐藏文件。

    root@tecmint:~# ls -a
    
    .		..		.DS_Store	meteortutorial	simple-todos


    注意:在Linux中,文件以“.”开头的就是隐藏文件,并且每个文件、文件夹、设备或者命令都是以文件对待。ls -l 命令输出:

    1. d (代表了是目录).
    2. rwxr-xr-x 是文件或者目录对所属用户,同一组用户和其它用户的权限。
    3. 上面例子中第一个harvey代表了文件属于用户harvey
    4. 上面例子中的第二个staff代表了文件文件属于用户组staff
    5. 306 代表了文件大小为306字节.
    6. 10 19 13:16 表示文件或者文件夹最后一次修改的日期和时间。
    7. 最后一项是文件或文件夹的名称。

    一共有10位数
    其中:最前面那个 d 代表的是类型,这里d 代表文件夹,如果是文件,则是-
         中间那三个 rwx    代表的是所有者(user)
         然后那三个 r-x    代表的是组群(group)
         最后那三个 r-x    代表的是其他人(other)
    
    然后我再解释一下后面那9位数:
       r 表示文件可以被读(read)
       w 表示文件可以被写(write)
       x 表示文件可以被执行(如果它是程序的话)
       - 表示相应的权限还没有被授予

    更多"ls"例子请查看 15 linux中ls命令实例

    2. lsblk命令

    "lsblk"就是列出块设备。除了RAM外,以标准的树状输出格式,整齐地显示块设备。

    root@tecmint:~# lsblk

    lsblk -l”命令以列表格式显示块设备(而不是树状格式)。
    root@tecmint:~# lsblk -l

    注意:lsblk是最有用和最简单的方式来了解插入的USB设备的名字,特别是当你在终端上处理磁盘/块设备时。

    3. md5sum命令

    md5sum”就是计算和检验MD5信息签名。md5 checksum(通常叫做哈希)使用匹配或者验证文件的文件的完整性,因为文件可能因为传输错误,磁盘错误或者无恶意的干扰等原因而发生改变。

    root@tecmint:~# md5sum teamviewer_linux.deb
    
    47790ed345a7b7970fc1f2ac50c97002  teamviewer_linux.deb

    注意:用户可以使用官方提供的和md5sum生成签名信息匹对以此检测文件是否改变。Md5sum没有sha1sum安全,这点我们稍后讨论。

    4. dd命令

    dd”命令代表了转换和复制文件。可以用来转换和复制文件,大多数时间是用来复制iso文件(或任何其它文件)到一个usb设备(或任何其它地方)中去,所以可以用来制作USB启动器。

    root@tecmint:~# dd if=/home/user/Downloads/debian.iso of=/dev/sdb1 bs=512M; sync

    注意:在上面的例子中,usb设备就是sdb1(你应该使用lsblk命令验证它,否则你会重写你的磁盘或者系统),请慎重使用磁盘的名,切忌。

    dd 命令在执行中会根据文件的大小和类型 以及 usb设备的读写速度,消耗几秒到几分钟不等。

    5. uname命令

    "uname"命令就是Unix Name的简写。显示机器名,操作系统和内核的详细信息。

    root@tecmint:~# uname -a
    
    Linux tecmint 3.8.0-19-generic #30-Ubuntu SMP Wed May 1 16:36:13 UTC 2013 i686 i686 i686 GNU/Linux

    注意: uname显示内核类别,uname -a显示详细信息。上面的输出详细说明了uname -a

    1. Linux“: 机器的内核名
    2. tecmint“: 机器的节点名
    3. 3.8.0-19-generic“: 内核发布版本
    4. #30-Ubuntu SMP“: 内核版本
    5. i686“: 处理器架构
    6. GNU/Linux“: 操作系统名

    6. history命令

    history”命令就是历史记录。它显示了在终端中所执行过的所有命令的历史。

    root@tecmint:~# history

    注意:按住“CTRL + R”就可以搜索已经执行过的命令,它可以在你写命令时自动补全。

    (reverse-i-search)`if':ifconfig

    7. sudo命令

    sudo”(super user do)命令允许授权用户执行超级用户或者其它用户的命令。通过在sudoers列表的安全策略来指定。

    root@tecmint:~# sudo add-apt-repository ppa:tualatrix/ppa

    注意:sudo 允许用户借用超级用户的权限,然而"su"命令实际上是允许用户以超级用户登录。所以sudosu更安全。
    并不建议使用sudo或者su来处理日常用途,因为它可能导致严重的错误如果你意外的做错了事,这就是为什么在linux社区流行一句话:

    “To err is human, but to really foul up everything, you need root password.”

    “人非圣贤孰能无过,但是拥有root密码就真的万劫不复了。” # 译
    8. mkdir命令

    mkdir”(Make directory)命令在命名路径下创建新的目录。然而如果目录已经存在了,那么它就会返回一个错误信息"不能创建文件夹,文件夹已经存在了"("cannot create folder, folder already exists")

    root@tecmint:~# mkdir tecmint

    注意:目录只能在用户拥有写权限的目录下才能创建。mkdir:不能创建目录`tecmint`,因为文件已经存在了。(上面的输出中不要被文件迷惑了,你应该记住我开头所说的-在linux中,文件,文件夹,驱动,命令,脚本都视为文件)

    9. touch 命令

    touch”命令代表了将文件的访问和修改时间更新为当前时间。touch命令只会在文件不存在的时候才会创建它。如果文件已经存在了,它会更新时间戳,但是并不会改变文件的内容。

    root@tecmint:~# touch tecmintfile

    注意:touch 可以用来在用户拥有写权限的目录下创建不存在的文件。

     

    10. chmod 命令

    chmod”命令就是改变文件的模式位。chmod会根据要求的模式来改变每个所给的文件,文件夹,脚本等等的文件模式(权限)。

    在文件(文件夹或者其它,为了简单起见,我们就使用文件)中存在3中类型的权限

    Read (r)=4
    
    Write(w)=2
    
    Execute(x)=1

    所以如果你想给文件只读权限,就设置为'4';只写权限,设置权限为'2';只执行权限,设置为1; 读写权限,就是4+2 = 6, 以此类推。

    现在需要设置3种用户和用户组权限。第一个是拥有者,然后是用户所在的组,最后是其它用户。

    rwxr-x--x   abc.sh

    这里root的权限是 rwx(读写和执行权限),
    所属用户组权限是 r-x (只有读和执行权限, 没有写权限)
    对于其它用户权限是 -x(只有只执行权限)

    为了改变它的权限,为拥有者,用户所在组和其它用户提供读,写,执行权限。

    root@tecmint:~# chmod 777 abc.sh

    三种都只有读写权限

    root@tecmint:~# chmod 666 abc.sh

    拥有者用户有读写和执行权限,用户所在的组和其它用户只有可执行权限

    root@tecmint:~# chmod 711 abc.sh

    注意:对于系统管理员和用户来说,这个命令是最有用的命令之一了。在多用户环境或者服务器上,对于某个用户,如果设置了文件不可访问,那么这个命令就可以解决,如果设置了错误的权限,那么也就提供了为授权的访问。 

     
     
  • 相关阅读:
    (笔试题)镇长选举
    (笔试题)最小的非“重复的数”
    ( 笔试题)只出现一次的数
    (算法)二叉树中两个结点的最近公共父结点
    (笔试题)区间最大重叠
    (剑指Offer)面试题61:按之字形顺序打印二叉树
    (算法)Partition方法求数组第k大的数
    (剑指Offer)面试题60:把二叉树打印成多行
    整理一些不错的、网上好评的电影、电视、视频等资源地址
    个人网站/博客,建站好的域名和网站供应商网站整理
  • 原文地址:https://www.cnblogs.com/wanghang/p/6298922.html
Copyright © 2011-2022 走看看