一 什么是进程
1 在Linux系统当中,触发任何一个事件时,系统都会将它定义成为一个进程,并且给予这个进程一个ID,称为PID,同时依据触发这个进程的用户与相关属性关系,给予这个PID一组有效的权限设置
2 我们说过,系统应该是仅认识二进制文件的,那么当我们要让系统工作的时候,当然就需要启动一个二进制文件,那个二进制文件就是程序
3 程序:通常为二进制程序放置在存储媒介中(如硬盘,光盘,软盘,磁带等),以物理文件的形式存在
进程:程序被触发后,执行者的权限与属性,程序的程序代码与所需数据等都会被加载到内存中,操作系统并给予这个内存中的单元一个标识符PID,可以说,进程就是一个正在运行中的程序
4 连续执行两个bash后,第二个bash的父进程就是前一个bash,因为每个进程都有一个PID,那某个进程的父进程可以通过PPID来判断
5 在Linux的过程调用中通常称为fork-and-exec的流程:进程都会通过父进程以复制fork的方式产生一个一模一样的进程,然后被复制出来的子进程再以exec的方式来执行实际要进行的进程,最终就成为一个子进程的存在
6 系统先以fork的方式复制一个与父进程一模一样暂存进程,这个进程与父进程唯一的区别就是PID不同,但是这个暂存进程还会多一个PPID参数,然后暂存进程开始以exec的方式加载实际要执行的程序,最终成为子进程
二 工作管理
1 在进行工作管理的行为中,其实每个工作都是目前bash的子进程,即彼此之间是有相关性的。即我们无法以工作管理的方式从tty1的环境去管理tty2的bash
2 假设我只有一个终端,因此在可以出现提示符让你操作的环境就称为前台,至于其他工作就可以让你放入后台去暂停或运行。要注意的是,放入后台的工作想要运行时,它必须不能够与用户互动。
3 总之要进行工作管理的限制是:
1 这些工作所触发的进程必须来自于你shell的子进程
2 前台:你可以控制与执行命令的这个环境称为前台工作
3 后台:可以自行运行的工作,你无法使用Ctrl+c终止它,可使用bg/fg调用该工作
4 后台中“执行”的进程不能等待终端的输入
4 直接将命令丢到后台中“执行”的&,这个&代表的是“将工作丢到后台中,不怕被Ctrl+c中断
5 将目前的工作丢到后台中“暂停”,Ctrl+z
6 在vi的一般模式下,按下Ctrl+z这两个按键,屏幕上面会出现[1],表示这是第一个工作,而那个+代表最近一个被丢进后台的工作,且目前在后台下默认会被取用的那个工作。而Stopped表示的是这个工作是暂停的
7 其实后台的工作+代表的是最近被放到后台的工作号码,-代表最近最后第二个被放置到后台的工作号码,而超过最后三个以上的工作,就不会有+/-符号存在了
8 将后台的工作拿到前台来处理fg,fg %jobnumber,jobnumber是工作号码
9 让工作在后台下的状态变成运行中bg,bg %jobnumber,jobnumber是工作号码
10 管理后台的工作kill
kill -signal %jobnumber
-1,重新读取一次参数的配置文件
-2,代表由键盘输入Ctrl+c同样的操作
-9,立刻强制删除一个工作
-15,以正常的程序终止一个工作,并将该工作强制删除
11 kill后面接的数字默认会是PID,如果想要管理bash的工作控制,就得要加上%数字了
12 脱机管理问题
1 我们在工作管理中所提到的“后台”指的是在终端机模式下可以避免Ctrl+c中断的一个情境,并不是放到系统的后台中
2 我们可以使用nohup命令实现真正的放到系统后台来运行
nohup 命令与参数 -->在终端机的前台工作
nohup 命令与参数 & -->在系统的后台工作
3 nohup并不支持bash内置的命令,因此你的命令必须要是外部命令才行
4 如果我们想要让在后台的工作在你注销后还能够继续执行,可以使用nohup命令
三 进程管理
1 进程的查看分为两种静态的ps以及动态的top
2 ps相关命令
ps aux -->查看系统所有的进程数据
ps -lA -->查看所有系统的数据
ps axjf -->连同部分进程树的状态
3 通常,造成僵尸进程的成因是因为该进程应该执行完毕,或者是因故应该要终止了,但是该进程的父进程却无法完整的将该进程结束掉,而造成那个进程一直在内存中。通过ps axu命令查看进程状态,如果在某个进程的最末尾有<defunct>就说明是僵尸进程
4 top动态的查看进程的变化,top -d 数字 -->数字表示要几秒钟刷新一下
5 一般来说我们经常需要找到最损耗资源的那个进程,大多数都是利用top这个程序,然后强制与CPU使用资源来排序
6 所有的进程都是依附在init这个进程下面的,init这个进程的PID是1号,因为它是由Linux内核所主动调用的第一个进程
7 系统资源的查看
1 free 查看内存的使用情况
2 uname 查看系统与内核相关信息
3 uptime 查看系统启动时间与工作负载
4 netstat 跟踪网络
5 dmesg 分析内核产生的信息
四 SELinux初探
1 什么是SELinux呢?其实就是安全强化Linux的意思
2 SELinux是通过MAC的方式来控管进程,它控制的主体是进程,而目标则是该进程能够读取的文件资源
3 SELinux支持三种模式
ecforcing:强制模式,代表SELinux正在运行中
permissive:宽容模式,代表SELinux正在运行中,不过仅会有警告信息并不会有实际限制domain/type的访问
disabeld:关闭,SELinux并没有实际运行
4 我们可以通过getenforce来查看当前的SELinux是哪一种模式
5 如果要启动SELinux的话,我们应该修改/etc/selinux/config,将这个文件的SELINUX=enforing设置妥当,并且指定SELINUXTYPE=targeted这一设置,并且到/boot/grub/menu.lst这个文件去,看看内核有没有关闭SELinux
分享到:
相关推荐
在IT行业中,容器技术已经成为应用部署和管理的标准方式,Docker是其中的领头羊。在CentOS系统上安装Docker时,一个重要的组件就是`container-selinux`,它在安全上下文中扮演了关键角色。本文将详细介绍`container-...
4.el7.noarch.rpm.zip`这个压缩包文件是与Docker相关的,它包含了一个名为`container-selinux-2.9-4.el7.noarch.rpm`的软件包,这是Docker在Red Hat Enterprise Linux 7 (RHEL 7)或其兼容版本如CentOS 7上安装和运行...
标题中的"container-selinux-2.9-4.el7.noarch.zip"表明这是一个与Linux安全模块SELinux(Security-Enhanced Linux)相关的软件包,适用于版本为2.9的container-selinux,并且它是针对EL7(Enterprise Linux 7,通常...
解决container-selinux >= 2:2.74,它被软件包 3:docker-ce-19.03.5-3.el7.x86_64 需要问题.container-selinux-2.74-1.el7.noarch.rpm
centos系统安装docker时常缺此安装包, 下载rpm安装包后执行命令: rpm -i container-selinux-2.9-4.el7.noarch.rpm 即可完成安装,再继续docker其他安装。
docker安装部署依赖包container-selinux-2.9-4.el7.noarch.rpm,yum资源无法下载。
container-selinux-2.107-3.el7.noarch.rpm
官方离线安装包,亲测可用。使用rpm -ivh [rpm完整包名] 进行安装
k3s-selinux-1.3-1.el7.noarch.rpm
官方离线安装包,亲测可用
错误:软件包:containerd.io-1.2.10-3.2.el7.x86_64 (docker-ce-stable) 需要:container-selinux >= 2:2.74
centos 7.4 安装docker 18所需 container-selinux-2.68-1.el7.noarch.rpm
离线安装包,亲测可用
ubuntu20.04.1_x86系统安装selinux所需软件包
离线安装包,亲测可用
官方离线安装包,亲测可用。使用rpm -ivh [rpm完整包名] 进行安装
官方离线安装包,亲测可用。使用rpm -ivh [rpm完整包名] 进行安装
docker-ce-selinux-17.05.0.ce-1.el7.centos.noarch.rpm离线安装包。
安装 Docker 时资源包docker-ce-18.03.1.ce-1.el7.centos.x86_64.rpm的依赖包