Linux中不同用户之间复制文件的两个方法
前言
考虑如下情景:foo用户home目录下有一文件file.txt,要将其copy至bar用户的home目录。Linux对用户home目录有严格的权限限制,非owner用户或者同group用户无权限读写,除非是root(至高无上的root)。如果没有root权限,有什么办法把file.txt 复制到bar用户的home目录下呢?
想到两个办法。
第一个办法,先用foo用户登录,把文件copy到系统临时目录/tmp,然后切换到bar用户,再从系统临时目录/tmp把文件copy到自己的home目录。这里为什么用cp不用mv?因为复制到/tmp的文件owner还是foo,默认情况下其他用户自有读权限,没有写权限(自然没有移动权限)。即使通过修改文件权限,让bar可写,移动到bar的home目录下owner还是foo,而且非得root才能改成bar。这个办法有点曲折,弊端也很明显,文件需要复制两次,花两倍的时间。
# cp file.txt /tmp/ # su - bar # cp /tmp/file.txt ~/ # exit # rm /tmp/file.txt
第二个办法,使用scp
命令。原本scp
是用来在不同主机上通过网络copy文件,用在这里刚好。用bar用户登录
# scp foo@localhost:/home/foo/file.txt ./
输入foo用户密码,开始文件传输。也可以用foo用户登录,
# scp file.txt bar@localhost:/home/bar/
输入bar用户密码,过程一样。
实际中使用哪一种方法,看个人喜好了。如果要copy的文件不大,第一种方法也不失为一种选择。
结束语
以上就是给大家分享的Linux中不同用户之间复制文件的两个方法,希望对大家的学习和工作能有所帮助。如果有疑问可以留言讨论。
- Linux 入门常用命令 password — 修改密码,改变用户
- linux下passwd命令设置修改用户密码的方法
- linux查看所有用户和查看用户组的方法(修改用户组)
- Linux下SFTP用户权限设置条件及实现命令
- 更改linux用户登录shell的操作方法
- Linux给普通用户加超级用户权限的方法
- linux中如何添加用户并赋予root权限详解
- Linux下交互式与非交互式修改用户密码的例子
- linux服务器下添加用户和删除用户的命令
- LINUX下Oracle数据库用户创建方法详解
- 如何在Linux下修改Mysql的用户(root)密码
- Linux 怎么实现添加FTP用户并设置权限的方法
- 在Linux系统的命令行中为MySQL创建用户的方法
- linux尝试登录失败后锁定用户账户的两种方法
- linux之普通用户与root用户之间切换方法
- Linux用户在第一次登录时强制更改初始密码
- Linux下Oracle删除用户和表空间的方法
- Unix/Linux系统下的nobody用户与nologin详细介绍
相关文章
使用CentOS 7.5卸载自带jdk安装自己的JDK1.8的过程
这篇文章主要介绍了使用CentOS 7.5卸载自带jdk安装自己的JDK1.8 的过程,本文通过安装步骤给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下2018-11-11Ubuntu 14.04 搭建 apt-get 服务器的教程
这篇文章主要介绍了Ubuntu 14.04 搭建 apt-get 服务器的教程,非常不错,具有参考借鉴价值,需要的朋友可以参考下2017-01-01
最新评论