Linux文件管理②

1.文件管理之:wget、curl; rz、sz 1.wget命令
1.CentOS7 系统最小化安装默认没有wget命令,需要进行安装
[root@chengyinwu ~]# yum install wget -y
2.找到我们需要下载的资源
复制资源的链接地址---->
3.在linux上使用wget命令进行下载(默认下载到当前目录来)

[root@chengyinwu ~]# wget http://fj.yinwucheng.com/public/weixin.py

【Linux文件管理②】4.由于我们下载的是文件,所有我们可以使用cat less more 查看该文件
[root@chengyinwu ~]# cat weixin.py
5.使用wget下载资源时,指定保存的位置,并重新命名
[root@chengyinwu ~]# wget -O /opt/tt.png http://fj.chengyinwu.com/public/ks.jpeg

6.下载资源时,如果不想重新命名只想修改保存的路径,请带上原有的名称
[root@chengyinwu ~]# wget -O /opt/ks.jpeg http://fj.chengyinwu.com/public/ks.jpeg

2.curl 浏览网络上的资源
1.在线浏览网站资源内容(源代码)
[root@chengyinwu ~]# curl http://fj.chengyinwu.com/public/weixin.py

2.使用curl将内容保存至本地,并重命名(如果没有明确指定路径,则表示当前目录)
[root@chengyinwu ~]# curl -o wei.txt http://fj.chengyinwu.com/public/weixin.py

3.将资源保存至指定的路径
[root@chengyinwu ~]# curl -o /opt/weixin.py http://fj.chengyinwu.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@chengyinwu ~]# wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo

2.curl保存至本地 /etc/yum.repos.d/epel.repohttp://mirrors.aliyun.com/repo/epel-7.repo
[root@chengyinwu ~]# curl -o /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo

3.最后执行一条命令检查 yum makecache
###**如果无法将文件直接拖拽进Linux服务器** 1.要么没有安装lrzsz ,建议安装yum install lrzsz -y 2.你上传的是一个空文件 注意:rz只能上传文件,不支持上传文件夹,不支持大于4个G上传,也不支持断点续传 sz /path/file只能下载文件 (任意单个文件),不支持下载文件夹

2.文件或命令查找(which、whereis、find)
1.查找一个命令的绝对路径
当我们想执行一个命令的绝对路径时,先使用which command 查询绝对路径
which ls 查找ls命令的绝对路径
2.whereis也使用来查询命令的绝对路径
whereis ls 查找命令的路径、帮助手册、等
whereis -b ls //仅显示命令所在的路径
3.对于内核相关的一些命令,使用which whereis是无法查询到,需要使用type命令查询
type -a ls #查看命令的绝对路径(包括别名)
3.文件内容处理命令(sort、uniq、cut、sed、awk、wc、) 1.在有些情况下,需要对应一个无序的文本文件进行数据的排序,这时就需要使用sort进行排序了。
sort [OPTION]... [FILE]...
-r:倒序 -n:按数字排序 -t:指定分隔符(默认空格) -k:指定第几列, 指定几列几字符(指定1,1 3.1,3.3)
1.首先创建一个文件,写入一写无序的内容 [root@chengyinwu ~]# cat >> file.txt <

2.如果文件中有多行完全相同的内容,当前是希望能删除重复的行,同时还可以统计出完全相同的行出现的总次数, 那么就可以使用uniq命令解决这个问题(但是必须配合sort使用)
uniq [OPTION]... [INPUT [OUTPUT]] 选项:-c 计算重复的行 1.创建一个file.txt文件: [root@chengyinwu ~]# cat >>file1.txt <

3.cut命令截取字段
cut OPTION... [FILE]... 选项:-d 指定分隔符 -f 数字,取第几列 –f3,6三列和6列 -c 按字符取(空格也算) [root@chengyinwu ~]# cat >>file2.txt <

4.wc统计行号
wc [OPTION]... [FILE]... 选项:-l显示文件行数 wc -l /etc/fstab#统计/etc/fstab文件有多少行 wc -l /etc/services#统计/etc/services 文件行号实践: 过滤出/etc/passwd以nologin结尾的内容,并统计有多少行 1.先筛选出目标的行 2.然后进行统计 [root@chengyinwu ~]# grep "nologin$" /etc/passwd | wc -l 18扩展统计文件行号的方法 [root@chengyinwu ~]# cat -n /etc/services | tail -1 [root@chengyinwu ~]# grep -n ".*" /etc/services | tail -1实践: 分析如下日志,统计每个域名被访问的次数。 [root@student tmp]# cat >> web.log <>实践: 使用awk取出系统的IP地址,思路如下: 1.我要取的值在哪里 ifconfig ens32 2.如何缩小取值范围(行) 3.如何精确具体内容(列) 先拿到结果,然后提取有关键字那一行,最后使用awk取出那一列[root@chengyinwu ~]# ifconfig ens32|grep "netmask" | awk '{print $2}' 10.0.0.200[root@chengyinwu ~]# ifconfig ens32 | awk '/netmask/' | awk '{print $2}' 10.0.0.200[root@chengyinwu ~]# ifconfig ens32 | awk '/netmask/ {print $2}' 10.0.0.200

    推荐阅读