- 用户组(Group)
- 其它用户(Other Users)
chmod(change mode)命令
:是控制用户对文件的权限的命令。
# 语法:
chmod [-cfvR] [--help] [--version] mode file...
# 简化:
chmod mode files
其中mode可以通过字符串
形式或数字
形式设定
字符串形式配置
:
mode写法:
[ugoa][+-=][rwx]
[ugoa]
表示:
-
u(owner)表示文件所有者,即创建文件的人
-
g(group):表示和文件所有者相同组的用户
-
o(other):表示非文件所有者和相同group的用户
-
a(all):表示所有用户
[+-=]
表示:
-
+:表示给指定的用户授权指定的权限
-
-: 表示撤销指定用户的某个权限
-
=: 将指定用户的指定权限重新设置
[rwx]
表示:
-
r:可读权限
-
w:可写权限
-
x:可执行权限
通过[ugoa][+-=][rwx]
拼接配置文件、目录的访问权限。下面就以陈哈哈的小秘密.txt
文件为例,来看一下:
# 给文件所有者(陈哈哈)设置可读权限
chmod u+r /home/csj/xiaomimi.txt
# 给文件所有者(陈哈哈)设置读写执行权限
chomd u+rwx test.txt
# 给所有用户设置可执行权限
chmod a+x /home/csj/xiaomimi.txt
# 将其他用户的可写权限撤销
chmod o-x /home/csj/xiaomimi.txt
# 给所有用户可读权限。这tm我的秘密是不也太不值钱了?随便搞?
chmod a-r /home/csj/xiaomimi.txt
数字形式配置
:
相信这是我们最常见的赋权方式:chmod -R 777 /home/csj/xiaomimi.txt
chmod可以使用八进制数来指定权限,无需再使用指定的权限和用户的字母来进行标识,通过读写执行等3个权限的数字来进行设置
-
r(读)
的权限的数字为4
。 -
w(写)
的权限的数字为2
。 -
x(执行)
的权限数字为1
。
所以7表示的赋权的用户有读写执行权限,最大的权限,下面是对照表。
| #八进制值 | 权限 | 二进制值 | rwx |
| — | — | — | — |
| 7 | 读+写+执行 | 111 | rwx |
| 6 | 读+写 | 110 | rw- |
| 5 | 读+执行 | 101 | r-x |
| 4 | 只读 | 100 | r– |
| 3 | 写+执行 | 011 | -wx |
| 2 | 只写 | 010 | -w- |
| 1 | 只执行 | 001 | –x |
| 0 | 无权限 | 000 | — |
如下,给xiaomimi.txt文件赋予了所有人可执行权限
课间休息,又来秀一下来自咱们群里同学的搬砖工地,坐标:山西太原。
作者:比方
====================================================================================
kill 和 kill -9 是常用的命令,都可以用来杀死进程。
kill
kill命令默认的信号就是15,也就是 kill -15 ,被称为优雅的退出
。
当使用kill -15时,系统会发送一个SIGTERM的信号
给对应的程序
。当程序接收到该信号后,具体要如何处理由程序自己来决定
。
应用程序的选择有三种:
-
立即停止程序
-
释放响应资源后停止程序
-
忽略该信号,继续执行程序
因为kill -15信号只是通知对应的进程要进行"安全、干净的退出"。
程序接到信号之后,退出前一般会进行一些准备工作
,如资源释放、临时文件清理等等,如果准备工作做完了,再进行程序的终止。但是,如果在准备工作进行过程中,遇到阻塞或者其他问题导致无法成功,那么应用程序可以选择忽略该终止信号
。
这也就是为什么我们有的时候使用kill命令是没办法"杀死"应用的原因,因为默认的kill信号是SIGTERM(15),而SIGTERM(15)的信号是可以被阻塞和忽略的
。
大部分程序接收到SIGTERM信号后,会先释放自己的资源,然后在停止。但是也有程序可以在接受到信号量后,先做一些善后的事情如关闭资源或记录日志等
,并且这些事情是可以配置的。
kill -9
我们在处理java项目或程序时经常会遇到kill不掉或几十秒后才退出的情况,换做我能给他等会儿,换做同事侨总
的暴脾气就忍不了了,每次都直接kill -9
。
采访侨总时他表示他只知道kill -9
这命令,我竖起大拇指微微一笑,转身把录音发给项目经理,深藏功与名~
所以,相比于kill命令,kill -9在执行时,应用程序是没有时间进行准备工作的,立即杀掉程序,所以这通常会带来一些副作用,如数据丢失或者终端无法恢复到正常状态等,具体常见问题大家可以在评论区@侨总
。
课间休息,又来秀一下来自咱们群里同学的搬砖工地,坐标:北京。
作者:小庄
=======================================================================================
Linux如何在后台跑程序?是刚接触Linux的同学都会遇到的问题。大家使用Linux操作系统时,或许都遇到过以下类似场景。
- 场景1:我用xshell通过 telnet/ssh 远程登录服务器,跑脚本或执行一些耗时较长的任务,有时会因为网络不稳定或手贱等原因断开我的控制终端(如:xshell、sourceCRT)的远程连接状态,导致花费大量时间执行的程序又要重新跑;真难受!
- 场景2:我需要长时间稳定的跑脚本,希望能在Linux后台跑,关掉xshell也没事,且随时可以回来看输出信息或操作。
应对方式
:1、nohup 命令 &
2、screen
我们知道,当用户注销(logout)或者网络断开时,终端会收到 HUP(hangup)信号从而关闭其所有子进程(包括sshd及其子进程)。
因此,我们的解决办法就有两种途径(对应以下两种方式):
-
让进程忽略 HUP 信号;
-
让进程运行在新的会话里从而成为不属于此终端的子进程。
nohup 是我们最常用的办法。顾名思义,nohup 就是让提交的命令忽略 hangup 信号。从而当ssh连接状态断开时,不会被系统中断掉。nohup 在使用上十分方便,只需在要处理的命令前加上 nohup 即可,标准输出和标准错误缺省会被重定向到 nohup.out 文件中。一般我们可在结尾加上 &
表示将命令放入后台运行。
比如我们测试在后台执行 ping www.baidu.com
命令,如下即可:
nohup ping www.baidu.com &
Docker步步实践
目录文档:
①Docker简介
②基本概念
③安装Docker
④使用镜像:
⑤操作容器:
⑥访问仓库:
⑦数据管理:
⑧使用网络:
⑨高级网络配置:
⑩安全:
⑪底层实现:
⑫其他项目:
[外链图片转存中…(img-iduraUVz-1628574455219)]
⑦数据管理:
[外链图片转存中…(img-lnYevjil-1628574455220)]
⑧使用网络:
[外链图片转存中…(img-xYg2kBjs-1628574455220)]
⑨高级网络配置:
[外链图片转存中…(img-rAzJ4hA0-1628574455221)]
⑩安全:
[外链图片转存中…(img-LBGM4beD-1628574455222)]
⑪底层实现:
[外链图片转存中…(img-69ikto2e-1628574455223)]
⑫其他项目:
[外链图片转存中…(img-STfZGdLT-1628574455224)]
有需要完整版源码+笔记的朋友点击这里免费获取