linux 用户权限设置
# useradd –d /usr/sam -m
sam
此命令创建了一个用户sam,其中-d和-m选项用来为登录名sam产生一个主目录/usr/sam(/usr为默认的用户主目录所在的父目录)。
假设当前用户是sam,则下面的命令修改该用户自己的口令:
#
passwd
Old
password:******
New
password:*******
Re-enter new
password:*******
如果是超级用户,可以用下列形式指定任何用户的口令:
#
passwd sam
New
password:*******
Re-enter new
password:*******
>>参考1====================================
1、添加用户
首先用adduser命令添加一个普通用户,命令如下:
#adduser
tommy //添加一个名为tommy的用户
#passwd tommy
//修改密码
Changing password for user
tommy.
New UNIX password:
//在这里输入新密码
Retype new UNIX password:
//再次输入新密码
passwd: all authentication tokens updated
successfully.
2、赋予root权限
方法一:修改
/etc/sudoers 文件,找到下面一行,把前面的注释(#)去掉
## Allows people in
group wheel to run all commands
%wheel
ALL=(ALL)
ALL
然后修改用户,使其属于root组(wheel),命令如下:
#usermod
-g root tommy
修改完毕,现在可以用tommy帐号登录,然后用命令 su -
,即可获得root权限进行操作。
方法二:修改 /etc/sudoers
文件,找到下面一行,在root下面添加一行,如下所示:
## Allow root to run any
commands anywhere
root
ALL=(ALL) ALL
tommy
ALL=(ALL)
ALL
修改完毕,现在可以用tommy帐号登录,然后用命令 su -
,即可获得root权限进行操作。
>>参考2====================================
用useradd新增的用户不能直接用ssh远程访问,需要修改ssh相关配置
如下:
vi
/etc/ssh/sshd_config
添加
AllowUsers
[email protected]
admin
多个用户用空格隔开
>>参考3====================================
如何让普通用户获得root用户的权限执行操作而不需要知道root用户的密码或向root用户进行切换呢?有一个命令sudo可以实现这个功能.
Sudo的工作流程:
(1)root用户编辑/etc/sudoers文件,添加要分配的普通用户记录,其中有这么一行记录:root
ALL=(ALL) ALL,在这行后面添加:Sam ALL=(ALL) ALL
(2)
那么sam用户在执行操作时,如果所执行的操作自己没有权限,则会去/etc/sudoers文件中查找是否有对应的记录,如果有的话则临时获得root权限,执行只有root才能执行的操作.
注意:这里会提示输入密码,但是输入的是sam用户的密码,而不是root用户的密码.例如:
Shell>
sudo mkdir –p a/b/c/d
We trust you have received the usual
lecture from the local System
Administrator. It usually
boils down to these three things:
#1) Respect the privacy
of others.
#2) Think before you
type.
#3) With great power comes great
responsibility.
Password:
#这里的密码是sam用户自己的密码,而不是root的密码
几个操作:
1)
编辑/etc/sudoers文件,使用visudo命令,
Shell>
visudo
其实visudo命令也是调用vi去编辑sudoer文件的,但是在保存时会去检查你修改后文件的语法,如果错误是不能保存的,但是如果直接用vi来编辑该文件,强制保存虽然成功,但是如果有语
法错误这里并不能给出提示,也就导致了后面sudo命令的不可用.
2)
记录解析:
Sam ALL=(ALL) ALL
使用者帐户
登入的主机=(可以变换的身份) 可以下达的命令
上述语句的意思是
sam用户可以在任何地方登录,并可切换成任何用户进行任何操作.这里如果(ALL)不写,只写为 sam
ALL=ALL,他默认只能切换为root用户.
>>参考4====================================
linux
chown命令参数及用法详解--改变档案的所有者:
要更改文件 program.c 的所有者: chown
jim program.c
program.c 的用户访问权限现在应用到 jim。作为所有者,jim 可以使用
chmod 命令允许或拒绝其他用户访问 program.c。
要将目录 /tmp/src
中所有文件的所有者和组更改为用户 john 和组 build:chown -R john:build
/tmp/src
如: tomcat的安装目录的所有者修改(#chown -R user:group
/usr/java/tomcat5.5)
>>参考5====================================
linux下添加,删除,修改,查看用户和用户组
1,创建组
groupadd
test
增加一个test组
2,修改组
groupmod
-n test2
test
将test组的名子改成test2
3,删除组
groupdel
test2
删除
组test2
4,查看组
a),查看当前登录用户所在的组
groups,查看apacheuser所在组groups apacheuser
b),查看所有组 cat
/etc/group
c),有的linux系统没有/etc/group文件的,这个时候看下面的这个方法
cat
/etc/passwd |awk -F [:] ‘{print $4}’ |sort|uniq | getent group |awk -F [:]
‘{print
$1}’
这里用到一个命令是getent,可以通过组ID来查找组信息,如果这个命令没有的话,那就很难查找,系统中所有的组了.
二,用户操作
1,增加用户
查看复制打印?
[root@krlcgcms01
mytest]# useradd –help
Usage: useradd [options]
LOGIN
Options:
-b, –base-dir
BASE_DIR
设置基本路径作为用户的登录目录
-c, –comment
COMMENT
对用户的注释
-d, –home-dir
HOME_DIR
设置用户的登录目录
-D,
–defaults
改变设置
-e, –expiredate EXPIRE_DATE
设置用户的有效期
-f, –inactive
INACTIVE
用户过期后,让密码无效
-g, –gid
GROUP
使用户只属于某个组
-G, –groups
GROUPS
使用户加入某个组
-h,
–help
帮助
-k, –skel
SKEL_DIR
指定其他的skel目录
-K, –key
KEY=VALUE 覆盖
/etc/login.defs 配置文件
-m,
–create-home
自动创建登录目录
-l,
不把用户加入到lastlog文件中
-M,
不自动创建登录目录
-r,
建立系统账号
-o,
–non-unique
允许用户拥有相同的UID
-p, –password
PASSWORD
为新用户使用加密密码
-s, –shell
SHELL
登录时候的shell
-u, –uid
UID
为新用户指定一个UID
-Z, –selinux-user
SEUSER use a specific SEUSER for the SELinux user
mapping
[root@krlcgcms01 mytest]# useradd
--help
Usage: useradd [options]
LOGIN
Options:
-b,
--base-dir BASE_DIR
设置基本路径作为用户的登录目录
-c, --comment
COMMENT
对用户的注释
-d, --home-dir
HOME_DIR
设置用户的登录目录
-D,
--defaults
改变设置
-e, --expiredate EXPIRE_DATE
设置用户的有效期
-f, --inactive
INACTIVE
用户过期后,让密码无效
-g, --gid
GROUP
使用户只属于某个组
-G, --groups
GROUPS
使用户加入某个组
-h,
--help
帮助
-k, --skel
SKEL_DIR
指定其他的skel目录
-K, --key
KEY=VALUE 覆盖
/etc/login.defs 配置文件
-m,
--create-home
自动创建登录目录
-l,
不把用户加入到lastlog文件中
-M,
不自动创建登录目录
-r,
建立系统账号
-o,
--non-unique
允许用户拥有相同的UID
-p, --password
PASSWORD
为新用户使用加密密码
-s, --shell
SHELL
登录时候的shell
-u, --uid
UID
为新用户指定一个UID
-Z, --selinux-user
SEUSER use a specific SEUSER for the SELinux user
mappinguseradd test
passwd
test
增加用户test,有一点要注意的,useradd增加一个用户后,不要忘了给他设置密码,不然不能登录的。
2,修改用户
usermod
-d /home/test -G test2
test
将test用户的登录目录改成/home/test,并加入test2组,注意这里是大G。
gpasswd
-a test test2 将用户test加入到test2组
gpasswd -d test test2
将用户test从test2组中移出
3,删除用户
userdel
test
将test用户删除
4,查看用户
a),查看当前登录用户
[root@krlcgcms01
~]# w
[root@krlcgcms01 ~]#
who
b),查看自己的用户名
[root@krlcgcms01
~]#
whoami
c),查看单个用户信息
[root@krlcgcms01
~]# finger apacheuser
[root@krlcgcms01 ~]# id
apacheuser
d),查看用户登录记录
[root@krlcgcms01
~]# last 查看登录成功的用户记录
[root@krlcgcms01 ~]# lastb
查看登录不成功的用户记录
e),查看所有用户
[root@krlcgcms01
~]# cut -d : -f 1 /etc/passwd
[root@krlcgcms01 ~]# cat
/etc/passwd |awk -F \: ‘{print
$1}’
----------------------------------------------------------------
Linux下有三类用户:
1.超级用户:
root 具有操作系统的一切权限, UID为0
2.普通用户:具有操作系统有限的权限
UID为500—6000
3.伪用户:
是为了方便系统管理,满足相应的系统进程文件属主的要求,不能登录系统,UID为1--499
Linux通过
/etc/passwd进行用户管理,
执行命令打开该文件: vi
/etc/passwd
在此文件中只定义账号,不定义口令。一行定义一个用户,分为七个部分:
第一列为账号名称,
第二列为用户密码(密码不在此定义),
第三列为用户标识码(用户ID),用来确认用户身份
第四列为用户所在组的表示(用户组ID),
第五列为用户相关信息(如root),
第六列为用户家目录(/root),
第七列为用户的环境(用户使用的shell)
shell:命令行命令解析器,如
echo $SHELL,查看当前shell
id
账户名,查看当前账户的uid
改变所属用户组:
chgrp
[-R] dirname/filename ..
-R:
进行递归(recursive)的持续更改,即连同子目录下得所有文件、目录都更新成这个用户组。常常用在更改某一目录的情况
eg:
chgrp users
install.log
//users为用户组名
更改文件拥有者:
文件拥有者必须已经存在于系统中们也就是在/etc/passwd这个文件中有记录的用户名称才可改变
chown
[-R] 账号名称:文件或目录
chown [-R]
账号名称:用户组名称、文件或目录
eg: chown bin
install.log
chown root:root
install.log
当需要复制文件给其他人时:
cp 源文件 目的文
eg: cp
.bashrc
.bashrc_test
ls -al
.bashrc*
更改9个属性:
数字类型改变文件权限
使用chmod命令改变文件的属性,属性的设置方法有两种,分别可以使用数字或者是符号:
Linux
文件的基本属性有9个,分别是
owner/group/others组别的read/write/excute属性。
eg:
-rwxrwxrwx中,三个为一组,其中可以使用数字来表示各个属性,各属性的对照表位:
r:4
w:2
x:1
将同一组(owner/group/others)的3个属性(r/w/x)累加,如当前属性为[-rwxrwx---],则是:
owner=rwx=4+2+1=7
group=rwx=4+2+1=7
others=
---
=0+0+0=0
该属性为770.
更改属性的命令chmod语法:
chmod
[-R] xyz
文件或目录
xyz:就是数字类型的权限属性,为rwx属性数值的和
eg:
ls -al .bashrc
chmod
777 .bashrc
ls -al
.bashrc
符号类型改变文件权限
可以通过u(user)、g(group)、o(others)来表示三组的属性,a表示all,即全部的三组,读写属性可以写成r、w、x:
chmod
u
g
o
a
+(加入)
-(除去)
=(设置)
r
w
x
文件或目录
eg:
chmod u=rwx,go=rx .bashrc
如果想把一个文件属性设置为
-rwxr-xr--,可以这样: chmod u=rwx,g=rx,o=r
filename
如果不知道文件的原先属性,但想增加其的每人均可写入的权限,可以这样:
chmod
a+w
filename
去掉所有人的x属性:
chmod
a-x filename
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。