一,loginctl的用途:

控制 systemd 登录管理器

管理当前登录的用户和session

说明:刘宏缔的架构森林是一个专注架构的博客,地址:https://www.cnblogs.com/architectforest

对应的源码可以访问这里获取: https://github.com/liuhongdi/

说明:作者:刘宏缔 邮箱: 371125307@qq.com

二,查看loginctl所属的包及安装

1,查看所属的rpm包

[root@blog ~]# whereis loginctl
loginctl: /usr/bin/loginctl /usr/share/man/man1/loginctl.1.gz [root@blog ~]# rpm -qf /usr/bin/loginctl
systemd-239-18.el8_1.4.x86_64

2,如果找不到loginctl命令,可以用yum安装

[root@blog ~]# yum install systemd

三,查看loginctl的版本和帮助

1,查看版本

[root@blog ~]# loginctl --version
systemd 239
+PAM +AUDIT +SELINUX +IMA -APPARMOR +SMACK +SYSVINIT
+UTMP +LIBCRYPTSETUP +GCRYPT +GNUTLS +ACL +XZ +LZ4
+SECCOMP +BLKID +ELFUTILS +KMOD +IDN2 -IDN +PCRE2 default-hierarchy=legacy

2,查看帮助

[root@blog ~]# loginctl --help 

四,loginctl在使用时需要systemd-logind.service开启

[root@redis local]# loginctl list-sessions
Failed to list-sessions: Unit systemd-logind.service is masked.
[root@redis local]# systemctl start systemd-logind.service
Failed to start systemd-logind.service: Unit systemd-logind.service is masked.

如果服务被mask,需要先取消mask再start

[root@redis local]# systemctl unmask systemd-logind.service
Removed /etc/systemd/system/systemd-logind.service.
[root@redis local]# systemctl start systemd-logind.service

五,loginctl 使用例子之一:session操作

1,列出本机所有的session

# 只执行loginctl 和loginctl list-sessions效果一样,

# list-sessions是 loginctl的默认操作

[root@blog ~]# loginctl list-sessions
SESSION UID USER SEAT TTY
974 1000 webop
975 1000 webop 2 sessions listed.

说明:可以看到:同一个用户可以开启多个session

2,显示一个session的详细信息

[root@blog ~]# loginctl show-session 974
Id=974
User=1000
Name=webop
Timestamp=Thu 2020-04-09 14:14:21 CST
TimestampMonotonic=7791035206379
VTNr=0
Remote=yes
RemoteHost=43.243.12.116
Service=sshd
Scope=session-974.scope
Leader=31899
Audit=974
Type=tty
Class=user
Active=yes
State=active
IdleHint=no
IdleSinceHint=0
IdleSinceHintMonotonic=0
LockedHint=no

3,显示一个session的状态:

#session-status: session状态,指定一个session id,

#可以看到这个session开启的进程等信息

[root@blog ~]# loginctl session-status 975

4,结束指定的session

即:杀死指定会话的所有进程、释放所有与此会话相关的资源

先列出所有的session

[root@blog ~]# loginctl list-sessions
SESSION UID USER SEAT TTY
974 1000 webop
975 1000 webop

上面可以看到975这个session

#terminate-session 结束指定的session

[root@blog ~]# loginctl terminate-session 975

再次列出当前的session

[root@blog ~]# loginctl list-sessions
SESSION UID USER SEAT TTY
974 1000 webop

已经看不到975了

此时我们从975这个session的终端可以看到:

[SSH] INFO: DISCONNECT

5,kill-session  杀死session

与terminate session基本相同,但可以指定发送的信号

如果不加参数,则signal为SIGTERM

[root@blog ~]# loginctl kill-session 976

976终端上的提示

[SSH] INFO: DISCONNECT

指定的session已经结束

如果指定SIGSTOP,则session没有退出,但用户的终端会停止响应

[root@blog ~]# loginctl kill-session 980 --signal=SIGSTOP

man参考:

 -s, --signal=
When used with kill-session or kill-user, choose which signal to send to selected processes.
Must be one of the well known signal specifiers, such as SIGTERM,
SIGINT or SIGSTOP. If omitted, defaults to SIGTERM.

