linux学习中,关于文件复制的cp命令,其中有一个 -i 的命令有点问题
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了linux学习中,关于文件复制的cp命令,其中有一个 -i 的命令有点问题相关的知识,希望对你有一定的参考价值。
其中在对-i 解释时是这样说的:
-i :若目标文件(destination)已经存在时,在覆盖时会先询问操作的进行
但是,实际上有没有-i 好像都会问一遍的吧?
你会发现 cp 默认就等于了 cp -i
所以导致你无论cp 还是 cp -i 都是一样的效果
我每次用linux之前都会把这句 alias cp='cp -i' 注释掉
附上我常用的alias文件吧,以后直接替换就可以了,操作步骤:
1.先进入编辑模式
vim ~/.bashrc2.跳转到文字的结尾:一直按page down按键,到最后一行,再按end到文字结尾
3.按a,或者o,进入编辑模式
3.ctrl+u是一行一行删除,把所有内容都删除掉
4.复制粘贴以下代码
# .bashrc# User specific aliases and functions
alias rm='rm -i'
#alias cp='cp -i'
alias mv='mv -i'
alias ll="ls -l"
# 修改alias文件
alias aliasvim="vim /root/.bashrc"
# 重载alias文件使其生效,每次修改后都要刷新
alias aliasource="source /root/.bashrc"
# 修改环境变量,比如添加jre,tomcat,redis
alias profilevim="vim /etc/profile"
# 重载环境变量,使其生效
alias profilesource="source /etc/profile"
# 重启网卡
alias networkrestart="service network restart"
# 列出此服务器的网卡配置文件
alias networkvim="cd /etc/sysconfig/network-scripts/ && ls | grep ifcfg-"
# 修改DNS解析
alias nameservervim="vim /etc/resolv.conf"
# 修改hosts
alias hostsvim="vim /etc/hosts"
# 查看端口当前占用情况
alias portcheck="netstat -tunlp |grep "
# 查看firewall防火墙开放端口列表(白名单)
alias firewallports="firewall-cmd --zone=public --list-ports"
# 设置firewall防火墙的mysql3306端口互通
alias firewalladd="echo 'firewall-cmd --zone=public --add-port=3306/tcp --permanent'"
# firewall防火墙重启
alias firewallreload="firewall-cmd --reload"
# iptables防火墙添加指定端口命令
alias iptablesadd="echo '/sbin/iptables -I INPUT -p tcp --dport 8080 -j ACCEPT'"
# 查看防火墙白名单(应该是重启还在的)
alias iptableports="more /etc/sysconfig/iptables"
# 查看指定进程
#alias pid="ps aux | grep "
alias pid="ps -ef | grep "
# 查找根目录/下的名字为xx的文件,支持通配符*
alias search="find / -name "
# 查看Linux系统版本和位数
alias systeminfo='cat /etc/redhat-release;getconf LONG_BIT;uname -a'
# 显示当前服务器时间
alias timenow='date +"%Y-%m-%d %H:%M:%S"'
# 更新服务器时间
#alias updatetime='ntpdate 0.centos.pool.ntp.org'
# 跳转tomcat路径
alias tomcatpwd="cd /disk1/app/tomcat8"
# 启动tomcat
alias tomcatstart="tomcatpwd && ./bin/startup.sh && tail -f ./logs/catalina.out"
# 停止tomcat
alias tomcatstop="tomcatpwd && ./bin/shutdown.sh && ps -ef | grep tomcat"
# 查看tomcat日志
alias tomcatlog="tomcatpwd && tail -200f ./logs/catalina.out"
# 批量启动多个tomcat
alias tomcatstartall="/usr/local/tomcat8080/bin/startup.sh && /usr/local/tomcat8081/bin/startup.sh && /usr/local/tomcat8082/bin/startup.sh && /usr/local/tomcat8083/bin/startup.sh && /usr/local/tomcat8084/bin/startup.sh"
# 批量关闭多个tomcat
alias tomcatstopall="/usr/local/tomcat8080/bin/shutdown.sh && /usr/local/tomcat8081/bin/shutdown.sh && /usr/local/tomcat8082/bin/shutdown.sh && /usr/local/tomcat8083/bin/shutdown.sh && /usr/local/tomcat8084/bin/shutdown.sh"
# redis查找指定key对应value值
alias rediskeys='redis-cli -a "abc@123" keys '
# 修改nginx默认配置
alias nginxconf="vim /usr/local/nginx/conf/nginx.conf"
# 以默认配置启动nginx
alias nginxstart="/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf"
# 强制停止nginx服务器,如果有未处理的数据,丢弃
alias nginxstop="/usr/local/nginx/sbin/nginx -s stop"
# 推荐:优雅的停止nginx服务器,如果有未处理的数据,等待处理完成之后停止
alias nginxquit="/usr/local/nginx/sbin/nginx -s quit"
# 重载nginx,用于修改配置后,直接刷新使配置生效
alias nginxreload="/usr/local/nginx/sbin/nginx -s reload"
# 检查nginx的配置是否可用
alias nginxcheck="/usr/local/nginx/sbin/nginx -t"
# 虚拟机共享文件夹路径
#alias share="/mnt/hgfs/ShareFolder/"
# Source global definitions
if [ -f /etc/bashrc ]; then
. /etc/bashrc
fi
5.粘贴后,按ESC退出编辑模式,然后按 冒号+w+q+回车 保存
我那些alias里面不懂的去百度吧,基本用过linux的差不多都接触过或者一看就懂
参考技术A LS说的对,现在linux系统有很多命令都已经配置不,可能你的系统 cp -i 已经在别名中和 ls -l =ll 一个意思。用ls说的命令 aliase看看是不是已经配置了别名本回答被提问者和网友采纳 参考技术B alias 命令看一下,
其实cp 已经做了aliase
cp=‘cp -i“ 即你的cp命令已经默认添加了i参数 参考技术C 尝试 这种问题不必问 实践会告诉你的 学计算机要有实践的意识 这很重要的追问
额。。。就是因为试过了,那两个东西就是一样的呀,然后我就困惑了,-i 貌似就没有用了的呀?
追答我学的是红帽的
linux学习笔记7---命令cp
cp命令用来复制文件或者目录,是Linux系统中最常用的命令之一。
cp命令用来将一个或多个源文件或者目录复制到指定的目的文件或目录。它可以将单个源文件复制成一个指定文件名的具体的文件或一个已经存在的目录下。cp命令还支持同时复制多个文件,当一次复制多个文件时,目标文件参数必须是一个已经存在的目录,否则将出现错误。
一般情况下,shell会设置一个别名,在命令行下复制文件时,如果目标文件已经存在,就会询问是否覆盖,不管你是否使用-i参数。但是如果是在shell脚本中执行cp时,没有-i参数时不会询问是否覆盖。这说明命令行和shell脚本的执行方式有些不同。
1.命令格式:
用法:
cp [选项]... [-T] 源 目的
或:cp [选项]... 源... 目录
或:cp [选项]... -t 目录 源...
2.命令功能:
将源文件复制至目标文件,或将多个源文件复制至目标目录。
3.命令参数:
-a, --archive 等于-dR --preserve=all
--backup[=CONTROL 为每个已存在的目标文件创建备份,新的文件或者目录和原文件或者目录具有相同的创建时间。
-b 类似--backup 但不接受参数
--copy-contents 在递归处理是复制特殊文件内容
-d 等于--no-dereference --preserve=links
-f, --force 如果目标文件无法打开则将其移除并重试(当 -n 选项
存在时则不需再选此项)
-i, --interactive 覆盖前询问(使前面的 -n 选项失效)
-H 跟随源文件中的命令行符号链接
-l:对源文件建立硬连接,而非复制文件;
-s:对源文件建立符号连接,而非复制文件;
-L, --dereference 总是跟随符号链接
-n, --no-clobber 不要覆盖已存在的文件(使前面的 -i 选项失效)
-P, --no-dereference 不跟随源文件中的符号链接
-p 等于--preserve=模式,所有权,时间戳. -p:保留源文件或目录的属性;
--preserve[=属性列表 保持指定的属性(默认:模式,所有权,时间戳),如果
可能保持附加属性:环境、链接、xattr 等
-R, -r, --recursive 复制目录及目录内的所有项目
4.命令实例:
实例一:复制单个文件到目标目录,文件在目标文件中不存在
命令:
cp log.log test5
输出:
[root@localhost test]# cp log.log test5
[root@localhost test]# ll
-rw-r--r-- 1 root root 0 10-28 14:48 log.log
drwxr-xr-x 6 root root 4096 10-27 01:58 scf
drwxrwxrwx 2 root root 4096 10-28 14:47 test3
drwxr-xr-x 2 root root 4096 10-28 14:53 test5
[root@localhost test]# cd test5
[root@localhost test5]# ll
-rw-r--r-- 1 root root 0 10-28 14:46 log5-1.log
-rw-r--r-- 1 root root 0 10-28 14:46 log5-2.log
-rw-r--r-- 1 root root 0 10-28 14:46 log5-3.log
-rw-r--r-- 1 root root 0 10-28 14:53 log.log
说明:
在没有带-a参数时,两个文件的时间是不一样的。在带了-a参数时,两个文件的时间是一致的。
实例二:目标文件存在时,会询问是否覆盖
命令:
cp log.log test5
输出:
[root@localhost test]# cp log.log test5
cp:是否覆盖“test5/log.log”? n
[root@localhost test]# cp -a log.log test5
cp:是否覆盖“test5/log.log”? y
[root@localhost test]# cd test5/
[root@localhost test5]# ll
-rw-r--r-- 1 root root 0 10-28 14:46 log5-1.log
-rw-r--r-- 1 root root 0 10-28 14:46 log5-2.log
-rw-r--r-- 1 root root 0 10-28 14:46 log5-3.log
-rw-r--r-- 1 root root 0 10-28 14:48 log.log
说明:
目标文件存在时,会询问是否覆盖。这是因为cp是cp -i的别名。目标文件存在时,即使加了-f标志,也还会询问是否覆盖。
实例三:复制整个目录
命令:
输出:
目标目录存在时:
[root@localhost test]# cp -a test3 test5
[root@localhost test]# ll
-rw-r--r-- 1 root root 0 10-28 14:48 log.log
drwxr-xr-x 6 root root 4096 10-27 01:58 scf
drwxrwxrwx 2 root root 4096 10-28 14:47 test3
drwxr-xr-x 3 root root 4096 10-28 15:11 test5
[root@localhost test]# cd test5/
[root@localhost test5]# ll
-rw-r--r-- 1 root root 0 10-28 14:46 log5-1.log
-rw-r--r-- 1 root root 0 10-28 14:46 log5-2.log
-rw-r--r-- 1 root root 0 10-28 14:46 log5-3.log
-rw-r--r-- 1 root root 0 10-28 14:48 log.log
drwxrwxrwx 2 root root 4096 10-28 14:47 test3
目标目录不存在时候:
[root@localhost test]# cp -a test3 test4
[root@localhost test]# ll
-rw-r--r-- 1 root root 0 10-28 14:48 log.log
drwxr-xr-x 6 root root 4096 10-27 01:58 scf
drwxrwxrwx 2 root root 4096 10-28 14:47 test3
drwxrwxrwx 2 root root 4096 10-28 14:47 test4
drwxr-xr-x 3 root root 4096 10-28 15:11 test5
[root@localhost test]#
说明:
注意目标目录存在与否结果是不一样的。目标目录存在时,整个源目录被复制到目标目录里面。如果目标目录不存在,整个源目录被复制到一个新的目录里,有点类似复制了一个;但是必须加上参数-a,否则没法复制。
实例四:复制的 log.log 建立一个连结档 log_link.log
命令:
cp -s log.log log_link.log
输出:
[root@localhost test]# cp -s log.log log_link.log
[root@localhost test]# ll
lrwxrwxrwx 1 root root 7 10-28 15:18 log_link.log -> log.log
-rw-r--r-- 1 root root 0 10-28 14:48 log.log
drwxr-xr-x 6 root root 4096 10-27 01:58 scf
drwxrwxrwx 2 root root 4096 10-28 14:47 test3
drwxrwxrwx 2 root root 4096 10-28 14:47 test4
drwxr-xr-x 3 root root 4096 10-28 15:11 test5
说明:
那个 log_link.log 是由 -s 的参数造成的,建立的是一个『快捷方式』,所以您会看到在文件的最右边,会显示这个文件是『连结』到哪里去的!
我们在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、传递了目录属性、没有略过目录。
我常用的cp命令:
1.cp sourcefile dirname :将一个文件复制到目录diraname下面。
2.cp dir/* dir :将一个目录下的所有文件复制到目录diraname下面。
3.cp -pR dir dir2 :将一个文件夹下面的所有文件复制到目录dir2下面。
4.cp -a dir1 dir2 :将一个文件复制到目录diraname下面,而且新路径下的文件夹有源文件的相同属性。
如果在软连接和硬链接的文件里写入内容的话,源文件也会发生变化。
以上是关于linux学习中,关于文件复制的cp命令,其中有一个 -i 的命令有点问题的主要内容,如果未能解决你的问题,请参考以下文章