Linux常见面试题汇总

Linux上如何查询某个端口是否被占用?

在Linux上,你可以使用以下几种方法来查询某个端口是否被占用:

  1. 使用netstat命令:

    netstat -tuln | grep <端口号>
    

    这个命令会列出当前正在运行的所有TCP和UDP端口,并过滤出指定端口是否被占用。如果端口被占用,会显示对应的PID和程序名称。

  2. 使用ps命令结合grep命令:

    ps -aux | grep <端口号>
    

    这个命令会列出所有正在运行的进程,并过滤出包含指定端口号的进程信息。通过查看对应的PID和程序名称,可以判断该端口是否被占用。

Linux常见目录有哪些?

Linux 系统中常见的目录有以下几个

  1. /bin:存放常用的命令二进制可执行文件,如 ls、grep 等
  2. /etc:系统配置文件目录,存放系统管理和配置文件
  3. /home:普通用户的主目录,在个人使用时通常将用户目录放在这里
  4. /root:超级管理员的主目录
  5. /usr:存放应用程序和文件。
    1. /usr/bin:应用程序目录,与/bin类似,但存放不常用的应用程序
    2. /usr/lib:共享库目录,存放系统和应用程序所需的共享库文件
    3. /usr/share:共享文件目录,不同系统和程序共享的数据文件存放这里
  6. /var:放系统运行过程中的各种变化文件,如日志
  7. /opt:可选应用软件包安装目录
  8. /tmp:临时文件目录

Linux中的常用命令有哪些?

Linux常用命令如下:

  1. ls: 列出当前目录下的文件和子目录信息。

    • 使用方式:ls [-options] [file/directory]
    • 示例:ls /home/user 列出 /home/user 目录下的所有文件信息。
  2. cd: 切换当前工作目录。

    • 使用方式:cd [directory]
    • 示例:cd Documents 切换到 Documents 目录,使用 cd … 返回上一级目录。
  3. pwd: 显示当前工作目录的绝对路径。

    • 使用方式:pwd
  4. mkdir: 创建新的目录。

    • 使用方式:mkdir [directory]
    • 示例:mkdir javacn 创建 “javacn” 文件夹。
  5. touch: 创建新文件或者更新已存在文件的时间戳。

    • 使用方式:touch [file]
    • 示例:touch newfile.txt
  6. rm: 删除指定的文件或目录。

    • 使用方式:rm [-options] file/directory
    • 示例:rm file.txt(删除单个文件)、rm -r directory(递归删除目录及其内容)。
  7. cp: 复制文件或目录。

    • 使用方式:cp [-options] source destination
    • 示例:cp file1.txt file2.txt(复制文件)、cp -r dir1 dir2(复制目录)
  8. mv: 移动或重命名文件或目录。

    • 使用方式:mv [-options] source destination
    • 示例:mv file.txt newfile.txt(重命名文件)、mv file.txt /dir/(移动文件到指定目录)。
  9. find: 在指定目录下查找满足条件的文件。

    • 使用方式:find [path] [expression]
    • 示例:find . -name “*.txt” 在当前目录及其子目录下查找扩展名为 .txt 的文件。
  10. grep: 搜索文件中匹配特定模式的行。
    • 使用方式:grep [options] pattern file(s)
    • 示例:grep “hello” file.txt 在 file.txt 中查找包含 “hello” 的行。

你可以使用命令的 --help 参数或查看相关命令的手册页(man 页)来获取更详细的信息,比如 man ls 可以查看 ls 命令的手册页

Linux中如何查看日志信息?

在 Linux 系统中查看日志一般需要以下两个步骤:

第一步:找到存放日志的位置。 日志文件通常存放在 /var/log 目录及其子目录中,不同的服务和应用程序可能会有自己独立的日志文件。常见的系统日志文件包括 /var/log/messages/var/log/syslog/var/log/dmesg 等,而特定服务或应用程序的日志文件则位于其对应的目录下,例如 Apache Web 服务器的日志文件通常位于 /var/log/apache2/ 目录下