6,如何查看自己的tty?

[root@blog ~]$ tty
/dev/pts/0

配合session-status即可找到自己的session id

[webop@blog ~]$ loginctl session-status 983
983 - webop (1000)
Since: Thu 2020-04-09 16:22:44 CST; 1min 53s ago
Leader: 821 (sshd)
Remote: 43.243.12.116
Service: sshd; type tty; class user
State: active
Unit: session-983.scope
├─821 sshd: webop [priv]
├─823 sshd: webop@pts/0
├─824 -bash
├─870 loginctl session-status 983
└─871 less Apr 09 16:22:44 blog systemd[1]: Started Session 983 of user webop.

可以看到自己的session id是983

六,loginctl 使用例子之二:user操作

1,列出所有用户

[root@blog ~]# loginctl list-users
UID USER
1000 webop 1 users listed.

2,查看当前登录用户的详细信息:

[root@blog ~]# loginctl show-user webop
UID=1000
GID=1000
Name=webop
Timestamp=Thu 2020-04-09 13:00:09 CST
TimestampMonotonic=7786582389261
RuntimePath=/run/user/1000
Service=user@1000.service
Slice=user-1000.slice
Display=974
State=active
Sessions=983 974
IdleHint=no
IdleSinceHint=0
IdleSinceHintMonotonic=0
Linger=no

3,查看登录用户的状态

[root@blog ~]# loginctl user-status webop
webop (1000)
Since: Thu 2020-04-09 13:00:09 CST; 3h 29min ago
State: active
Sessions: 983 *974
Linger: no
Unit: user-1000.slice
├─session-974.scope
│ ├─ 902 loginctl user-status webop
│ ├─ 903 less
│ ├─31899 sshd: webop [priv]
│ ├─31902 sshd: webop@pts/1
│ ├─31904 -bash
│ ├─31932 sudo -i
│ └─31933 -bash
├─session-983.scope
│ ├─821 sshd: webop [priv]
│ ├─823 sshd: webop@pts/0
│ └─824 -bash
└─user@1000.service
└─init.scope
├─31746 /usr/lib/systemd/systemd --user
└─31749 (sd-pam) Apr 09 14:14:29 blog sudo[31932]: pam_systemd(sudo-i:session): Cannot create session: Already running in a session or user slice
Apr 09 14:14:29 blog sudo[31932]: pam_unix(sudo-i:session): session opened for user root by webop(uid=0)
Apr 09 15:23:43 blog sshd[31740]: pam_unix(sshd:session): session closed for user webop
Apr 09 15:37:43 blog sshd[32339]: pam_unix(sshd:session): session closed for user webop
...

4,结束指定用户的所有session

[root@blog ~]# loginctl terminate-user webop 

5,停止用户的终端

[webop@blog ~]$ loginctl kill-user webop --signal=SIGSTOP

七,查看centos版本

[root@blog ~]# cat /etc/redhat-release
CentOS Linux release 8.0.1905 (Core)

