一、基础知识
1.1 Linux系统命令行的含义
示例:dev@DESKTOP-GD47KA1:~$
dev:用户名,如果是root表示超级用户
@:分隔符
DESKTOP-GD47KA1:主机名称
~:当前所在目录,默认用户目录为~,会随着目录切换而变化
$:表示当前用户是普通用户,如果是#,表示当前是超级用户
dev@DESKTOP-GD47KA1:/mnt$
表示用户"dev"访问/mnt目录
1.2 Linux系统的文件结构
/bin 二进制文件,系统常规命令 /boot 系统启动分区,系统启动时读取的文件 /dev 设备文件 /etc 大多数配置文件 /home 普通用户的家目录 /lib 32位函数库 /lib64 64位库 /media 手动临时挂载点 /mnt 手动临时挂载点 /opt 第三方软件安装位置 /proc 进程信息及硬件信息 /root 临时设备的默认挂载点 /sbin 系统管理命令 /srv 数据 /var 数据 /sys 内核相关信息 /tmp 临时文件 /usr 用户相关设定
1.3 Linux系统命令的组成
示例:命令 参数名 参数值
二、基础操作
2.1 立刻关机
(1) 立刻关机
shutdown -h now 或者 poweroff
(2) 两分钟后关机
shutdown -h 2
2.2 重启系统
(1) 立刻重启
shutdown -r now 或者 reboot
(2) 两分钟后重启
shutdown -r 2
2.3 帮助命令(help)
ifconfig --help // 查看 ifconfig 命令的用法
2.4 命令说明书(man)
man shutdown // 打开命令说明后,可按"q"键退出
2.5 切换用户
su dev // 切换为用户"dev",输入后回车需要输入该用户密码 exit // 退出当前用户
三、目录操作
3.1 切换目录(cd)
cd / // 切换到根目录 cd ../ // 切换到上一级目录 cd ../xx/ // 切换到根目录下的bin目录 cd ~ // 切换到home目录 cd - // 切换到上次访问的目录 cd xx // 切换到本目录下名为xx的目录,如果目录不存在报错 cd /xx/xx/x // 输入完整的路径直接切换到目标目录,输入过程中可以使用tab键快速补全
3.2 查看目录(ls)
ls // 查看当前目录下的所有目录和文件 ls -a // 查看当前目录下所有目录和文件(包括隐藏文件) ls -l // 列表查看当前目录下的所有目录和文件(列表查看,显示更多信息),与命令"ll"效果一样 ls /bin // 查看指定目录下的所有目录和文件
3.3 创建目录(mkdir)
mkdir tools // 在当前目录下创建一个名为tools的目录 mkdir /bin/tools // 在指定目录下创建一个名为tools的目录
3.4 删除目录与文件(rm)
rm 文件名 // 删除当前目录下的文件 rm -f 文件名 // 删除当前目录的的文件(不询问) rm -r 目录名 // 递归删除当前目录下此名的目录 rm -rf 目录名 // 递归删除当前目录下此名的目录(不询问) rm -rf * // 将当前目录下的所有目录和文件全部删除
3.5 修改目录(mv)
mv 当前目录名 新目录名 // 修改目录名,同样适用文件操作 mv /usr/tmp/tool /opt // 将/usr/tmp目录下的tool目录剪切到 /opt目录下面 mv -r /usr/tmp/tool /opt // 递归剪切目录中所有文件 和文件夹
3.6 拷贝目录(cp)
cp /usr/tmp/tool /opt // 将/usr/tmp目录下的tool 目录复制到/opt目录下面 cp -r /usr/tmp/tool /opt // 递归复制目录中所有文件和文件夹
3.7 搜索目录(cp)
find /bin -name 'a*' // 查找/bin目录下所有以a开头的文件或目录
3.8 查看当前目录(pwd)
pwd // 显示当前位置路径
四、文件操作
4.1 新建文件(touch)
touch 1.txt // 在当前目录下创建名为1的txt文件,如果文件 存在,将时间属性修改为当前系统时间
4.2 删除文件(rm)
rm 文件名 // 删除当前目录下的这个文件 rm -f 文件名 // 删除当前目录下的这个文件(不询问)
4.3 编辑文件(vi、vim)
vi 文件名 // 打开需要编辑的文件 vim 文件名 // 打开需要编辑的文件
进入后,操作界面有三种模式:
命令模式(command mode)
1. 刚进入文件就是命令模式,通过方向键控制光标位置, 2. 使用命令"dd"删除当前整行 3. 使用命令"/字段"进行查找 4. 按"i"在光标所在字符前开始插入 5. 按"a"在光标所在字符后开始插入 6. 按"o"在光标所在行的下面另起一新行插入 7. 按":"进入底行模式
插入模式(Insert mode)
3. 此时可以对文件内容进行编辑,左下角会显示 "-- 插入 --"" 2. 按"ESC"进入底行模式
底行模式(last line mode)
1. 退出编辑:q 2. 强制退出:q! 3. 保存并退出:wq
具体操作步骤:
1. 保存文件:按"ESC" -> 输入":" -> 输入"wq",回车 // 保存并退出编辑 2. 取消操作:按"ESC" -> 输入":" -> 输入"q!",回车 // 撤销本次修改并退出编辑
补充 :
vim +10 filename.txt // 打开文件并跳到第10行 vim -R /etc/passwd // 以只读模式打开文件
4.4 查看文件
cat a.txt // 查看文件最后一屏内容 less a.txt // PgUp向上翻页,PgDn向下翻页,"q"退出 查看 more a.txt // 显示百分比,回车查看下一行,空格查看 下一页,"q"退出查看 tail -100 a.txt // 查看文件的后100行,"Ctrl+C"退出查看
五、文件权限
5.1 权限说明
文件权限简介:'r' 代表可读, 'w' 代表可写, 'x' 代表可执行 "8421法",r = 4,w = 2,x = 1,rwx = 0111 = 7
文件权限信息示例:-rwxrwxrwx
第一位:'-' 代表是文件,'d' 表是目录 第一组rwx:拥有者的权限 第二组rwx:拥有者所在的组,组员的权限 第三组rwx:代表的是其他用户的权限
5.2 文件权限
chmod 777 a.txt // 777即代表三组rwx,7
六、打包压缩与解压
6.1 后缀说明
.zip、.rar // windows系统中压缩文件的扩展名 .tar // Linux中打包文件的扩展名 .gz // Linux中压缩文件的扩展名 .tar.gz // Linux中打包并压缩文件的扩展名
6.2 打包文件
tar -zcvf 打包压缩后的文件名 要打包的文件名
参数说明:
z:调用gzip压缩命令进行压缩
c:打包文件
v:显示运行过程
f:指定文件名 示例:
tar -zcvf 1.tar file1 // 将file1文件打包成名为1.tar的压缩文件 tar -zcvf 1.tar file1 file2 ... // 多个文件压缩打包
6.3 解压文件
tar -zxvf 1.tar // 解压至当前目录 tar -zxvf 1.tar -C /usr // 指定解压的位置/user unzip 1.zip // 解压1.zip文件 unzip -l 1.zip // 查看1.zip文件的内容
七、其它常用命令
7.1 find
find . -name "*.c" // 将目前目录及其子目录所有后缀为.c的文件列出来 find . -type f // 将目前目录其其下子目录中所有一半文件列出来 find . -ctime -20 // 将目前目录及其子目录下所有最近20 天内更新过的文件列出来 find /var/log -type f -mtime +7 -ok rm {} \ // 查找/var/log目录中更改时间在7日以前的普通文件,并删除之前询问它们 find / -type f -size 0 -exec ls -l {} \ // 为了查找系统中所有文件长度为0的普通文件,并列出它们的完整路径 find . -type f -perm 644 -exec ls -l {} \ // 查找前目录中文件属主具有读、写权限,并且文件所属组的用户和其他用户具有读权限的文件
7.2 whereis
whereis ls // 将和ls文件相关的文件都查找出来
7.3 which
说明:which指令会在环境变量$PATH设置的目录里查找符合条件的文件。
which bash // 查看指令"bash"的绝对路径
7.4 sudo
说明:sudo是表示超级用户,sudo命令以系统管理者的身份执行指令,需要输入自己账户密码。
sudo vim 1.txt // 使用超级用户的身份编辑1.txt文件
7.5 grep
grep -i "the" demo_file // 在文件中查找字符串(不区分大小写) grep -A 3 -i "example" demo_text // 输出成功匹配的行,以及该行之后的三行 grep -r "ramesh" * // 在一个文件夹中递归查询包含指定字符串的文件
7.6 service
说明:service命令用于运行System V init脚本,这些脚本一般位于/etc/init.d文件下,这个命令可以直接运行这个文件夹里面的脚本,而不用加上路径。
service ssh status // 查看服务状态 service --status-all // 查看所有服务状态 service ssh restart // 重启服务
7.7 free
说明:这个命令用于显示系统当前内存的使用情况,包括已用内存、可用内存和交换内存的情况。
free -g // 以G为单位输出内存的使用量,-g为GB,-m为MB,-k为KB,-b为字节 free -t // 查看所有内存的汇总
7.8 top
top // 显示当前系统中占用资源最多的一些进程, shift+m按照内存大小查看
7.9 df
说明:显示文件系统的磁盘使用情况
df -h // 一种易看的显示
7.10 mount
mount /dev/sdb1 /u01 // 挂载一个文件系统,需要先创建一个目录,然后将这个文件系 统挂载到这个目录上 dev/sdb1 /u01 ext2 defaults 0 2 // 添加到fstab中进行自动挂载,这样任何时候系统重启的时 候,文件系统都会被加载
7.11 uname
说明:uname可以显示一些重要的系统信息,例如内核名称、主机名、内核版本号、处理器类型之类的信息。
uname -a
7.12 yum
说明:安装插件命令。
yum install httpd // 使用yum安装apache yum update httpd // 更新apache yum remove httpd // 卸载/删除apache
7.13 rpm
说明:插件安装命令。
rpm -ivh httpd-2.2.3-22.0.1.el5.i386.rpm //使用rpm文件安装apache rpm -uvh httpd-2.2.3-22.0.1.el5.i386.rpm // 使用rpm更新apache rpm -ev httpd // 卸载/删除apache
7.14 date
date -s "01/31/2010 23:59:53" // 设置系统时间
7.15 wget
说明:使用wget从网上下载软件、音乐、视频。
wget http://download.redis.io/releases/redis-3.2.10.tar.gz // wget命令下载redis-3.2.10.tar.gz wget -O redis.tar.gz http://download.redis.io/releases/redis-3.2.10.tar.gz // wget命令下载redis-3.2.10.tar.gz并命名为redis.tar.gz
7.16 ftp
ftp IP/hostname // 访问ftp服务器 mls *.html - // 显示远程主机上文件列表
7.17 scp
scp /opt/1.txt 192.168.1.66:/opt/ // 将本地opt目录下的1.txt文件发送到192.168.1.66服务器的opt目录下
八、系统管理
8.1 防火墙操作
service iptables status // 查看iptables服务的状态 service iptables start // 开启iptables服务 service iptables stop // 停止iptables服务 service iptables restart // 重启iptables服务 chkconfig iptables off // 关闭iptables服务的开机自启动 chkconfig iptables on // 开启iptables服务的开机自启动
8.2 查看网络
ifconfig
8.3 修改IP
修改网络配置文件,文件地址:/etc/sysconfig/network-scripts/ifcfg-eth0
主要修改以下配置:
TYPE=Ethernet // 网络类型 BOOTPROTO=static // 静态IP DEVICE=ens00 // 网卡名 IPADDR=192.168.1.100 // 设置的IP NETMASK=255.255.255.0 // 子网掩码 GATEWAY=192.168.1.1 // 网关 DNS1=192.168.1.1 // DNS DNS2=8.8.8.8 // 备用DNS ONBOOT=yes // 系统启动时启动此设置
修改保存以后使用命令重启网卡:service network restart
8.4 配置映射
修改文件:vi /etc/hosts 在文件最后添加映射地址,示例如下:
192.168.1.66 ip1 192.168.1.67 ip2 192.168.1.68 ip3
配置好保存退出,输入命令:ping ip1可见实际ping的是 192.168.1.101。
8.5 查看进程
ps -ef // 查看所有正在运行的进程
8.6 结束进程
kill pid // 杀死该pid的进程 kill -9 pid // 制杀死该进程
8.7 查看链接
ping IP // 查看与此IP地址的连接情况 netstat -an // 查看当前系统端口 netstat -an | grep 8080 // 查看指定端口
8.8 快速清屏
ctrl+l // 清屏,往上翻可以查看历史操作
8.9 远程主机
ssh IP // 远程主机,需要输入用户名和密码
分享是一种积极的生活态度