Linux中普通用户如何在root管理权限下创建文件

Linux中普通用户如何在root管理权限下创建文件

如果直接使用普通用户在root拥有的权限目录下直接创建目录,系统会报“权限不够” 的错误

drwxr--r--. 4 root     root    4096 10月 14 20:50 test
[zhangsan@node02 home]$ mkdir test/666.txt
mkdir: 无法创建目录"test/666.txt": 权限不够

普通用户使用sudo 创建 sudo mkdir 文件名时 提示错误“用户名 不在 sudoers 文件中”

drwxr--r--. 4 root     root    4096 10月 14 20:50 test
[zhangsan@node02 home]$ sudo mkdir test/666.txt
[sudo] password for zhangsan: 
Sorry, try again.
[sudo] password for zhangsan: 
zhangsan 不在 sudoers 文件中。此事将被报告。
如果遇见上述问题以下方式可以解决:
-r--r-----. 1 root root 3729 10月 14 20:52 sudoers

1.使用root用户将 /etc/sudoers文件权限改为:

-rwxrwxrwx. 1 root root 3729 10月 14 20:52 sudoers

操作命令是:chmod 777 /etc/sudoers

2.进入sudoers文件中进行修改。
进入sudoers文件修改命令:vim /etc/sudoers
进入文件后 /root 查找到有root的地方

## Allow root to run any commands anywhere 
root    ALL=(ALL)       ALL

/root   

在下方添加你需要给权限的用户名 在这我用zhangsan代替

## Allow root to run any commands anywhere 
root    ALL=(ALL)       ALL
zhangsan        ALL=(ALL)       ALL

写完后 shift+:wq保存

3.因为sudoers文件只能在权限为-r–r-----.时生效,所以保存完毕后需要将sudoers文件权限改回为原来权限。修改命令为: chmod 440 /etc/sudoers

