前言
现在行业对于测试工程师的要求越来越高,除了要会自动化测试,会数据库操作,现在对于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 系统安全的重要步骤。防火墙能够限制对系统的访问,更新系统补丁可以修复已知漏洞,而密码策略则可以防止密码被轻易破解。示例代码如下,使用防火墙配置规则,更新系统补丁和执行密码策略:
代码语言:shell复制sudo ufw allow ssh
sudo apt-get upgrade
sudo passwd username
SSH
SSH 是一种加密网络协议,用于在不安全的网络中安全地运行网络服务。通过使用 SSH,用户可以安全地远程登录和执行命令,防止数据在传输过程中被窃取或篡改。示例代码如下,使用 SSH 远程连接服务器并执行命令:
代码语言:shell复制ssh username@hostname
用户访问限制
iptables
可以用于配置 Linux 内置防火墙规则,限制特定 IP 或 IP 范围的访问。这种限制有助于加强系统的安全性。示例代码如下,使用 iptables
限制特定 IP 地址的访问:
sudo iptables -A INPUT -s 192.168.1.100 -j DROP
总结
本文主要介绍了面试经常会问到的Linux
问题,对于测试来说,并不需要对Linux
烂熟于胸,但是对于我们部署测试环境以及在docker
等容器中经常使用到的命令,我们必须要学习掌握,希望本文能够帮到大家!