信创操作系统--统信UOS桌面版(使用Systemd管理系统服务)


冬日文静
冬日文静 2022-09-29 09:46:48 52224
分类专栏: 资讯


信创操作系统–统信UOS桌面版(使用Systemd管理系统服务)


前言

安全中心是统信UOS预装的安全辅助应用,主要包括系统体检、病毒查杀、防火墙、自启动管理以及系统安全等功能,可以全面提升系统的安全性。

1、使用Systemd管理系统服务

system是操作系统的管家,通过它可以快捷、方便的管理系统的各项功能。

1.1、systemd概述

Systemd是 Linux操作系统中最基础的组成部分,作为操作系统的第一个用户进程(PID1)运行并启动操作系统的其余部分,其主要作用是进行操作系统和服务管理。
Systemd 具有并行启动系统服务的功能,使用套接字和D-Bus激活来启动服务,按需启动、守护程序,使用Linux cgroups跟踪进程,维护安装和自动挂载点,以及实现精心设计的基于事务依赖关系的服务控制逻辑。
Systemd支持SysV和LSB 初始化脚本,并替代SysVinit。Systemd 的其他功能包括日志记录守护程序,用于控制基本系统配置,如主机名、日期、区域设置、已登录用户和正在运行的容器、虚拟机的列表、系统账户、运行时目录和设置等,也可用于管理简单网络的守护程序配置,如网络事件的同步,日志转发以及名称解析等
虽然systemd功能较强大,管理范围较宽广,但它的核心只有一个/bin/systemd。Linux内核启动后,它作为第一个被执行的用户进程,起到了承上启下的作用。当某个进程占用太多系统资源时,systemd有权执行(MOO killer)机制来杀死该进程,即彻底结束该进程,以此保护整个系统不会因资源耗尽而崩溃。

1.2、服务管理

systemd最重要的功能就是对系统的服务管理,服务进程的启动、重启等都时由它控制的。如在准备搭建一个网站前,需在终端执行sudo apt install nginx命令安装NGINX(Web服务器),然后就可以用如下所示的命令来管理NGINX服务器。

*启动服务:sudo systectl start nginx.sercive*
*停止服务:sudo systectl stop niginx.service*
*重启服务:sudo systectl restart niginx.service* 
*查看服务:sudo systemctl status nginx.service*
*开机启动服务:sudo systemctl enable nginx.service*
*禁止开机启动服务:sudo systemctl disable nginx.service*
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

1.3、电源管理

在终端中执行如下命令可对计算机的电源进行管理。
重启:执行命令sudo systemctl reboot
关机:执行命令sudo systemctl poweroff
待机:执行命令sudo systemctl suspend
休眠:执行命令sudo systemctl hibernate

1.4、日志管理

  1. systemd可以使用journalctl命令管理日志。
    执行命令sudo journalctl可查看所有日志,如图1-1所示。

在这里插入图片描述

图1-1 筛选出与内核相关日志
  1. 执行命令sudo journalctl -p err,可查看所有日志,并筛选出错误相关的日志,如图1-2所示。

在这里插入图片描述

图1-2 筛选错误相关的日志
  1. 除了err,还可以替换为其他的参数来查看所有日志,并筛选出错误相关的日志,可选参数有0:emerg、1:alert、2:crit、3:err、4:warning、5:notice、6:info或7:debug。其中数字代表级别,级别越高越详细。在使用err查看日志时也可以使用3来代替err,其效果是一样的。
  2. 执行命令sudo journalctl -b,可查看本次开机到查看日志时的日志,如图1-3所示。

在这里插入图片描述

图1-3开机到查看日志时的日志
  1. 执行命令sudo journalctl -b -l,可查看上一次开机到关机的日志;
  2. 上述参数还可以组合使用,如执行命令sudo journalctl -b -l -k -p err可查看上一次开机到关机的日志,并筛选出内核出错的日志;
    还可以查看自某个时间点以来的日志,如执行命令sudo journalctl –since “2021-09-19 12:00”,即可查看自该时间点到查看日志时的日志;
  3. 执行命令sudo journalctl –since “2021-09-18 12:00” - -until ”2021-09-19 12:30”,可查看指定时间段的日志;
  4. 除了查看指定时间段的日志外还可以查看指定服务的日志,如查看NGINX服务的日志,执行命令sudo journalctl -u nginx即可;
    查看完日志后可执行命令sudo journalctl > ~/rizhi.txt,重定向日志到根目录下的rizhi.txt中。
  5. 如果发现只能显示本次启动的日志,而不能显示上次启动的的日志,可能时因为日志没有存储在磁盘上,可执行如下命令来开启的磁盘存储功能。
    sudo mkdir /var/log/journal
    sudo chown root:system-journal /var/log/journal
    sudo chmod 2775 /var/log/journal
    sudo systemctl restart system-journald.service

1.5、主机信息管理

  1. 执行命令homenamectl,可查询主机信息,如图1-4所示。

在这里插入图片描述

图1-4 主机信息
  1. 执行命令sudo hostnamectl set-hostname UOS可设置主机名称,在执行命令bash刷新主机名称,如图1-5所示。

在这里插入图片描述

图1-5设置主机主机名称

1.6、系统语言管理

执行命令localectl可查询系统语言设置,如图1-6所示。

在这里插入图片描述

图1-6系统语言设置

执行命令sudo localect set-locale LANG=zh_CN.utf8可设置系统语言为中文;
执行命令sudo localectl set-keymap zh_CN可设置系统键盘布局为中文。

1.7、时间管理