第二步:使用以下命令查询具体的日志信息:

  1. cat: 查看某个日志文件中的所有内容

    • 使用示例:cat file.txt 显示 file.txt 文件的所有内容
  2. head: 查看某个日志文件中开头的内容

    • 使用示例:head file.txt 显示 file.txt 文件的前 10 行内容。也可以指定查看的行数,例如,head -n 5 file.txt 显示 file.txt 文件的前 5 行内容
  3. tail: 查看某个日志文件中末尾的内容,用法和 head 类似

    • 使用示例:tail file.txt 显示 file.txt 文件的最后 10 行内容
  4. more: 分页方式显示文件内容,常用来查看大型日志文件

    • 使用示例:more file.txt 分页查看 file.txt 文件内容,一次只显示一屏内容,用户通过空格键或回车键翻看下一页,按 q 退出查看

Linux中如何查看负载情况?什么情况算负载比较高?

在Linux系统中,可以使用以下几种方式来查看系统的负载情况:

  1. 使用 uptime 命令:

    • uptime 命令可以显示系统的运行时间以及平均负载。
    • 示例:uptime
  2. 使用 top 命令:

    • top 命令可以实时显示系统的各项指标,包括负载情况、CPU利用率、内存使用情况等。
    • 示例:top

单核负载 0.7 以下是健康的情况,反之大于 0.7 表示负载比较高,对应四核健康的情况就是 0.7*4=2.8 是健康的情况,大于 2.8 就表示负载比较高

实际工作中如何排查CPU飙升问题?

在实际工作中,我们可以通过以下步骤来排查CPU飙升的问题:

  1. 使用系统监控工具:首先,我们可以使用系统监控工具,如top命令,来查看所有进程占系统CPU的排序。这样可以帮助我们快速定位到占用CPU资源最多的进程

  2. 查看具体进程的CPU占用情况:接着,我们可以执行top -Hp 进程号命令,查看该进程下的所有线程占CPU的情况

  3. 查看耗CPU的线程:然后,我们可以执行printf \"%x\\n 线程号\"命令,把线程号转成16进制,以便在后续查看线程堆栈信息

  4. 查看线程堆栈信息:我们可以执行jstack 进程号 | grep 线程ID命令,查找某进程下线程ID(jstack堆栈信息中的nid)的线程状态

  5. 查看GC情况:我们还可以执行jstat -gcutil 进程号 统计间隔毫秒 统计次数命令,查看某进程GC持续变化情况

  6. 查看进程的堆内存情况:我们可以执行jmap -heap 进程ID命令,查看一下进程的堆内从是不是要溢出了

  7. 导出内存heap到文件中:最后,我们可以执行jmap -dump:format=b,file=filename 进程ID命令,导出某进程下内存heap输出到文件中

以上步骤可以帮助我们定位到问题所在,例如是否存在死锁,是否有大量消耗CPU的操作,或者内存消耗过大导致Full GC次数过多等问题。这些都是我们在实际工作中可能会遇到的问题,通过这些步骤,我们可以有效地排查和解决这些问题

如何获取当前Java程序的堆日志?如何查看堆日志分析和排查问题?

在Java应用程序的开发和维护过程中,了解和分析Java堆信息是一项重要的任务。本文将介绍如何获取Java堆信息的不同方法,并提供一些分析堆信息的实用技巧。

获取Java堆信息的方法

  1. Java虚拟机(JVM)工具
    1. 使用jcmd命令:在命令行中运行jcmd GC.heap_info,其中是Java进程的进程ID。这个命令会输出与Java堆有关的信息,包括堆的使用情况、对象分配统计等。
    2. 使用jmap命令:在命令行中运行jmap -heap ,其中是Java进程的进程ID。这个命令会显示Java堆的详细信息,包括堆的大小、已使用空间、GC收集器等。
    3. 使用jconsole工具:启动jconsole,选择要监视的Java进程。在内存选项卡下,您可以查看堆的使用情况、生成报告和进行分析。
  2. Java内存分析工具
    1. 使用VisualVM:这是一个功能强大的Java性能监视和分析工具。它提供了深入分析Java堆和内存的功能,包括堆的大小、对象数量、内存泄漏检测等。
    2. 使用Eclipse Memory Analyzer:这是一款专用于分析Java堆转储文件(Heap Dump)的工具。它可以帮助您识别内存泄漏问题、查找大对象和无效对象等。
  3. 堆转储文件
    1. 通过在JVM启动参数中添加-XX:+HeapDumpOnOutOfMemoryError标志,当发生内存溢出错误时,JVM将自动生成堆转储文件(Heap Dump)。这些文件包含了完整的Java堆信息,您可以使用Java内存分析工具打开和分析这些文件。