centos8平台使用loginctl管理登录用户与session的更多相关文章

  1. Spark项目之电商用户行为分析大数据平台之(六)用户访问session分析模块介绍

    一.对用户访问session进行分析 1.可以根据使用者指定的某些条件,筛选出指定的一些用户(有特定年龄.职业.城市): 2.对这些用户在指定日期范围内发起的session,进行聚合统计,比如,统计出 ...

  2. centos8平台使用journalctl管理systemd-journald日志

    一,systemd-journald的作用 1,什么是systemd-journald? systemd-journald 是 systemd 自带的日志系统,是一个收集并存储各类日志数据的系统服务. ...

  3. centos8平台使用rpm管理软件包

    一,什么是rpm rpm是redhat package manager redhat的软件包管理器 说明:刘宏缔的架构森林是一个专注架构的博客,地址:https://www.cnblogs.com/a ...

  4. centos8平台使用parted管理分区

    一,parted的用途 parted是GNU发布的强大的分区工具, parted命令可以划分单个分区大于2T的GPT格式的分区,也可以划分普通的MBR分区. 因为fdisk命令对于大于2T的分区无法划 ...

  5. Xianfeng轻量级Java中间件平台:权限管理

    权限管理:是通过系统对用户的行为进行控制的一套业务规则,可以做得很简单,比如通过硬编码的方式进行控制,也可以做得很复杂,比如通过一些复杂的权限模型去实现一些复杂的权限控制,比如菜单访问权限.按钮操作权 ...

  6. ThreadLocal管理登录信息

    通常在项目中,用户登录后,我们会将用户的信息存到session,如果想在其它地方获取session中的用户信息,我们需要先获取HttpServletRequest,再通过request.getSess ...

  7. Linux下查看/管理当前登录用户及用户操作历史记录

    转载自: http://www.cnblogs.com/gaojun/archive/2013/10/24/3385885.html 一.查看及管理当前登录用户 1.使用w命令查看登录用户正在使用的进 ...

  8. C#开发微信门户及应用(41)--基于微信开放平台的扫码登录处理

    在现今很多网站里面,都使用了微信开放平台的扫码登录认证处理,这样做相当于把身份认证交给较为权威的第三方进行认证,在应用网站里面可以不需要存储用户的密码了.本篇介绍如何基于微信开放平台的扫码进行网站的登 ...

  9. SNF快速开发平台2019-权限管理模型-记录级-字段级权限实践

    1.1.1  字段级权限 字段级权限适用于对不同人的能否查看或录入不同表不同字段的权限控制. 是否启用字段级权限配置 不启用字段级权限后,[用户权限管理]程序[字段级权限]按钮会隐藏,导致无法给管理其 ...

随机推荐

  1. mysql 5.7密码策略和安装密码校验插件validate_password

    当执行sql:SHOW VARIABLES LIKE 'validate_password%';提示empty,说明没有安装密码插件 1.查看当前mysql安装的插件信息 mysql> show ...

  2. ARL(资产侦察灯塔系统)-源码搭建

    freebuf能力中心开源了一套资产扫描系统(https://github.com/TophantTechnology/ARL),提供docker版,但并无源码搭建的文档(无完整文档).于是在星光哥及 ...

  3. 复习 | 彻底弄懂Flexbox之Demo篇

    flexbox之前有接触,写项目时也用过,但也只是简单的,对其也是似懂非懂,所以今天下定决心把这个再学一遍,因为似懂非懂就是不懂 本文主要是的demo演示,想看flexbox语法 请移步flexbox ...

  4. C#开发PACS医学影像处理系统(十五):Dicom影像交叉定位线算法

    1.定位线概念:某个方位的影像在另一个方向的影像上的投影相交线,例如横断面(从头到脚的方向)在矢状面(从左手到右手)上的影像投影面交线. 举个例子:右边的是MR(核磁共振)的某一帧切片,这是从头开始扫 ...

  5. python的学习准备工作

    python是开放的的语言,可以从官方网站下载www.python.org 下载下来后直接运行安装就行了 ctrl+n新建一个文件 ctrl+s保存,以.py为扩展名 点run module 或者F5 ...

  6. docker的使用场景和背景了解

    Docker的使用场景以及优缺点 https://blog.csdn.net/zhangdekui/article/details/81541519 浅析Docker容器的应用场景 https://w ...

  7. ES6 常用总结——第三章(数组、函数、对象的扩展)

    1.1. Array.from() Array.from方法用于将两类对象转为真正的数组:类似数组的对象(array-like object)和可遍历(iterable)的对象(包括ES6新增的数据结 ...

  8. 【JAVA】HashMap源码阅读

    目录 1.关键的几个static参数 2.内部类定义Node节点 3.成员变量 4.静态方法 5.HashMap的四个构造方法 6.put方法 7.扩容resize方法 8.get方法 9.remov ...

  9. JVM学习(四)JVM调优

    一.调优命令 Sun JDK监控和故障处理命令有jps.jstat.jmap.jhat.jstack.jinfo jps,JVM Process Status Tool,显示指定系统内所有的HotSp ...

  10. MMC & SD 发展历史

    一.概述 MMC 卡和 SD 卡都是基于 Nand Flash 技术的移动存储卡. MMC(MultiMediaCard) 卡于 1997 年由西门子和 Sandisk 推出,SD (Secure D ...