[转帖]详细解释cp、cpio、createrepo、createdb命令的用法。

详细,解释,cp,cpio,createrepo,createdb,命令,用法 · 浏览次数 : 0

小编点评

**使用说明:** ```bash cpio –icduv < /opt/etc.cpio 注意,cpio恢复的路径,如果cpio在打包备份的时候用的是绝对路径,那么在恢复的时候会自动恢复到这些绝对路径下,本例就会将备份文件全部还原到/etc路径下对应的目录中。同理,如果在打包备份用的是相对路径,还原时也将恢复到相对路径下。 ``` **示例:** ``` mkdir -p /yum/centos/6/ createrepo -p -d -o /yum/centos/6/ix86_64 /yum/centos/6/ix86_64& ``` 该示例创建了一个名为`ix86_64`的目录并初始化了`repodata`目录,产生了`repodata`文件。 **其他参数:** * `-u --baseurl <url>`指定Base URL的地址 * `-o --outputdir <url>`指定元数据的输出位置 * `-x --excludes <packages>`指定在形成元数据时需要排除的包 * `-i --pkglist <filename>`指定一个文件,该文件内的包信息将被包含在即将生成的元数据中,格式为每个包信息独占一行 * `-n --includepkg`通过命令行指定要纳入本地库中的包信息,需要提供URL或本地路径 * `-q --quiet`安静模式执行操作,不输出任何信息 * `-g --groupfile <groupfile>`指定本地软件仓库的组划分 * `-v --verbose`输出详细信息 * `-c --cachedir <path>`指定一个目录,用作存放软件仓库中软件包的校验和信息 * `--update`如果元数据已经存在,且软件仓库中只有部分软件发生了改变或增减,则可用`update`参数直接对原有元数据进行升级,效率比重新分析rpm包依赖并生成新的元数据要高很多 * `-p --pretty`以整洁的格式输出xml文件 * `-d --database`该选项指定使用SQLite来存储生成的元数据,默认项 * `-T template--template template`声明创建此数据库的模板数据库

正文

以下为你详细解释cp、cpio、createrepo、createdb命令的用法。

 

Linux cp命令的用法及解释

Linux cp命令用来将一个或多个源文件或者目录复制到指定的目的文件或目录。它可以将单个源文件复制成一个指定文件名的具体的文件或一个已经存在的目录下。cp命令还支持同时复制多个文件,当一次复制多个文件时,目标文件参数必须是一个已经存在的目录,否则将出现错误。

1、语法

cp(选项)(参数)

2、选项

-a:此参数的效果和同时指定"-dpR"参数相同;

-d:当复制符号连接时,把目标文件或目录也建立为符号连接,并指向与源文件或目录连接的原始文件或目录;

-f:强行复制文件或目录,不论目标文件或目录是否已存在;

-i:覆盖既有文件之前先询问用户;

-l:对源文件建立硬连接,而非复制文件;

-p:保留源文件或目录的属性;

-R/r:递归处理,将指定目录下的所有文件与子目录一并处理;

-s:对源文件建立符号连接,而非复制文件;

-u:使用这项参数后只会在源文件的更改时间较目标文件更新时或是名称相互对应的目标文件并不存在时,才复制文件;

-S:在备份文件时,用指定的后缀“SUFFIX”代替文件的默认后缀;

-b:覆盖已存在的文件目标前将目标文件备份;

-v:详细显示命令执行的操作。

3、参数

源文件:制定源文件列表。默认情况下,cp命令不能复制目录,如果要复制目录,则必须使用-R选项;

目标文件:指定目标文件。当“源文件”为多个文件时,要求“目标文件”为指定的目录。

4、实例

如果把一个文件复制到一个目标文件中,而目标文件已经存在,那么,该目标文件的内容将被破坏。此命令中所有参数既可以是绝对路径名,也可以是相对路径名。通常会用到点.或点点..的形式。例如,下面的命令将指定文件复制到当前目录下:

cp ../mary/homework/assign .

所有目标文件指定的目录必须是己经存在的,cp命令不能创建目录。如果没有文件复制的权限,则系统会显示出错信息。

将文件file复制到目录/usr/men/tmp下,并改名为file1:

cp file /usr/men/tmp/file1

将目录/usr/men下的所有文件及其子目录复制到目录/usr/zh中:

cp -r /usr/men /usr/zh

交互式地将目录/usr/men中的以m打头的所有.c文件复制到目录/usr/zh中:

cp -i /usr/men m*.c /usr/zh