分析Java堆信息的技巧

获取Java堆信息是第一步,而深入分析这些信息以获得有价值的见解则是关键。以下是一些实用的技巧:

  1. 查看堆内存占用情况:了解堆的使用量,包括已分配的空间、已使用的空间和剩余的空间。根据这些指标,您可以判断是否需要调整堆的大小或优化内存使用方式
  2. 分析对象数量和大小:通过分析堆中对象的数量和大小分布,可以确定哪些类型的对象占用了较多的内存空间。这有助于您识别内存消耗较大的部分,并进行针对性的优化
  3. 检测内存泄漏:观察堆中无法被垃圾回收器回收的对象,可以识别是否存在内存泄漏问题。通过查看对象引用链,您可以确定哪些对象导致了内存泄漏,并采取相应的措施进行修复
  4. 优化对象生命周期:合理管理对象的生命周期非常重要。及时释放不再使用的对象可以减少堆内存的占用,并改善应用程序的性能和稳定性

结论

获取和分析Java堆信息对于开发和维护Java应用程序至关重要。本文介绍了多种获取Java堆信息的方法,包括JVM工具、Java内存分析工具以及堆转储文件。同时,还提供了一些实用的技巧来帮助您深入分析堆信息,并从中获得有价值的见解。通过了解堆的使用情况、分析对象数量和大小、检测内存泄漏以及优化对象生命周期,您可以改善应用程序的性能和稳定性

Linux中如何给某个脚本赋值运行权限?

  1. 定位到脚本所在的目录:使用cd命令来定位到存放脚本的目录

  2. 赋予脚本执行权限:使用chmod +x filename命令来给脚本赋予执行权限,其中filename是脚本文件的名称

场景题:项目本地能运行,发布到Linux后运行不了,可能是什么原因?该如何解决?

  1. 环境差异:本地环境和服务器环境可能存在差异,例如Java版本、系统环境变量、依赖库等。解决方法是确保服务器环境和本地环境尽可能一致
  2. 权限问题:可能是Linux服务器上的文件权限或者防火墙设置导致的。解决方法是检查并修改相关的权限设置
  3. 依赖问题:可能是项目依赖的库在服务器上不存在或版本不匹配。解决方法是检查项目的依赖,并确保它们在服务器上正确地被安装和配置
  4. 配置问题:可能是配置文件中的路径、数据库连接信息等在服务器上不适用。解决方法是检查并修改配置文件,确保它们在服务器环境中是正确的

其中最需要注意的就是防火墙问题,大部分都是由于防火墙没有开启

什么是零拷贝技术?它有哪些使用场景?

零拷贝技术是一种优化数据传输的方法,它通过最小化数据在内存中的拷贝次数来提高数据传输的效率和性能。通常,在数据传输过程中,数据需要从一个缓冲区(如内核缓冲区)拷贝到另一个缓冲区(如用户空间缓冲区),然后再传输到目标位置。而零拷贝技术的目标是尽可能减少或消除这些拷贝操作,从而降低系统开销和提高性能。零拷贝技术的使用场景包括但不限于以下几种:

  1. 网络数据传输:在网络传输过程中,零拷贝技术可以避免数据在内核空间和用户空间之间的拷贝,从而提高网络数据传输的效率。常见的应用包括高性能网络服务器、网络流媒体服务等

  2. 文件传输:在文件传输过程中,零拷贝技术可以减少数据在文件系统缓存和用户空间缓冲区之间的拷贝次数,提高文件传输的效率。例如,在文件系统中实现零拷贝的技术可以加速文件的读取和写入操作

  3. 内存映射文件:内存映射文件是一种将文件映射到进程地址空间的技术,可以让应用程序直接操作文件而无需进行显式的读写操作。零拷贝技术可以用于内存映射文件的实现,从而提高文件的访问速度和效率

  4. 数据库系统:在数据库系统中,零拷贝技术可以用于加速数据的读取和写入操作,提高数据库的性能和吞吐量。例如,通过将数据库缓存直接映射到内存中,可以避免数据在内存和数据库之间的拷贝操作

你可能感兴趣的:(面试题,linux,运维,服务器)