• 在 Linux 中如何禁止用户登录


    默认情况下,Linux中创建用户帐户时,用户具有shell访问权限。在某些情况下不需要用户帐户登录shell。本文介绍如何设置已存在的用户禁止shell登录、创建用户时禁止shell登录。

    创建用户时设置禁止shell登录


    默认情况下,创建用户时,将按照/etc/default/useradd文件中定义的为用户分配shell。Linux中附带了一个/sbin/nologinshell,当用户尝试连接时,它会显示一条消息“This account is current not available”。这是禁止用户登录shell的一种方法。下面是使用方式:

    useradd -s /sbin/nologin {username}

    下面实例,创建一个用户,shell设置为/sbin/nologin

    [root@localhost ~]# useradd user01 -s /sbin/nologin
    [root@localhost ~]# tail -1 /etc/passwd
    user01:x:1000:1000::/home/user01:/sbin/nologin

    查看/etc/passwd可以看到user01的shell为/sbin/nologin

    给user01用户设置密码,然后ssh登录测试一下:

    [root@localhost ~]# echo '123'|passwd --stdin user01
    Changing password for user user01.
    passwd: all authentication tokens updated successfully.
    [root@localhost ~]# ssh user01@localhost
    user01@localhost's password: 
    This account is currently not available.
    Connection to localhost closed.

    输入密码之后,提示This account is current not available,然后连接就关闭了。

    为现有用户时设置禁止shell登录


    更改现有用户的shell,可以使用usermodchsh两个命令来修改:chsh命令使用语法如下:

    chsh -s /sbin/nologin {username}

    下面修改user02用户的shell:

    # Centos8默认没有安装chsh,使用下面命令安装:
    [root@localhost ~]# yum -y install util-linux-user
    [root@localhost ~]# chsh -s /sbin/nologin user02
    Changing shell for user02.
    chsh: Warning: "/sbin/nologin" is not listed in /etc/shells.
    Shell changed.

    usermod命令使用语法如下:

    usermod -s /sbin/nologin {username} 

    下面修改user03用户的shell:

    [root@localhost ~]# usermod -s /sbin/nologin user03

    也可以手动修改/etc/passwd文件中的用户shell。

     

    转自https://mp.weixin.qq.com/s/vuFygVagKLuVeYrqGlRo4w

  • 相关阅读:
    iot 表 主键索引叶子块包含了表所有数据
    iot 表索引dump《2》
    iot 表索引dump《2》
    heap表和iot表排序规则不同
    heap表和iot表排序规则不同
    ActiveMQ学习总结(4)——业界消息队列简介
    主宰全球的10大算法
    主宰全球的10大算法
    主宰全球的10大算法
    SVN学习总结(1)——SVN简介及入门使用
  • 原文地址:https://www.cnblogs.com/cangqinglang/p/15320603.html
Copyright © 2020-2023  润新知