1.文件下载 wget curl
1. Centos7 系统最小化安装默认没有 wget 命令,需要安装
[root@oldboyedu ~]# yum install wget -y
2.找到我们需要下载的资源
3.在 linux 上使用 wget 命令进行下载(默认下载到当前目录)
[root@oldboyedu ~]# wget http://fj.xuliangwei.com/public/weixin.py
4.由于我们下载的是文件,所以我们可以使用 cat less more 查看该文件
[root@oldboyedu ~]# cat weixin.p
5.使用 wget 下载资源时,指定保存的位置,并重新命名
[root@oldboyedu ~]# wget -O /opt/tt.png http://fj.xuliangwei.com/public/ks.jpeg
6.下载资源时,如果不想重新命名 只想修改保存的路径,请带上原有的名称
[root@oldboyedu ~]# wget -O /opt/ks.jpeg http://fj.xuliangwei.com/public/ks.jpeg
2. curl 预览网络上的资源
1.在线预览网站资源内容(源代码)
[root@oldboyedu ~]# curl http://fj.xuliangwei.com/public/weixin.py
2.使用 curl 将内容保存至本地,并重新命名(如果没有表示明确指定路径,则表示当前目录)
[root@oldboyedu ~]# curl -o wei.txt http://fj.xuliangwei.com/public/weixin.py
3.将资源保存至指推荐使用 wget定的路径
[root@oldboyedu ~]# curl -o /opt/weixin.py http://fj.xuliangwei.com/public/weixin.py
PS:通常情况下 我们推荐使用 wget 下载,但由于系统很多时候没有 wget 会偶尔使用以下 curl
#练习: 使用两种方式下载如下的两个文件
#1.wget保存至本地 /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
[root@oldboyedu ~]# wget -O /etc/yum.repos.d/CentOSBase.repo http://mirrors.aliyun.com/repo/Centos-7.repo
#2.curl保存至本地 /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo
[root@oldboyedu ~]# curl -o /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo
#3.最后执行一条命令检查 yum makecache
3. rz sz 上传下载文件
如果无法将文件直接拖拽进 linux 服务器
1.要么没有安装 lrzsz ,建议安装 yum install lrzsz -y
2.你上传的是一个空文件
# rz 只能上传文件,不支持上传文件夹不支持大于 4个G 上传,也不支持断点续传
# sz /path/file #只能下载文件 (任意单个文件)不支持,不支持下载文件夹
4.命令查找
1.查找一个命令的绝对路径
# 当我们想执行一个命令的绝对路径时,先使用 which command 查找据对路径
2. whereis 也使用来查询命令的绝对路径
# whereis ls 查找命令的路径,帮助手册 等
# whereis -b ls 仅显示命令所在的路径
3. 对于内核相关的一些命令,使用 which whereis 是无法查询到,需要使用 type 命令查询
# type -a ls 查看命令的绝对路径(包括 别名)
5. 排序 sort
# sort -r 倒序 , -n 按数字排序 ,-t 指定分隔符(默认空格) ,-k 指定第几列,指定几列几字符 (指定 1,1 3.1,3.3)
1. 首先创建一个文件,写入一些无序的内容
[root@xuliangwei ~]# cat >> file.txt <<EOF
b:3
c:2
a:4
e:5
d:1
f:11
EOF
2.使用 sort 下面对输出的内容进行排序
[root@xuliangwei ~]# sort file.txt
a:4
b:3
c:2
d:1
e:5
f:11
3.结果并不是按照数字排序,而是按字母排序。
# 可以使用 -t 指定分隔符,使用 -k 指定需要排序的列
[root@xuliangwei ~]# sort -t ":" -k2 sort.txt
d:1
f:11 #第二行为什么是11?不应该按照顺序排列?
c:2
b:3
a:4
e:5
4. # 按照排序的方式,只会看到第一个字符,11 的第一个字符是 1 ,安装字符来排序确实比 2 小。
如果想要按照数字的方式进行排序,需要使用 -n 参数
[root@xuliangwei ~]# sort -t ":" -n -k2 p.txt
d:1
c:2
b:3
a:4
e:5
f:11
6.去重 uniq
# 如果文件中有多行完全相同的内容,当前是希望能删除重复的行,同时还可以统计出完全相同的行出现的总次数,那么就可以使用 uniq 命令解决这个问题(但是必须配合 sort 使用)
# 选项:-c 计算重复的行
1.创建一个 file.txt 文件:
[root@xuliangwei ~]# cat >>file1.txt <<EOF
abc
123
abc
123
EOF
2. uniq 需要和 sort 一起使用,先使用 sort 排序,让重复内容连续在一起
[root@xuliangwei ~]# sort file.txt
123
123
abc
abc
3.使用 uniq 去除相邻重复的行
[root@xuliangwei ~]# sort file.txt |uniq
123
abc
4.-c 参数能统计出文件中每行内容重复的次数
[root@xuliangwei ~]# sort file.txt |uniq -c
2 123
2 abc
7. cut 截取字段(不太重要)
cut -d 指定分隔符, -f 数字 ,取第几列 -f 3,6 三列和六列 -c 按字符取(空格也算)
[root@oldboyedu ~]# cat >>file2.txt <<EOF
Im xlw, is QQ 552408925
EOF
#实现: 筛选出文件里 xlw以及552408925
[root@oldboyedu ~]# awk '{print $2,$5}' file2.txt | awk -F ","
'{print $1,$2}'
xlw 552408925
[root@oldboyedu ~]# cut -d " " -f 2,5 file2.txt | awk -F "," '{print $1,$2}'
xlw 552408925
[root@oldboyedu ~]# cut -d " " -f 2,5 file2.txt | sed 's#,##g'
xlw 552408925
[root@oldboyedu ~]# sed 's#,##g' file2.txt | awk '{print $2,$5}'
xlw 552408925
# PS:实际生产使用过程中,很少使用到 cut ,通常都是使用 awk 因为 awk 是去列专业户
8. wc 统计行号
1. wc -l 显示文件行数
# wc -l /etc/fstab #统计/etc/fstab文件有多少行
# wc -l /etc/services #统计/etc/services 文件行号
思路如下:
1.我要取的值在哪里 ifconfig ens32
2.如何缩小取值范围(行)
3.如何精确具体内容(列)