Linux系统中的cpio、createdb、createrepo、createuser命令详细解释

以下为你详细解释Linux操作系统中的:cpio、createdb、createrepo、createuser命令,内容有:Linux cpio命令的语法/选项/实例、Linux createdb命令的用法/参数/实例、Linux createrepo命令的基本语法/参数/实例、Linux createuser命令的用法/参数/实例。

Linux系统中的cpio、createdb、createrepo、createuser命令详细解释

1、Linux cpio命令的语法/选项/实例

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

语法:

cpio(选项)

选项:

-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:显示版本信息。

实例:

将/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命令配合使用。其实,上面的示例我们已经看到了它们的组合用法。

2、Linux createdb命令的用法/参数/实例

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

用法:

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

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

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

参数:

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 的选项;参考该条目获取更多相关信息。

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

-h host

--host host

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

-p port

--port port

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

-U username

--username username

    进行联接的用户名。

-W --password

    强制口令提示符。

实例:

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

3、Linux createrepo命令的基本语法/参数/实例

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

基本语法:

createrepo [option] <directory>

常用参数详解:

-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来存储生成的元数据,默认项。

实例:

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

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

4、Linux createuser命令的用法/参数/实例

Linux createuser命令用于创建一个postgresql的用户。

用法:

createuser [OPTION]... [ROLENAME]

参数:

-s, --superuser           超级用户

-S, --no-superuser        非超级用户

-d, --createdb            用户可以创建数据库

-D, --no-createdb         用户不可以创建数据库

-r, --createrole          用户可以创建其他用户

-R, --no-createrole       用户不可以创建其他用户

-l, --login               用户可以登录

-L, --no-login            用户不可以登录

-i, --inherit             用户可以继承权限

-I, --no-inherit          用户不可以继承权限

-c, --connection-limit=N  设置用户的连接数,默认不限制

-P, --pwprompt            设置用户密码

-E, --encrypted           加密存储密码

-N, --unencrypted         不加密存储密码

-e, --echo                将执行过程显示到Shell上

-q, --quiet               将执行过程不显示到Shell上

--help                    帮助

--version                 退出时显示版本

连接参数:

-h, --host=HOSTNAME       设置连接的IP或者域名

-p, --port=PORT           设置连接端口

-U, --username=USERNAME   设置连接用户朐

-W, --password            设置密码

实例:

bash-3.2$ createuser -P -D -R -e playboy     #创建一个用户,-P要设置密码,-R,不参创建其他用户,-D不能创建数据库。

Enter password for new role:  

Enter it again:  

CREATE ROLE playboy PASSWORD 'play-_-boy' NOSUPERUSER NOCREATEDB NOCREATEROLE  INHERIT LOGIN;  

CREATE ROLE  

bash-3.2$ createuser -P -R -s -e test       #创建一个超级用户,但是该用户不能创建其他用户。

注明

以上就是Linux cpio、createdb、createrepo、createuser命令的详细解释内容。

栏目相关文章