我们在Linux下使用cp命令复制文件时候,有时候会需要覆盖一些同名文件,覆盖文件的时候都会有提示:需要不停的按Y来确定执行覆盖。文件数量不多还好,但是要是几百个估计按Y是件很痛苦的事,于是折腾来半天总结了一个方法:

cp aaa/* /bbb

复制目录aaa下所有到/bbb目录下,这时如果/bbb目录下有和aaa同名的文件,需要按Y来确认并且会略过aaa目录下的子目录。

cp -r aaa/* /bbb

这次依然需要按Y来确认操作,但是没有忽略子目录。

cp -r -a aaa/* /bbb

依然需要按Y来确认操作,并且把aaa目录以及子目录和文件属性也传递到了/bbb。

\cp -r -a aaa/* /bbb

成功,没有提示按Y、传递了目录属性、没有略过目录。

Linux cpio命令的用法及解释

Linux cpio命令主要是用来建立或者还原备份档的工具程序,cpio命令可以复制文件到归档包中,或者从归档包中复制文件。

1、语法

cpio(选项)

2、选项

-0或--null:接受新增列控制字符,通常配合find指令的“-print0”参数使用;

-a或--rest-access-time:重新设置文件的存取时间;

-A或--append:附加到已存在的备份文档中,且这个备份文档必须存放在磁盘上,而不能放置于磁带机里;

-b或--awap:此参数的效果和同时指定“-ss”参数相同;

-B:将输入/输出的区块大小改成5210Bytes;

-c:使用旧ASCII备份格式;

-C<区块大小>或--io-size=<区块大小>:设置输入/输出的区块大小,单位是Byte;

-d或--make-directories:如有需要cpio会自行建立目录;

-E<范本文件>或--pattern-file=<范本文件>:指定范本文件,其内含有一个或多个范本样式,让cpio解开符合范本条件的文件,格式为每列一个范本样式;

-f或--nonmatching:让cpio解开所有不符合范本条件的文件;

-F<备份档>或--file=<备份档>:指定备份档的名称,用来取代标准输入或输出,也能借此通过网络使用另一台主机的保存设备存取备份档;

-H<备份格式>:指定备份时欲使用的文件格式;

-i或--extract:执行copy-in模式,还原备份档;

-l<备份档>:指定备份档的名称,用来取代标准输入,也能借此通过网络使用另一台主机的保存设备读取备份档;

-k:此参数将忽略不予处理,仅负责解决cpio不同版本间的兼容性问题;

-l或--link:以硬连接的方式取代复制文件,可在copy-pass模式下运用;

-L或--dereference:不建立符号连接,直接复制该连接所指向的原始文件;

-m或preserve-modification-time:不去更改文件的更改时间;

-M<回传信息>或--message=<回传信息>:设置更换保存媒体的信息;

-n或--numeric-uid-gid:使用“-tv”参数列出备份档的内容时,若再加上参数“-n”,则会以用户识别和群组识别码替代拥有者和群组名称列出文件清单;

-o或--create:执行copy-out模式,建立备份档;

-O<备份档>:指定备份档的名称,用来取代标准输出,也能借此通过网络使用另一台主机的保存设备存放备份档;

-p或--pass-through:执行copy-pass模式,略过备份步骤,直接将文件复制到目的目录;

-r或--rename:当有文件名称需要更改时,采用互动模式;

-R<拥有者><:/.><所属群组>或----owner<拥有者><:/.><所属群组>   在copy-in模式还原备份档,或copy-pass模式复制文件时,可指定这些备份,复制的文件的拥有者与所属群组;

-s或--swap-bytes:交换每队字节的内容;

-S或--swap-halfwords:交换每半个字节的内容;

-t或--list:将输入的内容呈现出来;

-u或--unconditional:置换所有文件,不论日期时间的新旧与否,皆不予询问而直接覆盖;

-v或--verbose:详细显示指令的执行过程;

-V或--dot:执行指令时。在每个文件的执行程序前面加上“.”号;

--block-size=<区块大小>:设置输入/输出的区块大小,假如设置数值为5,则区块大小为2500,若设置成10,则区块大小为5120,以此类推;

--force-local:强制将备份档存放在本地主机;

--help:在线帮助;

--no-absolute-filenames:使用相对路径建立文件名称;

--no-preserve-owner:不保留文件的拥有者,谁解开了备份档,那些文件就归谁所有;

-only-verify-crc:当备份档采用CRC备份格式时,可使用这项参数检查备份档内的每个文件是否正确无误;

--quiet:不显示复制了多少区块;

--sparse:倘若一个文件内含有大量的连续0字节,则将此文件存在稀疏文件;

--version:显示版本信息。

3、实例

将/etc下的所有普通文件都备份到/opt/etc.cpio,使用以下命令:

find /etc –type f | cpio –ocvB >/opt/etc.cpio

将系统上所有资料备份到磁带机内,使用以下命令:

find / -print | cpio -covB > /dev/st0

这里的/dev/st0是磁带的设备名,代表SCSI磁带机。

查看上例磁带机上备份的文件,使用以下命令:

cpio  -icdvt < /dev/st0 > /tmp/st_content

有时可能因为备份的文件过多,一个屏幕无法显示完毕,此时我们利用下面命令,让磁带机的文件信息输出到文件。

将示例1中的备份包还原到相应的位置,如果有相同文件进行覆盖,使用以下命令:

cpio –icduv < /opt/etc.cpio

注意,cpio恢复的路径,如果cpio在打包备份的时候用的是绝对路径,那么在恢复的时候会自动恢复到这些绝对路径下,本例就会将备份文件全部还原到/etc路径下对应的目录中。同理,如果在打包备份用的是相对路径,还原时也将恢复到相对路径下。

通过上面的示例,可以看出,cpio无法直接读取文件,它需要每个文件或者目录的完整路径名才能识别读取,而find命令的输出刚好做到了这点,因此,cpio命令一般和find命令配合使用。其实,上面的示例我们已经看到了它们的组合用法。

Linux createrepo命令的用法及解释

Linux createrepo命令用来创建yum源(软件仓库),即为存放于本地特定位置的众多rpm包建立索引,描述各包所需依赖信息,并形成元数据。

1、基本语法

createrepo [option] <directory>

2、常用参数详解

-u  --baseurl <url>

指定Base URL的地址

-o --outputdir <url>

指定元数据的输出位置

-x --excludes <packages>

指定在形成元数据时需要排除的包

-i --pkglist <filename>

指定一个文件,该文件内的包信息将被包含在即将生成的元数据中,格式为每个包信息独占一行,不含通配符、正则,以及范围表达式。

-n --includepkg

通过命令行指定要纳入本地库中的包信息,需要提供URL或本地路径。

-q --quiet

安静模式执行操作,不输出任何信息。

-g --groupfile <groupfile>

指定本地软件仓库的组划分,范例如下:

createrepo -g comps.xml /path/to/rpms

注意:组文件需要和rpm包放置于同一路径下。

-v --verbose

输出详细信息。

-c --cachedir <path>

指定一个目录,用作存放软件仓库中软件包的校验和信息。当createrepo在未发生明显改变的相同仓库文件上持续多次运行时,指定cachedir会明显提高其性能。

--update

如果元数据已经存在,且软件仓库中只有部分软件发生了改变或增减,则可用update参数直接对原有元数据进行升级,效率比重新分析rpm包依赖并生成新的元数据要高很多。

-p --pretty

以整洁的格式输出xml文件。

-d --database

该选项指定使用SQLite来存储生成的元数据,默认项。

3、实例

$ mkdir -p /yum/centos/6/  #创建本地源目录

$ createrepo -p -d -o /yum/centos/6/ix86_64 /yum/centos/6/ix86_64   #初始化源目录,产生repodata

Linux createdb命令的用法及解释

Linux createdb命令是用于创建一个新的 PostgreSQL 数据库。

1、用法

createdb [option...] [dbname] [description]

通常,执行这个命令的数据库用户成为新数据库的所有者。不过,如果执行用户拥有合适的权限,那么他可以通过 -O 指定合适的用户。

createdb 是一个 SQL 命令 CREATE DATABASE 的封装。因此,用哪种方法创建数据库都没什么特别的。

2、参数

dbname

    声明要创建的数据库名。该名称应该在本节点的 PostgreSQL 所有数据库里面是唯一的。 缺省是与当前系统用户同名。

description

    这个选项声明一个与新创建的数据库相关的注解。

-D tablespace --tablespace tablespace

    声明数据库的缺省表空间。

-e --echo

    回显 createdb 生成的命令并且把它发送到服务器。

-E encoding --encoding encoding

    声明用于此数据库的字符编码方式。PostgreSQL 服务器支持的字符集在 Section 21.2.1 里列出。

-q --quiet

    不显示响应。

-O owner

--owner owner

    指定将拥有新数据库的数据库用户。

-T template

--template template

    声明创建此数据库的模板数据库。

    选项 -h,-p,-U, -W,-e 是以文本形式传递给 psql。选项-O,-D,-T 和 -E 转换为下层的 SQL 命令 CREATE DATABASE 的选项;参考该条目获取更多相关信息。

3、createdb 还接受下列命令行参数作为连接参数

-h host

--host host

    声明运行服务器的主机名。 如果数值以斜杠开头,则它被用做到 Unix 域套接字的路径。

-p port

--port port

    声明服务器 侦听的等待连接的互联网 TCP 端口或一个本地 Unix 域套接字文件扩展(描述符)。

-U username

--username username

    进行联接的用户名。

-W --password

    强制口令提示符。

4、实例

bash-3.2$ $ createdb test    #创建数据库

CREATE DATABASE

bash-3.2$ createdb -p 5000 -h 192.168.1.163 -E LATIN1 -e test    #在主机192.168.1.163上的服务器创建数据库test,端口是5000,使用 LATIN1 编码方式

CREATE DATABASE "test" WITH ENCODING = 'LATIN1'

CREATE DATABASE

与[转帖]详细解释cp、cpio、createrepo、createdb命令的用法。相似的内容:

[转帖]详细解释cp、cpio、createrepo、createdb命令的用法。

以下为你详细解释cp、cpio、createrepo、createdb命令的用法。 Linux cp命令的用法及解释 Linux cp命令用来将一个或多个源文件或者目录复制到指定的目的文件或目录。它可以将单个源文件复制成一个指定文件名的具体的文件或一个已经存在的目录下。cp命令还支持同时复制多个文件

[转帖]hex,base64,urlencode编码方案对比

https://www.cnblogs.com/codelogs/p/16060248.html 简介# 在工作过程中,我们慢慢会了解到hex、base64、urlencode这3种常见的字节编码方案,它们是如此的熟悉,可是经常我们自己也说不清为啥要使用它们,下面我会详细解释下。 hex编码# he

[转帖]hex,base64,urlencode编码方案对比

https://www.jianshu.com/p/4d701c09d44e 原创:打码日记,欢迎分享,转载请保留出处。 简介 在工作过程中,我们慢慢会了解到hex、base64、urlencode这3种常见的字节编码方案,它们是如此的熟悉,可是经常我们自己也说不清为啥要使用它们,下面我会详细解释下

[转帖]超详细的解决ModuleNotFoundError: No module named '_curses'错误的方法!!!

超详细的解决ModuleNotFoundError: No module named '_curses’的错误 问题描述:在写py脚本时,需要用到curses库(提供了控制字符屏幕的独立于终端的方法)。 导入的时候完全正常 Run的时候却报了这样的错误(它说找不到这个包) 本能的解决方法: 首先想到

[转帖]【详细齐全】FIO使用方法 及参数解析(文章末尾)

linux 使用FIO测试磁盘iops 方法详解 FIO是测试IOPS的非常好的工具,用来对硬件进行压力测试和验证,支持13种不同的I/O引擎, 包括:sync,mmap, libaio, posixaio, SG v3, splice, null, network, syslet, guasi,

[转帖]《服务器应用场景性能测试方法 虚拟化》解读

《服务器应用场景性能测试方法 虚拟化》解读 https://aijishu.com/a/1060000000343436 今天为大家带来《服务器应用场景性能测试方法 虚拟化》的详细解读。 《服务器应用场景性能测试方_虚拟化》起草单位包括中国电子技术标准化研究院、云宏信息科技股份有限公司、飞腾信息技术

[转帖]Access-Control-Allow-Origin跨域解决及详细介绍

重要声明:本文章仅仅代表了作者个人对此观点的理解和表述。读者请查阅时持自己的意见进行讨论。 本文更新不及时,建议到原文地址浏览:跨域解决及详细介绍。 首先,跨域不是问题。是一种安全机制。 这是你在开发时、上线前就必须提前考虑到的安全问题并且采取合适的手段去避免这个问题带来的程序错误。不过通常情况下,

[转帖]Kafka 基本概念大全

https://my.oschina.net/jiagoushi/blog/5600943 下面给出 Kafka 一些重要概念,让大家对 Kafka 有个整体的认识和感知,后面还会详细的解析每一个概念的作用以及更深入的原理 ・Producer:消息生产者,向 Kafka Broker 发消息的客户端

[转帖]VMware vCenter证书过期解决方法

https://www.yii666.com/blog/395521.html vCenter证书过期解决方法 目录 1 概述 2 详细操作步骤 2.1 检查关键的STS证书是否过期并修复 2.2 检查除STS证书外是否还有其余证书过期 2.3 续订除STS和data-encipherment以外的

[转帖]RabbitMQ基础概念详细介绍

https://www.jianshu.com/p/e55e971aebd8 AMQP简介 AMQP,即 Advanced Message Queuing Protocol,高级消息队列协议,是应用层协议的一个开放标准,为面向消息的中间件设计。消息中间件主要用于组件之间的解耦和通讯。 AMQP的主要