抱歉,彷佛有些标题党了。最近作服务器的热备,整理了些李纳斯
工具的适用方法。看看还有不错的。linux
基本命令
- sleep 500 暂停
- ctrl + z 暂停
- progress & 后台运行
- jobs\bg\fg 查看后台任务
- file 查看文件类型
- cd - 上一个工做目录
- pwd 查看当前工做目录
- touch 建立文件或者更新文件建立时间
- rm -i 交互式删除
时间相关
- date 查看时间
- date +%Y--%m--%d 格式化显示
- date -s "20:20:16" 修改时间
- hwclock 查看硬件时钟
- cal 查看日历
- uptime 查看系统运行时间
输出查看
- echo 输出指定的字符到标准输出
- cat 输出指定文件到标准输出
- head -n 指定行数
- tail
- more 只能向下翻页
- less 上下翻页
查看硬件信息
- lspci -v 查看pci设备
- lsusb -v 查看use设备
- lsmod 查看加载的驱动
关机重启
- shutdown -h 关机
- shutdown -h +10 10分钟后关机
- shutdown -r 重启
- shutdown -r now 如今重启
- shutdown -h 20:30 20点30分关机
- poweroff 关机
- reboot 重启
归档、压缩
查找
- locate keyword 在数据库里查找
updatedb 更新数据库bash
- find . -name "aa" 查找文件名带aa的文件
- find / -name *.conf 查找conf目录
- find / -perm 777 查找文件模式为777的
find / -type d 查找文件夹服务器
find . -name "*a*" -exec cat {} \;
查找名字里带a的文件,而且cat出来,注意后面的{} ;是必须的,且中间必须有空格网络
- 查找条件
- -name
- -perm
- -user
- -group
- -ctime
- -type
- -size
常见目录及功能
- /opt 目录安装大型软件
- /proc 系统实时信息,虚拟目录
- /sbin 超级用户才能执行的命令
- /usr 通常的软件安装
- /var 常常变化的信息
BASH
VIM
:sh
到BASH环境中测试
ctrl+d
回到VIM
分区
- fdisk -l 列出硬盘信息
- fdisk /dev/sdb 进行交互式分区
- partprobe 更新一下分区表
分区机制有MBR和GPT两种
MBR 使用BIOS引导方式的PC设备,目前不支持2T以上,支持分区数量有限
分区表只有256字节信息
MBR最多只能建立4个主分区,主分区能够直接使用, 更多分区使用扩展分区和逻辑分区
一个扩展分区会占用一个主分区位置,扩展分区不能直接用
基于扩展分区建立逻辑分区
最多支持63个IDE分区,15个SCSI分区
GPT EFFI引导方式
文件系统
操做系统经过文件系统管理文件及数据,磁盘或者分区须要建立文件系统后才能被操做系统使用
- mke2fs 建立文件系统
- mke2fs -t ext4 /dev/sda3 建立文件系统类型
- -b 文件块大小,4k
- -c 创建的时候检查坏损块
- -L 创建卷标
- -j 创建文件系统日志
dumpe2fs 查看分区的文件系统信息
fsck 检查而且修复损坏的文件系统
带有日志的文件系统有较强的恢复性
挂载分区
- mount /dev/sdb1 /mnt/ 挂载到指定的位置
- mount 查看已经挂载的分区
- lsof 查看哪些文件被使用,被谁打开
- fuser -m /dev/sdb1 被谁使用
配置/etc/fstab 自动挂载
帮助信息
- ls --help
- ls -h
- man ls
- man -k 关键字查找命令
- info 更详细
用户
root 用户 0
系统用户 1-499
普通用户 500以上
相关文件
- /etc/passwd 密码
- /etc/shadow 用户密码
- /etc/group 保存组
当前用户命令
- whami 当前登陆用户
- who 哪些用户
- w 有哪些用户在干什么
用户操做
- useradd 添加用户
- usermod 修改用户
- userdel 删除用户
用户组操做
- groupadd 用户组添加
- groupmod 用户组修改
- groupdel 用户组删除
权限
限制对特定文件的读、写、执行,每个文件都有特定的权限
进程权限与运行它的用户权限相关
目录必须有x权限,不然不能查看内容
UGO: user group other
每三个一组r w x
rwxrwxrwx 三个一组
修改权限
- chown 修改拥有者
- chgrp 修改全部组
chmod 修改权限
- u\g\o表明用户、组其它
- a表明全部
- +-增长或者删除
r\w\x 三种权限
chmod g-x xxxxx 减去xxxxx的用户组执行权限
网络
32bit分为网络部分和主机部分
子网掩码用来肯定网络部分的位数
- ifconfig -a 查看全部接口
ifconfig eth0 查看特定接口
- ifup eth0 启用接口
ifdown eth0 禁用接口
setup 配置网络信息
网络排查相关命令
- host 查看域名对应ip
- dig 查看域名信息
- ip route 查看路由表
- traceroute 查看到达目标地址通过的路由
- mtr 网络质量测试
管道和重定向
- STDIN 0
- STDOUT 1
- STDERR 2
> STDOUT 重定向到文件【覆盖】
>> STDOUT 重定向到文件,追加
2> STDERR 重定向到文件
2>&1 STDERR与STDOUT结合
< 重定向到STDIN
| 一个命令的STDOUT做为另外一个命令的STDIN
2>/dev/null 把错误重定向到null设备
安装删除包
- rpm -i xxx.rpm 安装
- rpm -e xxxx 卸载
- rpm -U xxx 升级
- rpm -ivh http://xxxx 网络安装
- rpm -qa 安装的列表
rpm -ql xxx 安装的东西
- yum search
- yum list (all | installed | updates)
yum info packagename
文本处理工具
- grep
- -i 忽略大小写
- -n 显示行数
- -v 不带关键字的行
- -Ax 以后的x行
- -Cx 以前以后的x行
- -Bx 以前的x行
- cut
- -d 切分符号
- -f 显示的列
- -c 基于字符进行切割
cut -d: -f1 xxx 对xx文件进行
cut -c2-6 xxx 基于2到6进行切割
- wc
- -l 只计行数
- -w 只讲单词
- -m 字符
- -c 只计字节数
- sort 排序
- -r 倒序
- -u 删除重复行
- -tc 使用c进行分割为列进行排序
uniq 删除重复相邻行
- diff 比较文件
aspell 拼写检查
实际例子
tr -d 'apple' < hosts 删除hosts文件里的apple
tr 'a-z''A-Z' < hosts 大小写转换
sed 's/str/newstr/g' hosts 替换hosts中的str
sed '1,50s/str/newstr/g' hosts 只替换1到50行
sed -e 's/linux/unix/g' -e 's/xxx/xsdjlfsjdf' hosts 连续处理两个替换
sed -f command hosts 把替换的命令放到command文件里
ps aux | grep xxx 查看某个进程
lsof -i:portnum 查看端口被哪一个进程占用
kill -9 pid 杀掉某个进程
killall program 杀掉指定名称的全部进程