执行timedatectl 可查看系统时区,如图1-7所示。

在这里插入图片描述

图1-7 系统时区

执行命令timedatectl list-timezone,可显示所有可用时区;
执行命令sudo timedatectl set-ntp false,可关闭网络同步时间服务;
执行命令sudo timedatectl set-timezone America/New_York,可设置系统时区。
当需要手动更改系统本地时间时,需要先手动关闭同步时间服务。

1.8、登录管理

当某个用户登录操作系统后,systemd 会在内存开辟一块区域,叫作session,里面存放着这个用户登录后运行的进程。当用户注销后,session会被删除,内存会被回收。
执行命令loginctl list-sessions,列出当前session,如图1-8所示。

在这里插入图片描述

图1-8 session

systemd允许同一用户在不同终端同时登录,但每次登录都会生成新的session,一个session的崩溃或者注销不会影响到另一个session,session之间有一定的隔离性。
执行命令loginctl list-users,即可列出当前登录用户,如图1-9所示。

在这里插入图片描述

图1-9 当前登录用户

2、系统错误排查

当系统没能按照预期运行,出现应用程序无响应、卡顿或者崩溃的现象时,可以通过查看系统的各种日志来定位问题所在,然后通过修改代码或者修改配置等方式来解决。

2.1、使用journalctl查看内核和应用错误

在终端中执行命令sudo journalctl,然后输入斜杠【/】进入搜索模式;
输入关键词查找内核和应用错误的详细信息,并按【Enter】键进行搜索。按【PageUp】键和【PageDown】键进行翻页,或按【N】键搜索下一个匹配。

2.2、使用coredumpctl查看应用崩溃错误

在终端中执行命今sudo apt install systemd-coredump安装systemd-coredump工具。当程序崩溃时,可能会产生core文件(一般用来调试代码bug),然后被systemd-coredump工具捕获,这样可以很方便地使用coredumpctl命令查看应用崩溃的信息。
执行命令sudo coredumpctl list可查看崩溃的进程列表,其中包含崩溃进程的PID值(进程ID,各进程的身份标识),如图1-10所示。

在这里插入图片描述

图1-10 崩溃的进程列表

执行命令sudo coredumpctl info 796,可查看某个崩溃进程的详细信息,其中796值得是该进崩溃进程的PID值,如图1-11所示。

在这里插入图片描述

图1-11 查看某个崩溃进程的详细信息

想进一步了解崩溃原因,可以进行调试。在终端中执行命令sudo coredumpctl debug 10914,系统默认调用GDB进行调试,可以使用bt命令查看堆栈信息,确定应用崩溃的原因,如图1-12所示。

在这里插入图片描述

图1-12 确定应用崩溃的原因

2.3、查看系统日志和内核日志

在 system-journal之前,Linux系统上一般是使用rsyslog来记录系统日志和内核日志。日志一般放在/var/log/message目录下,可以使用cat、less或tail去读取日志。
执行命令sudo less /var/log/messages,可查看所有日志;
执行命令sudo less /var/log/syslog,可查看系统日志;
执行命令sudo less /var/log/kern.log,可查看内核日志;
执行命令sudo less /var/log/boot.log可查看启动日志;
执行命令sudo less /var/log/user.log可查看用户日志。

2.4、查看桌面日志

在系统运行的过程中,有时会遇到桌面崩溃、进程退出、桌面黑屏等情况,可以执行命令sudo less /var/log/Xorg.0.log查看桌面日志来定位问题。

2.5、查看串口日志

有些问题,如磁盘损坏、内核崩溃、固件问题等,通过上文的方式均无法定位问题,需要以更加底层的方式去获取日志,此时就需要通过串口去获取固件、内核以及操作系统的日志。


制作成员: 郑伟钦
排版: 梁汉荣
初审: 蔡君贤
复审: 二月二
在这里插入图片描述


点击下方“正月十六工作室”查看更多学习资源

正月十六工作室

网站声明:如果转载,请联系本站管理员。否则一切后果自行承担。

本文链接:https://www.xckfsq.com/news/show.html?id=10879
赞同 0
评论 0 条
冬日文静L1
粉丝 0 发表 14 + 关注 私信
上周热门
如何使用 StarRocks 管理和优化数据湖中的数据?  2944
【软件正版化】软件正版化工作要点  2863
统信UOS试玩黑神话:悟空  2823
信刻光盘安全隔离与信息交换系统  2718
镜舟科技与中启乘数科技达成战略合作,共筑数据服务新生态  1251
grub引导程序无法找到指定设备和分区  1217
华为全联接大会2024丨软通动力分论坛精彩议程抢先看!  163
点击报名 | 京东2025校招进校行程预告  162
2024海洋能源产业融合发展论坛暨博览会同期活动-海洋能源与数字化智能化论坛成功举办  160
华为纯血鸿蒙正式版9月底见!但Mate 70的内情还得接着挖...  157
本周热议
我的信创开放社区兼职赚钱历程 40
今天你签到了吗? 27
信创开放社区邀请他人注册的具体步骤如下 15
如何玩转信创开放社区—从小白进阶到专家 15
方德桌面操作系统 14
我有15积分有什么用? 13
用抖音玩法闯信创开放社区——用平台宣传企业产品服务 13
如何让你先人一步获得悬赏问题信息?(创作者必看) 12
2024中国信创产业发展大会暨中国信息科技创新与应用博览会 9
中央国家机关政府采购中心:应当将CPU、操作系统符合安全可靠测评要求纳入采购需求 8

加入交流群

请使用微信扫一扫!