0%
记录Linux的常用命令,有备无患
常用Linux操作系统
1 2 3
| RedHat(红帽):6.5、7 CentOS:6.5、7 Ubuntu:16.04、18.04
|
远程连接工具-xshell
1 2 3 4 5 6 7 8
| xshell: 安装终端模拟软件
文件-新建-输入服务器IP地址-输入用户名-输入密码-确认连接
sudo apt-get install lrzsz Windows -> Linux:rz Linux -> Windows: sz filename
|
默认已熟练使用的Linux命令
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
| 1、pwd 2、cd -- cd .. 、cd 3、ls -l -- ll 4、mkdir -p /home/tarena/a/b/c/d os os.mkdir('') os.makedirs('') 5、touch 6、tar tar -zcvf xxx.tar.gz dir1 dir2 tar -zxvf xxx.tar.gz tar -xf xxx.tar.gz tar xf xxx.tar.gz unzip xxx.zip 7、cp -- cp -r 8、mv mv dir1 /home/tarena/ mv dir1 new_dir1
|
常用命令
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65
| 1、ifconfig 查看IP地址和MAC地址 Windows中命令为:ipconfig 或者 ipconfig/all sudo apt-get install net-tools
2、ping IP/域名 [-c n] 测试网络连通性,-c指定连接次数
3、nslookup 域名 解析域名对应的IP地址
4、ls -lh file|directory 显示文件权限及详细信息,h选项提供易读容量单位 -rw-r--r-- tarena tarena 分三组: 所有者权限 所属组用户权限 其他用户权限 r - 读(4) w - 写(2) x - 可执行(1) 前3位: 所有者(tarena这个用户)rw- 中3位: 所属组其它用户(用户tarena2对文件权限)r-- 尾3位: 其它组其它用户(用户develop1对文件权限)r--
5、tar -zcvf filename.tar.gz file1 file2 directory3 将文件|目录打包并压缩 6、tar -zxvf filename.tar.gz [-C path] 解压缩,默认解压到当前路径,-C可指定路径
7、ps -aux 显示进程命令(包含PID号) ps -aux | grep 'mysql'
8、kill PID 杀死某个进程 eg: ps -aux | grep 'mysql' sudo kill PID号
9、chmod 权限 file 给文件指定或者增加某权限 chmod 777 文件名 chmod 644 文件名 rw-r--r-- chmod u+x 文件名 chmod g+w 文件名 chmod o-r 文件名 chmod a+x 文件名
10、chown user:group file 更改属主和属组 eg: chown root:root file 11、find path -name filename 在某个路径下查找文件 eg: find /home/tarena/ -name '*.avi' 12、ssh user@IP 远程连接到服务器 eg: ssh tarena@172.40.91.138 13、scp file user@IP:绝对路径 本地文件复制到远程 eg: scp python.tar.gz tarena@172.40.91.138:/home/tarena/
|
vi及vim使用
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
| 文本编辑器,vim是vi的升级版
1、vi filename 初始(不能编辑,浏览模式) -> 按 a(可编辑,插入模式) -> 编辑内容 -> 按ESC,然后shift+:(命令行模式) -> 输入wq!(保存并退出)、或q!(不保存直接退出)
1、打开一个文件,写入你最喜欢的一首诗,保存退出 2、cat 文件名
1、查找 浏览模式 -> 输入 / -> 输入查找内容 -> Enter (n表示下1个,shift+n表示上1个) 2、复制+删除+粘贴+撤销 yy:复制光标所在行(2yy复制两行内容) p:粘贴 dd:删除(剪切)光标所在行(3dd删除(剪切)3行内容) u: 撤销
行首: home 行尾: end 全文的首行:gg 全文的最后一行:G 全文的12行:12G
|
Linux命令-Go on
1 2 3 4 5 6 7 8 9 10
| wc -l eg1: wc -l /etc/passwd
sort 文件名
uniq -c sort 文件名 | uniq -c
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
| 将前面命令的输出,传递给后面命令,作为后面命令的参数 查看 /etc/passwd 文件的 第6-10行? - cat、head、tail
du -sh 目录
df -h
*:任意多个字符 ?:单个字符 eg1: rm -rf /home/tarena/test/* eg2: ls *.jpg
>:覆盖重定向 >>:追加重定向
useradd username
sudo passwd 用户名
userdel 用户名 -r:递归删除,删除用户的家目录以及用户的邮件文件
|
raid0 raid1 raid5的区别
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
| 由一系列硬盘组成的阵列,简单说:一个服务器有10个一硬盘,你如何能保证坏掉1个硬盘后数据不丢,业务不断
raid0 1、特点:数据分散存储在多个硬盘 2、优点:读写并发,速度超快,提升数倍 3、缺点:一旦一个硬盘挂掉,则损坏全部数据 raid1: 1、特点:数据分别写入两个磁盘(写了两份) 2、优点:实现了数据备份 3、缺点:磁盘使用率只能到50% raid5: 1、特点:提供热备盘实现故障恢复 2、优点:只损坏1块磁盘,数据不会损坏 3、缺点:同时坏2块磁盘,数据损坏
|
周期性计划任务
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
| crontab -e (首次进入按2 - 找vim)
* * * * * : 五个*号代表 分 时 日 月 周 0 2 * * * : 每天凌晨2点 分 :0-59 时 :0-23 日 :1-31 月 :1-12 周 :0-6
1、'*' 代表所有可能值 2、',' 指定多个时间点 0 1,5 * * * xxx 3、'/' 指定时间间隔频率 0 0-6/1 * * * xxx 4、'-' 指定一个时间段
1、每月的1日和5日两天: * * 1,5 * * 2、每10分钟: */10 * * * * 3、0点-6点每小时执行: 0 0-6/1 * * * 4、每分钟执行: * * * * *
1、每小时的第3分钟和第15分钟执行 3,15 * * * * python3 xxx.py 2、每周六、周日的0点执行一个 01.py 文件 0 0 * * 6,0 6、每天18:00到23:00之间每小时执行 01.py 文件 0 18-23/1 * * *
|
文本处理工具 - awk
语法格式
常用方式
使用方法
1 2 3 4 5 6 7 8 9 10 11 12
| awk '{print "abc"}' ip.txt
df -h | awk '{print $1}'
awk -F ":" '{print $2}'
df -h | head -4 | tail -1 | awk '{print $5}' | awk -F '%' '{print $1}'
输出本机的IP地址 ifconfig | head -2 | tail -1 | awk '{print $2}'
|
grep命令之正则表达式
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
| ^ : 以 ... 开头 $ : 以 ... 结尾 . : 任何1个字符 * : 0次或多次
+ : 1次或多次 {n} : 出现n次 () : 分组
[a-z] : 所有小写字母 [A-Z] : 所有大写字母 [a-Z] : 所有字母 [0-9] : 所有数字 [a-Z0-9] : 所有的字母和数字
|
应用场景
1 2
| ([0-9a-fA-F]{2}:){5}[0-9a-fA-F]{2}
|
使用命令必须养成的习惯
1 2 3
| 1、tab键自动补全 2、Ctrl + l : 清理屏幕 3、Ctrl + c : 终止当前命令的执行
|
常用远程连接软件
1 2 3 4 5 6 7
| 1、Xshell 2、Secure CRT
1、xshell图形界面: 新建文件传输 2、安装: lrzsz,是一款可在linux里可代替ftp上传和下载的程序
|
常见服务的端口号
1 2 3 4 5 6 7 8 9 10
| MySQL - 3306 MongoDB - 27017 Redis - 6379 redis-sentinel - 26379 SSH - 22 HTTP - 80 NGINX - 80 HTTPS - 443 TELNET - 23 FTP - 21
|
文本处理工具 - awk
语法格式
常用方式
作业
1 2 3 4 5 6 7
| 问题1: 把访问过自己的IP地址输出 cat access.log | awk '{print $1}' | sort | uniq 问题2: 统计有多少个IP访问过我 cat access.log | awk '{print $1}' | sort | uniq | wc -l 问题3: 统计每个IP地址的访问次数,输出前10个访问量最大的用户IP cat access.log | awk '{print $1}' | sort | uniq -c | sort -rnk 1 | head -10
|
grep命令之正则表达式
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
| ^ : 以 ... 开头 $ : 以 ... 结尾 . : 任何1个字符 * : 0次或多次
+ : 1次或多次 {n} : 出现n次 () : 分组
[a-z] : 所有小写字母 [A-Z] : 所有大写字母 [a-Z] : 所有字母 [0-9] : 所有数字 [a-Z0-9] : 所有的字母和数字
|
应用场景
1 2 3 4 5
|
([0-9a-fA-F]{2}:){5}[0-9a-fA-F]{2}
ifconfig | egrep "([0-9a-fA-F]{2}:){5}[0-9a-fA-F]{2}" | awk '{print $2}'
|