Java岗大厂面试百日冲刺 - 日积月累,每日三题【Day21】—— Linux命令(1)

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前在阿里

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Linux运维全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上运维知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化的资料的朋友,可以点击这里获取!

其中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 &

在这里插入图片描述

同时,会在输入命令的目录下生成一个nohup.log日志文件(如已有该文件则继续使用)

当然,也可加上 >filename 2>&1 来自行更改日志输出的目录及文件filename。如下:

nohup ping www.baidu.com > /home/myout.log 2>&1 &

在这里插入图片描述

方式二:screen


我们认为Screen是目前最实用的Linux后台运行工具之一。简单的说,screen 提供了 ANSI/VT100 的终端模拟器,使它能够在一个真实终端下运行多个全屏的伪终端,每个伪终端我们称之为一个session。

相当于我们可以用xshell打开多个连接(session),不用时可以将这些连接置为离线状态 - Detached离线状态下session中的程序会正常运行,也就是后台运行,并随时可以恢复继续使用,恢复使用时为Attached在线状态,说明有人正在使用。

如何使用screen

在这里插入图片描述

上图是screen的session列表,图中Attached代表有其他终端正在使用这个session,Detached说明session处于离线状态,

下面一起来看一下我们使用Screen时,常用的一些命令:

screen -S name -> 创建一个名为:name 的session(伪终端)

screen -R name -> 先试图恢复离线的session。若找不到离线的,即建立新的session(伪终端)

screen -ls -> 列出所有已经存在的session

ctrl + a + d -> 退出当前的session

screen -d name -> 将指定的session作业离线。

最全的Linux教程,Linux从入门到精通

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

  1. linux从入门到精通(第2版)

  2. Linux系统移植

  3. Linux驱动开发入门与实战

  4. LINUX 系统移植 第2版

  5. Linux开源网络全栈详解 从DPDK到OpenFlow

华为18级工程师呕心沥血撰写3000页Linux学习笔记教程

第一份《Linux从入门到精通》466页

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

内容简介

====

本书是获得了很多读者好评的Linux经典畅销书**《Linux从入门到精通》的第2版**。本书第1版出版后曾经多次印刷,并被51CTO读书频道评为“最受读者喜爱的原创IT技术图书奖”。本书第﹖版以最新的Ubuntu 12.04为版本,循序渐进地向读者介绍了Linux 的基础应用、系统管理、网络应用、娱乐和办公、程序开发、服务器配置、系统安全等。本书附带1张光盘,内容为本书配套多媒体教学视频。另外,本书还为读者提供了大量的Linux学习资料和Ubuntu安装镜像文件,供读者免费下载。

华为18级工程师呕心沥血撰写3000页Linux学习笔记教程

本书适合广大Linux初中级用户、开源软件爱好者和大专院校的学生阅读,同时也非常适合准备从事Linux平台开发的各类人员。

需要《Linux入门到精通》、《linux系统移植》、《Linux驱动开发入门实战》、《Linux开源网络全栈》电子书籍及教程的工程师朋友们劳烦您转发+评论

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以点击这里获取!

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

g-blog.csdnimg.cn/img_convert/9d4aefb6a92edea27b825e59aa1f2c54.png)

本书适合广大Linux初中级用户、开源软件爱好者和大专院校的学生阅读,同时也非常适合准备从事Linux平台开发的各类人员。

需要《Linux入门到精通》、《linux系统移植》、《Linux驱动开发入门实战》、《Linux开源网络全栈》电子书籍及教程的工程师朋友们劳烦您转发+评论

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以点击这里获取!

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值