Java岗大厂面试百日冲刺 - 日积月累,每日三题(2),2021春招面试

  • 用户组(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文件赋予了所有人可执行权限

在这里插入图片描述


在这里插入图片描述

课间休息,又来秀一下来自咱们群里同学的搬砖工地,坐标:山西太原

作者:比方


面试题2:kill -9 和kill的区别

====================================================================================

kill 和 kill -9 是常用的命令,都可以用来杀死进程。

在这里插入图片描述

kill

kill命令默认的信号就是15,也就是 kill -15 ,被称为优雅的退出

当使用kill -15时,系统会发送一个SIGTERM的信号对应的程序。当程序接收到该信号后,具体要如何处理由程序自己来决定

应用程序的选择有三种:

  1. 立即停止程序

  2. 释放响应资源后停止程序

  3. 忽略该信号,继续执行程序

因为kill -15信号只是通知对应的进程要进行"安全、干净的退出"。

程序接到信号之后,退出前一般会进行一些准备工作,如资源释放、临时文件清理等等,如果准备工作做完了,再进行程序的终止。但是,如果在准备工作进行过程中,遇到阻塞或者其他问题导致无法成功,那么应用程序可以选择忽略该终止信号

这也就是为什么我们有的时候使用kill命令是没办法"杀死"应用的原因,因为默认的kill信号是SIGTERM(15),而SIGTERM(15)的信号是可以被阻塞和忽略的

大部分程序接收到SIGTERM信号后,会先释放自己的资源,然后在停止。但是也有程序可以在接受到信号量后,先做一些善后的事情如关闭资源或记录日志等,并且这些事情是可以配置的。

kill -9

我们在处理java项目或程序时经常会遇到kill不掉或几十秒后才退出的情况,换做我能给他等会儿,换做同事侨总的暴脾气就忍不了了,每次都直接kill -9

采访侨总时他表示他只知道kill -9这命令,我竖起大拇指微微一笑,转身把录音发给项目经理,深藏功与名~

所以,相比于kill命令,kill -9在执行时,应用程序是没有时间进行准备工作的,立即杀掉程序,所以这通常会带来一些副作用,如数据丢失或者终端无法恢复到正常状态等,具体常见问题大家可以在评论区@侨总


在这里插入图片描述

课间休息,又来秀一下来自咱们群里同学的搬砖工地,坐标:北京

作者:小庄


面试题3:你用Linux一般怎么在后台运行程序?

=======================================================================================

Linux如何在后台跑程序?是刚接触Linux的同学都会遇到的问题。大家使用Linux操作系统时,或许都遇到过以下类似场景。

  • 场景1:我用xshell通过 telnet/ssh 远程登录服务器,跑脚本或执行一些耗时较长的任务,有时会因为网络不稳定或手贱等原因断开我的控制终端(如:xshell、sourceCRT)的远程连接状态,导致花费大量时间执行的程序又要重新跑;真难受!
  • 场景2:我需要长时间稳定的跑脚本,希望能在Linux后台跑,关掉xshell也没事,且随时可以回来看输出信息或操作。

应对方式:1、nohup 命令 & 2、screen

我们知道,当用户注销(logout)或者网络断开时,终端会收到 HUP(hangup)信号从而关闭其所有子进程(包括sshd及其子进程)。

因此,我们的解决办法就有两种途径(对应以下两种方式):

  • 让进程忽略 HUP 信号;

  • 让进程运行在新的会话里从而成为不属于此终端的子进程。

方式一:nohup 命令 &


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)]

有需要完整版源码+笔记的朋友点击这里免费获取

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值