zoukankan      html  css  js  c++  java
  • linux常用命令

    一.cp命令

    功能: 复制文件或目录
    说明: cp指令用于复制文件或目录,如同时指定两个以上的文件或目录,且最后的目的地是一个已经存在的目录,则它会把前面指定的所有文件或目录复制到此目录中。若同时指定多个文件或目录,而最后的目的地并非一个已存在的目录,则会出现错误信息
    参数:
         -a 或 --archive     此参数的效果和同时指定"-dpR"参数相同
         -b 或 --backup      删除、覆盖目的文件先备份,备份的文件或目录亦建立为符号链接,并指向源文件或目录链接的源文件或目录。假如没有加上这个参数,在复制过程中若遇到符号链接,则会直接复制源文件或目录
         -f 或 --force       强行复制文件或目录, 不论目的文件或目录是否已经存在
         -i 或 --interactive 覆盖文件之前先询问用户
         -l 或 --link        对源文件建立硬链接,而非复制文件
         -p 或 --preserve    保留源文件或目录的属性,包括所有者、所属组、权限与时间
         -P 或 --parents     保留源文件或目录的路径,此路径可以是绝对路径或相对路径,且目的目录必须已经丰在
         -r                  递归处理,将指定目录下的文件与子目录一并处理。若源文件或目录的形态,不属于目录或符号链接,则一律视为普通文件处理
         -R 或 --recursive   递归处理,将指定目录下的文件及子目录一并处理
         -s 或 --symbolic-link  对源文件建立符号链接,而非复制文件
         -S <备份字尾字符串> 或 --suffix=<备份字尾字符串> 用"-b"参数备份目的文件后,备份文件的字尾会被加上一个备份字符串。默认的备份字尾符串是符号"~"
         -u 或 --update      使用这项参数之后,只会在源文件的修改时间(Modification Time)较目的文件更新时,或是名称相互对应的目的文件并不存在,才复制文件
         -v 或 --verbose     显示执行过程
         -V <备份方式> 或 --version-control=<备份方式>  指定当备份文件时,备份文件名的命名方式,有以下3种:
                             1.numbered或t, 将使用备份编号,会在字尾加上~1~字符串,其数字编号依次递增
                             2.simple或never 将使用简单备份,默认的备份字尾字符串是~, 也可通过-S来指定
                             3.existing或nil将使用当前方式,程序会先检查是否存在着备份编号,若有则采用备份编号,若无则采用简单备份
         -x 或 --one-file-system  复制的文件或目录存放的文件系统,必须与cp指令执行时所处的文件系统相同,否则不复制,亦不处理位于其他分区的文件
         --help              显示在线帮助
         --sparse=<使用时机>  设置保存希疏文件的时机
         --version           显示版本

    示例:
        .复制文件,只有源文件较目的文件的修改时间新时,才复制文件
         cp -u -v file1 file2

        .将文件file1复制成文件file2
         cp file1 file2

        .采用交互方式将文件file1复制成文件file2
         cp -i file1 file2

        .将文件file1复制成file2,因为目的文件已经存在,所以指定使用强制复制的模式
         cp -f file1 file2

        .将目录dir1复制成目录dir2
         cp -R file1 file2

        .同时将文件file1、file2、file3与目录dir1复制到dir2
       cp -R file1 file2 file3 dir1 dir2

        .复制时保留文件属性
         cp -p a.txt tmp/

        .复制时保留文件的目录结构
         cp -P  /var/tmp/a.txt  ./temp/

        .复制时产生备份文件
         cp -b a.txt tmp/

        .复制时产生备份文件,尾标 ~1~格式
         cp -b -V t   a.txt /tmp    
      
        .指定备份文件尾标    
         cp -b -S _bak a.txt /tmp

    问题:

    cp:omitting directory`XXX'问题解决
     
    cp: omitting directory `foldera/'  
    其中foldera是我要复制的文件夹名,出现该警告的原因是因为foldera目录下还存在目录,所以不能直接拷贝。
    解决办法:
    使用递归拷贝,在cp命令后面加上-r参数,形如:
    Shell代码  
    [root@localhost opt]# cp -r foldera folderc  
    这里的-r代表递归的意思。
     
    同样,当我们在linux系统下删除目录时也需要加上-r参数 ,如果目录为空,则会直接删除,如果目录非空,则会级联删除。不过在级联删除时也会有一个问题就是如果目录下存在很多的文件或者子目录,系统会一个一个进行提示。如果想一步删除不用提示的话可以使用rm -rf命令。f是force的意思,代表强制删除,无提示!
     

    二.chmod命令

    chmod [options] mode files
     
    只能文件属主或特权用户才能使用该功能来改变文件存取模式。mode可以是数字形式或以who opcode permission形式表示。who是可选的,默认是a(所有用户)。只能选择一个opcode(操作码)。可指定多个mode,以逗号分开。
    options:
    -c,--changes
    只输出被改变文件的信息
    -f,--silent,--quiet
    当chmod不能改变文件模式时,不通知文件的用户
    --help
    输出帮助信息。
    -R,--recursive
    可递归遍历子目录,把修改应到目录下所有文件和子目录
    --reference=filename
    参照filename的权限来设置权限
    -v,--verbose
    无论修改是否成功,输出每个文件的信息
    --version
    输出版本信息。
    who
    u
    用户
    g
    o
    其它
    a
    所有用户(默认)
    opcode
    +
    增加权限
    -
    删除权限
    =
    重新分配权限
    permission
    r
    w
    x
    执行
    s
    设置用户(或组)的ID号
    t
    设置粘着位(sticky bit),防止文件或目录被非属主删除
    u
    用户的当前权限
    g
    组的当前权限
    o
    其他用户的当前权限
    作为选择,我们多数用三位八进制数字的形式来表示权限,第一位指定属主的权限,第二位指定组权限,第三位指定其他用户的权限,每位通过4(读)、2(写)、1(执行)三种数值的和来确定权限。如6(4+2)代表有读写权,7(4+2+1)有读、写和执行的权限。
    还可设置第四位,它位于三位权限序列的前面,第四位数字取值是4,2,1,代表意思如下:
    4,执行时设置用户ID,用于授权给基于文件属主的进程,而不是给创建此进程的用户。
    2,执行时设置用户组ID,用于授权给基于文件所在组的进程,而不是基于创建此进程的用户。
    1,设置粘着位。
     
    实例:
    $ chmod u+x file                      给file的属主增加执行权限
    $ chmod 751 file                      给file的属主分配读、写、执行(7)的权限,给file的所在组分配读、执行(5)的权限,给其他用户分配执行(1)的权限
    $ chmod u=rwx,g=rx,o=x file      上例的另一种形式
    $ chmod =r file                     为所有用户分配读权限
    $ chmod 444 file                   同上例
    $ chmod a-wx,a+r   file          同上例
    $ chmod -R u+r directory           递归地给directory目录下所有文件和子目录的属主分配读的权限
    $ chmod 4755                            设置用ID,给属主分配读、写和执行权限,给组和其他用户分配读、执行的权限。
  • 相关阅读:
    Openjudge-计算概论(A)-求出e的值
    Openjudge-计算概论(A)-球弹跳高度的计算
    Openjudge-计算概论(A)-求分数序列和
    Openjudge-计算概论(A)-第二个重复出现的数
    Openjudge-计算概论(A)-角谷猜想
    Openjudge-计算概论(A)-分数求和
    Openjudge-计算概论(A)-人民币支付
    Openjudge-计算概论(A)-年龄与疾病
    Openjudge-计算概论(A)-求特殊自然数
    Openjudge-计算概论(A)-短信计费
  • 原文地址:https://www.cnblogs.com/ginikeer/p/3629453.html
Copyright © 2011-2022 走看看