软件测试/人工智能|Linux常见面试问题讲解
  X7HGjGJ7MG9G 2023年12月23日 13 0

软件测试/人工智能|Linux常见面试问题讲解_IP

前言

现在行业对于测试工程师的要求越来越高,除了要会自动化测试,会数据库操作,现在对于linux命令的要求也越来越高了,因为很多时候,测试环境以及持续集成持续交付需要用到越来越多的Linux命令,本文就来给大家介绍一下面试常见的Linux问题以及基本概念。

基础概念

Linux的起源和特点

Linux 是一个开源的类 Unix 操作系统,最初由 Linus Torvalds 于 1991 年创建。其特点包括稳定性、安全性和灵活性,可运行于各种设备和架构上,是许多服务器和嵌入式系统的首选。

Linux和Unix的区别

虽然 Linux 受到了 Unix 的启发,但它们并不完全相同。Unix是一系列商业操作系统的总称,而Linux是一种开源操作系统。Linux有很多发行版(例如 Ubuntu、CentOS、Debian 等),而Unix则由多个版本,如 Solaris、AIX 和 HP-UX。

Linux文件系统结构

Linux文件系统遵循树状结构,根目录/包含了众多子目录和文件。常见目录包括 /bin 存放二进制可执行文件、/etc 包含系统配置文件、/home 存放用户主目录、/var 包含可变数据文件等。

命令行操作

文件和目录操作命令

ls 用于列出目录内容,cd 用于改变目录,mkdir 用于创建目录,cp 用于复制文件或目录,mv 用于移动文件或目录,rm 用于删除文件或目录等。这些命令还可以结合参数使用,如-r用于递归操作。示例代码如下,使用 ls 命令列出当前目录下的文件和目录,mkdir 创建一个新目录,cp 复制文件,rm 删除文件:

ls
mkdir new_directory
cd new_directory
cp file1.txt file2.txt
rm file2.txt

查找文件命令

find 用于按条件查找文件,而grep用于在文件中搜索指定模式的文本。find可以根据文件名、类型、大小等条件搜索文件,而grep可以在文件中查找匹配的文本。示例代码如下,使用 find 查找文件和目录,使用 grep 在文件中搜索特定内容:

find /home -name "*.txt"
grep "keyword" file.txt

查看文件内容

cat 用于连接文件并打印到标准输出,less 用于分页显示文件内容,tail 用于查看文件尾部内容,可实时输出新添加的内容。示例代码如下,使用 cat 显示文件内容,使用 less 逐页查看大文件,使用 tail 查看文件尾部内容:

cat file.txt
less large_file.log
tail -n 10 file.txt

系统管理

进程管理

ps 用于列出系统进程信息,top 用于实时显示系统进程状况,kill 用于终止进程。通过这些命令,可以查看进程详细信息并根据需要终止特定进程。示例代码如下,使用 ps 列出当前系统的进程信息,使用 kill 终止特定进程:

ps aux
kill PID
top

用户和权限管理

adduser 用于添加新用户,usermod 用于修改用户属性,chmod 用于修改文件或目录权限。Linux系统通过权限机制保护文件和目录的安全,合适的权限设置是确保系统安全的重要一环。示例代码如下,使用 adduser 添加新用户,使用 chmod 更改文件权限:

adduser new_user
chmod 755 file.txt

软件包管理

apt(Debian/Ubuntu)和yum(Red Hat/CentOS)是常用的包管理器,用于安装、更新和删除软件包。这些工具简化了软件的管理和安装流程。示例代码如下,使用 apt 安装软件包,使用 apt-get update 更新软件包列表。

sudo apt-get install package_name
sudo apt-get update

网络配置

查看网络配置信息

ifconfig(较旧的命令)和ip(较新的命令)都可以用于查看和配置网络接口信息,包括 IP 地址、子网掩码、网关等。示例代码如下, 使用 ifconfig 查看网络接口信息,使用 ip addr 查看 IP 地址信息:

ifconfig
ip addr show

网络故障排除

ping 用于测试主机之间的连通性,traceroute 用于跟踪数据包的路径,netstat 用于显示网络连接、路由表等信息。这些命令是排除网络问题的有力工具。示例代码如下,使用 ping 测试网络连通性,使用 netstat 查看网络连接状态:

ping google.com
netstat -tuln

安全

Linux系统安全措施

防火墙配置、定期更新系统补丁、密码策略的实施等都是确保 Linux 系统安全的重要步骤。防火墙能够限制对系统的访问,更新系统补丁可以修复已知漏洞,而密码策略则可以防止密码被轻易破解。示例代码如下,使用防火墙配置规则,更新系统补丁和执行密码策略:

sudo ufw allow ssh
sudo apt-get upgrade
sudo passwd username

SSH

SSH 是一种加密网络协议,用于在不安全的网络中安全地运行网络服务。通过使用 SSH,用户可以安全地远程登录和执行命令,防止数据在传输过程中被窃取或篡改。示例代码如下,使用 SSH 远程连接服务器并执行命令:

ssh username@hostname

用户访问限制

iptables 可以用于配置 Linux 内置防火墙规则,限制特定 IP 或 IP 范围的访问。这种限制有助于加强系统的安全性。示例代码如下,使用 iptables 限制特定 IP 地址的访问:

sudo iptables -A INPUT -s 192.168.1.100 -j DROP

总结

本文主要介绍了面试经常会问到的Linux问题,对于测试来说,并不需要对Linux烂熟于胸,但是对于我们部署测试环境以及在docker等容器中经常使用到的命令,我们必须要学习掌握,希望本文能够帮到大家!

【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2023年12月23日 0

暂无评论

推荐阅读
X7HGjGJ7MG9G