如果觉得修改sudoers文件权限很麻烦 可直接进入第二步 在修改后保存时输入:shift+:wq!
如果不懂上述命令中的 777 或 440代表什么意思的 可以点击下方链接: Linux权限管理
  • 10
    点赞
  • 31
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
linux操作系统 一、单项选择题 1. 关于Linux内核版本的说法,以下错误的是()。 A.表示为主版本号.次版本号.修正号 B.1.2.3表示稳定的发行版 C.1.3.3表示稳定的发行版 D.2.2.5表示对内核2.2的第5次修正 2. 系统引导的过程一般包括如下几步: a.MBR的引导装载程序启动; b.用户登录; c.Linux内核运行; d.BIOS自检。 正确的顺序是()。 A.d,b,c,a B.d,a,c,b C.b,d,c,a D.a,d,c,b 3. 字符界面下使用shutdown命令重启计算机时所用的参数是()。 A.-h B.-t C.-k D.-r 4. 下面哪个不是桌面环境软件? A.KDE B.twm C. Gnome D.CDE 5. 在UNIX/Linux系统添加新用户的命令是() A. groupadd B. usermod C. userdel D. useradd 6. Android系统是基于Linux操作系统开发的手机系统,因此在进行刷机、删除系统自带软件时需要获得管理员账户( )的权限。 A.administrator B.admin C.root D.liveuser 7.已知当前系统umask的值为022,请问这时新建目录文件的权限为()。 A. 755 B. 644 C.775 D.664 8.已知用户sarwar在虚拟终端1和虚拟终端2及图形用户界面下登录,请问sarwar在虚拟终端1执行ls >tty2后,命令输出到哪里?() A.虚拟终端1 B.虚拟终端2 C.图形终端 D.无输出 二、填空题(每空1分,共15分) 1. Linux系统有三种基本的文件类型:普通文件、目录文件和 设备文件 。 2. 在超级用户下显示Linux系统正在运行的全部进程,应使用的命令及参数是 ps -aux 。 3. 将前一个命令的标准输出作为后一个命令的标准输入,称之为 管道 。 4. /sbin 目录用来存放系统管理员使用的管理程序。 5. 安装Linux系统对硬盘分区时,必须有两种分区类型: 文件系统分区 和 交换分区 。 11.将/home/stud1/wang目录做归档压缩,压缩后生成wang.tar.gz文件,并将此文件保存到/home目录下,实现此任务的tar命令格式__ __tar -czvf wang.tar.gz /home/stud1/wang_ 三、判断题(每题1分,共10分) 1. Ubuntu LINUX安装时自动创建了根用户。( T ) 2. LINUX的超级用户为root,登陆时不需要口令。( F ) 3. Linux不可以与MS-DOS、OS/2、Windows等其他操作系统共存于同一台机器上。( F ) 4. Linux的特点之一是它是一种开放、免费的操作系统。 ( T ) 5. RedHat系统,默认情况下根口令没有字符长短的的限制,但是必须把口令输入两次;如果两次输入的口令不一样,安装程序将会提示用户重新输入口令。 ( F ) 四、问答题\应用操作题(每题5分,共25分) 1. Linux内核主要由哪几部分组成?每部分的作用? Linux内核主要由五个子系统组成:进程调度,内存管理,虚拟文件系统,网络接口,进程间通信。 进程调度(SCHED):控制进程对CPU的访问。当需要选择下一个进程运行时, 由调度程序选择最值得运行的进程; 内存管理(MM)允许多个进程安全的共享主内存区域; 虚拟文件系统(VirtualFileSystem,VFS)隐藏了各种硬件的具体细节,为所有的设备提供了统一的接口,VFS提供了多达数十种不同的文件系统; 网络接口(NET)提供了对各种网络标准的存取和各种网络硬件的支持; 进程间通讯(IPC) 支持进程间各种通信机制。 2. vi编辑器有哪几种工作模式?如何在这几种工作模式之间转换? Vi的工作模式有三种:命令模式、输入模式、末行模式。 在命令模式下输入a、A、i、I、o、O等命令之一可以进入输入模式, 在输入模式下按Esc键回到命令模式; 在命令模式下输入:进入末行模式,末行命令执行完后回到命令模式。 3.假设你是系统管理员,需要增加一个新的用户账号u1,为新用户设置初始密码,锁定用户账号u2,并删除用户账号u3。请写出完成本题所述功能的命令序列 useradd u1 -添加用户u1 passwd 123456 -为用户添加密码123456 passwd -l u2 -锁定用户账号u2 userdel u3 -删除用户账号u3 4.写出将/abc目录所有文件及目录打包压缩成文件abc.tar.gz的命令。 tar -zcvf abc.tar.gz /bc 5.创建一个用户,用户名为user02,所属私有组和标准组为group01,用户主目录为/home/user02,用户登录shell为/bin/bash。 useradd -g group01 –G group01 –d /home/user02 -s /bin/bash user02 五、综合题(1题10分,1题10分,共20分) 1、已知管理员用户的主目录结构如图2所示: (1)管理员用户目前在/R/B/T4/S0,分别写出执行以下命令后,管理员在目录系统的位置。 cd /R cd .. /R/B/T4 cd ../.. /R/B cd / / cd ~ /R (2)写出删除目录C的两种办法。 1.rm -rf /root/C 2.rm /root/T3 rm /root/T4 rmdik/root/C (3)已知管理员用户在/R目录,分别用绝对路径和相对路径方式写出将目录/R/C/T3/S0的文件复制到/R/D/T5目录的方法。 cp /R/C/T3/S0 /R/D/T5 cp /C/T3/S0 /D/T5 2、设计一个shell程序计算n的阶乘。要求: (1) 从命令行接收参数n; (2) 在程序开始后立即判断n的合法性,即是否有参数,若有是否为正整数,若非法请给错误提示; (3) 最后输出计算的结果。 #!/bin/sh echo “please input your number n:” read n #if(( ! -n “$n”)); then if test -z “$”; then echo “n is no data !” exit 1 else if(( $n<=));then echo -e “$n is no zhengzhengshu.\n”; exit 1 fi fi fact=1;tmp=1 while[$tmp -le $n ] do fact=$((fact*tmp));tmp=$((++tmp)); done echo "fact=$fact"
linux下创建用户 1、添加ftp用户 useradd ftpname -d /home/ftp passwd ftppwd 以下操作都以root权限进行: service vsftpd start 启动Linux自带的FTP服务 2. 添加普通用户 useradd nagios –d /usr/local/nagios chown nagios.nagios /usr/local/nagios 将用户切换到nagios 用户,添加nagios的访问用户: su nagios htpasswd –c /usr/local/nagios/etc/htpasswd.users nagiosadmin 系统会提示输入两次密码,例如两次输入nagios。 注: 这是第一次创建用户,需要“-c”选项,表示创建一个存放用户名和密码的文件,当再次添加用户或修改密码时不用“-c”选项。 添加新的用户账号使用useradd命令,其语法如下:   useradd 选项 用户名   其各选项含义如下:   -c comment 指定一段注释性描述。   -d 目录 指定用户主目录,如果此目录不存在,则同时使用-m选项,可以创建主目录。   -g 用户组 指定用户所属的用户组。   -G 用户组,用户组 指定用户所属的附加组。   -s Shell文件 指定用户的登录Shell。   -u 用户号 指定用户的用户号,如果同时有-o选项,则可以重复使用其他用户的标识号。   用户名 指定新账号的登录名。   例如:   # useradd –d /usr/sam -m sam   此命令创建了一个用户sam,其-d和-m选项用来为登录名sam产生一个主目录/usr/sam(/usr为默认的用户主目录所在的父目录)。   # useradd -s /bin/sh -g group –G adm,root gem   此命令新建了一个用户gem,该用户的登录Shell是/bin/sh,它属于group用户组,同时又属于adm和root用户组,其group用户组是其主组。   增加用户账号就是在/etc/passwd文件为新用户增加一条记录,同时更新其他系统文件如/etc/shadow, /etc/group等。这几个文件的内容在后面会做详细介绍。   Linux提供了集成的系统管理工具userconf,它可以用来对用户账号进行统一管理。   如果一个用户的账号不再使用,可以从系统删除。删除用户账号就是要将/etc/passwd等系统文件的该用户记录删除,必要时还删除用户的主目录。删除一个已有的用户账号使用userdel命令,其格式如下:   userdel 选项 用户名   常用的选项是-r,它的作用是把用户的主目录一起删除。   例如:   # userdel sam   此命令删除用户sam在系统文件(主要是/etc/passwd, /etc/shadow, /etc/group等)的记录,同时删除用户的主目录。   修改用户账号就是根据实际情况更改用户的有关属性,如用户号、主目录、用户组、登录Shell等。   修改已有用户的信息使用usermod命令,其格式如下:   usermod 选项 用户名   常用的选项包括-c, -d, -m, -g, -G, -s, -u以及-o等,这些选项的意义与useradd命令的选项一样,可以为用户指定新的资源值。另外,有些系统可以使用如下选项:   -l 新用户名   这个选项指定一个新的账号,即将原来的用户名改为新的用户名。   例如:   # usermod -s /bin/ksh -d /home/z –g developer sam   此命令将用户sam的登录Shell修改为ksh,主目录改为/home/z,用户组改为developer。   用户管理的一项重要内容是用户口令的管理。用户账号刚创建时没有口令,但是被系统锁定,无法使用,必须为其指定口令后才可以使用,即使是指定空口令。   指定和修改用户口令的Shell命令是passwd。超级用户可以为自己和其他用户指定口令,普通用户只能用它修改自己的口令。命令的格式为:   passwd 选项 用户名   可使用的选项:   -l 锁定口令,即禁用账号。   -u 口令解锁。   -d 使账号无口令。   -f 强迫用户下次登录时修改口令。   如果默认用户名,则修改当前用户的口令。   例如,假设当前用户是sam,则下面的命令修改该用户自己的口令:   $ passwd   Old password:******   New password:*******   Re-enter new password:*******   如果是超级用户,可以用下列形式指定任何用户的口令:   # passwd sam   New password:*******   Re-enter new password:*******   普通用户修改自己的口令时,passwd命令会先询问原口令,验证后再要求用户输入两遍新口令,如果两次输入的口令一致,则将这个口令指定给用户;而超级用户为用户指定口令时,就不需要知道原口令。   为了系统安全起见,用户应该选择比较复杂的口令,例如最好使用8位长的口令,口令包含有大写、小写字母和数字,并且应该与姓名、生日等不相同。   为用户指定空口令时,执行下列形式的命令:   # passwd -d sam   此命令将用户sam的口令删除,这样用户sam下一次登录时,系统就不再询问口令。   passwd命令还可以用-l(lock)选项锁定某一用户,使其不能登录,例如:   # passwd -l sam 二、Linux系统用户组的管理 每个用户都有一个用户组,系统可以对一个用户组的所有用户进行集管理。不同Linux 系统对用户组的规定有所不同,如Linux下的用户属于与它同名的用户组,这个用户组在创建用户时同时创建。 用户组的管理涉及用户组的添加、删除和修改。组的增加、删除和修改实际上就是对/etc/group文件的更新。 1、增加一个新的用户组使用groupadd命令。 其格式如下: 代码: groupadd 选项 用户组 可以使用的选项有: 代码: -g GID 指定新用户组的组标识号(GID)。 -o 一般与-g选项同时使用,表示新用户组的GID可以与系统已有用户组的GID相同。 例1: 代码: # groupadd group1 此命令向系统增加了一个新组group1,新组的组标识号是在当前已有的最大组标识号的基础上加1。 例2: 代码: #groupadd -g 101 group2 此命令向系统增加了一个新组group2,同时指定新组的组标识号是101。 2、如果要删除一个已有的用户组,使用groupdel命令, 其格式如下: 代码: groupdel 用户组 例如: 代码: #groupdel group1 此命令从系统删除组group1。 3、修改用户组的属性使用groupmod命令。 其语法如下: 代码: groupmod 选项 用户组 常用的选项有: 代码: -g GID 为用户组指定新的组标识号。 -o 与-g选项同时使用,用户组的新GID可以与系统已有用户组的GID相同。 -n新用户组 将用户组的名字改为新名字 例1: 代码: # groupmod -g 102 group2 此命令将组group2的组标识号修改为102。 例2: 代码: # groupmod –g 10000 -n group3 group2 此命令将组group2的标识号改为10000,组名修改为group3。 4、如果一个用户同时属于多个用户组,那么用户可以在用户组之间切换,以便具有其他用户组的权限。用户可以在登录后,使用命令newgrp切换到其他用户组,这个命令的参数就是目的用户组。 例如: 代码: $ newgrp root 这条命令将当前用户切换到root用户组,前提条件是root用户组确实是该用户的主组或附加组。类似于用户账号的管理,用户组的管理也可以通过集成的系统管理工具来完成。 权限分配 分配权限 chown -R hadoop:hadoop /usr/hadoop/ 让普通用户拥有root的权限 1.root登录 2.adduser 用户名 3.passwd 用户名 确定密码 4.修改/etc/passwd即可,把用户名的ID和ID组修改成0。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值