linux 添加用户、权限html
# useradd –d /usr/sam -m samjava
此命令建立了一个用户sam,其中-d和-m选项用来为登陆名sam产生一个主目录/usr/sam(/usr为默认的用户主目录所在的父目录)。linux
假设当前用户是sam,则下面的命令修改该用户本身的口令:shell
# passwdapache
Old password:******tomcat
New password:*******app
Re-enter new password:*******ssh
若是是超级用户,能够用下列形式指定任何用户的口令:ui
# passwd sam加密
New password:*******
Re-enter new password:*******
>>参考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.
二、赋予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相关配置 AllowUsers root@192.168.1.32 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}’