Day 5文件管理—三剑客的了解
文件的下载 wget curl
1.文件的上传 rz sz #不支持拷贝文件夹
文件内容进行 排序 sort ,去重uniq, 统计 文件的截取 cut awk sed .... |
3.文件管理之:联网下载文件(wget、curl)、文件上传与下载(rz、sz) ---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](http://fj.xuliangwei.com/public/weixin.py)
4.由于我们下载的是文件,所有我们可以使用cat less more 查看该 文件
[root@oldboyedu ~]# cat weixin.py
5.使用wget下载资源时,指定保存的位置,并重新命名
[root@oldboyedu ~]# wget -O /opt/tt.png [http://fj.xuliangwei.com/public/ks.jpeg](http://fj.xuliangwei.com/public/ks.jpeg)
6.下载资源时,如果不想重新命名只想修改保存的路径,请带上原有的名称
[root@oldboyedu ~]# wget -O /opt/ks.jpeg [http://fj.xuliangwei.com/public/ks.jpeg](http://fj.xuliangwei.com/public/ks.jpeg)
url----------------> curl 浏览网络上的资源
1.在线浏览网站资源内容(源代码)
[root@oldboyedu ~]# curl [http://fj.xuliangwei.com/public/weixin.py](http://fj.xuliangwei.com/public/weixin.py)
2.使用curl将内容保存至本地,并重命名(如果没有明确指定路径,则表示 当前目录)
[root@oldboyedu ~]# curl -o wei.txt [http://fj.xuliangwei.com/public/weixin.py](http://fj.xuliangwei.com/public/weixin.py) #3.将资源保存至指定的路径
[root@oldboyedu ~]# curl -o /opt/weixin.py [http://fj.xuliangwei.com/public/weixin.py](http://fj.xuliangwei.com/public/weixin.py)
PS: 通常情况下我们推荐使用wget下载,但由于系统很多时候默认没有 按照wget 会偶尔使用一下curl
rzsz上传下载文件
练习: 使用两种方式下载如下的两个文件
1.wget保存至本地 /etc/yum.repos.d/CentOS-Base.repo
[http://mirrors.aliyun.com/repo/Centos-7.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]
(http://mirrors.aliyun.com/repo/Centos-7.repo)
2.curl保存至本地 /etc/yum.repos.d/epel.repo
[http://mirrors.aliyun.com/repo/epel-7.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]
(http://mirrors.aliyun.com/repo/epel-7.repo)
3.最后执行一条命令检查 yum makecache #练习: 将阿里云的仓库源 该为 清华大学的源 https://mirrors.tuna.tsinghua.edu.cn 搜狐 网易 ===
4.文件管理之:文件或命令查找(which、whereis、find) ----------------------------------------命令查找---------------------------------------
5.文件管理之:文件内容处理命令(sort、uniq、cut、sed、awk、 wc、) ----------------------------------------sort排序--------------------------------------- #如果无法将文件直接拖拽进Linux服务器 #1.要么没有安装lrzsz ,建议安装 yum install lrzsz -y
2.你上传的是一个空文件
rz #只能上传文件,不支持上传文件夹,不支持大于4个G上传,也不 支持断点续传 # sz /path/file #只能下载文件 (任意单个文件),不支持下载文件 夹
1.查找一个命令的绝对路径 #当我们想执行一个命令的绝对路径时,先使用which command 查询绝 对路径 # which ls #查找ls命令的绝对路径
2.whereis也使用来查询命令的绝对路径 # whereis ls //查找命令的路径、帮助手册、等 # whereis -b ls //仅显示命令所在的路径
3.对于内核相关的一些命令,使用which whereis是无法查询到,需要使 用type命令查询 # type -a ls #查看命令的绝对路径(包括别名) #对于后面要使用一个命令的绝对时. 在有些情况下,需要对应一个无序的文本文件进行数据的排序,这时 就需要使用sort进行排序了。 sort [OPTION]... [FILE]... # -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 #结果并不是按照数字排序,而是按字母排序。 #可以使用-t指定分隔符, 使用-k指定需要排序的列。
[root@xuliangwei ~]# sort -t ":" -k2 sort.txt d:1 f:11 #第二行为什么是11?不应该按照顺序排列? c:2 b:3 a:4 e:5 ----------------------------------------uniq去重---------------------------------------如果文件中有多行完全相同的内容,当前是希望能删除重复的行,同 时还可以统计出完全相同的行出现的总次数, 那么就可以使用uniq命 令解决这个问题(但是必须配合sort使用)。 #按照排序的方式, 只会看到第一个字符,11的第一个字符是1, 按照字符 来排序确实比2小。 #如果想要按照数字的方式进行排序, 需要使用 -n参数。
[root@xuliangwei ~]# sort -t ":" -n -k2 p.txt d:1 c:2 b:3 a:4 e:5 f:11 #
测试案例,下载文件 [http://fj.xuliangwei.com/public/ip.txt]
(http://fj.xuliangwei.com/public/ip.txt),对该文件进行排序 [
root@xuliangwei ~]# sort -t. -k3.1,3.1nr -k4.1,4.3nr ip.txt uniq
[OPTION]... [INPUT [OUTPUT]] #选项:-c 计算重复的行 #1.创建一个file.txt文件: [root@xuliangwei ~]# cat >>file1.txt <<EOF abc 123
abc 123 EOF #2.uniq需要和sort一起使用, 先使用sort排序, 让重复内
容连续在一 起 ----------------------------------------cut截取字段(不太重
要)-------------------------------------- [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
面试题: 请统计分析如下日志,打印出访问最高前10的IP cut OPTION... [FILE]... #选项:-d 指定分隔符 -f 数字,取第几列 –f3,6三列和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 ----------------------------------------wc统计行号-------------------------------------- 习题: 分析如下日志,统计每个域名被访问的次数。
[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 是取列专业户 wc [OPTION]... [FILE]... #选项:-l显示文件行数
wc -l /etc/fstab #统计/etc/fstab文件有多少行 # wc -l /etc/services #统计/etc/services 文件行号
练习题: 过滤出/etc/passwd以nologin结尾的内容,并统计有多少行 #1.先筛选出目标的行 #2.然后进行统计 [root@oldboyedu ~]# grep "nologin$" /etc/passwd | wc l 18
扩展统计文件行号的方法
[root@oldboyedu ~]# cat -n /etc/services | tail -1
[root@oldboyedu ~]# grep -n ".*" /etc/services | tail -1
习题: 使用awk取出系统的IP地址,思路如下: 1.我要取的值在哪里 ifconfig ens32 2.如何缩小取值范围(行) 3.如何精确具体内容(列)
[root@student tmp]# cat >> web.log <<EOF
[http://www.xuliangwei.com/index.html]
(http://www.xuliangwei.com/index.html)
[http://www.xuliangwei.com/1.html]
(http://www.xuliangwei.com/1.html)
[http://post.xuliangwei.com/index.html]
(http://post.xuliangwei.com/index.html)
[http://mp3.xuliangwei.com/index.html]
(http://mp3.xuliangwei.com/index.html)
[http://www.xuliangwei.com/3.html]
(http://www.xuliangwei.com/3.html)
[http://post.xuliangwei.com/2.html](http://post.xuliangwei.com/2.html)
EOF
[root@oldboyedu ~]# cut -d "/" -f 3 web.log | sort | uniq -c | sort -nr
[root@oldboyedu ~]# awk -F "/" '{print $3}' web.log |sort |uniq -c |sort -nr
.先拿到结果,然后提取有关键字那一行,最后使用awk取出那一列
[root@oldboyedu ~]# ifconfig ens32|grep "netmask" | awk '{print $2}'
10.0.0.200 [root@oldboyedu ~]# ifconfig ens32 | awk '/netmask/' |
awk '{print $2}' 10.0.0.200 [root@oldboyedu ~]# ifconfig ens32 |
awk
'/netmask/ {print $2}' 10.0.0.200 习题:分析如下日志,请提取出访问次
数
É高的TOP10IP地址 习题: 将/etc/passwd文件中的第一行中的第一列
和É后一列位置进行 交换。 习题: 将/etc/sysconfig/selinux 文件中的
SELINUX=enforcing替换成 SELINUX=disabled
2 今日内容 文件相关 1.wget curl 下载互联网上的文件
2.rz sz 下载linux服务器上的文件,或上传文件至linux服务器
3.which whereis type 查找一个命令的绝对路径
4.cut awk 取列 grep 取行 wc 统计内容
cut+awk awk grep+awk grep+wc
Day 5文件管理—三剑客的了解的更多相关文章
- 文件管理工具“三剑客” #Everything #SpaceSniffer #Clover
前言: 本文收集了我日常使用的三个文件管理工具: 文件搜索神器--Everything 磁盘文件占用分析工具--SpaceSniffer 文件资源管理器--Clover 下面我从工具解决的痛点和使用技 ...
- 03 Linux的目录结构与常见文件管理
Linux目录结构 根文件系统rootfs用来实现整个文件的管理: 而Linux下的所有文件都需要通过根文件系统才能访问: FHS:Filesystem Hierarchy Standard文件层次化 ...
- Linux安装LAMP开发环境及配置文件管理
Linux主要分为两大系发行版,分别是RedHat和Debian,lamp环境的安装和配置也会有所不同,所以分别以CentOS 7.1和Ubuntu 14.04做为主机(L) Linux下安装软件,最 ...
- java springMVC SSM 操作日志 4级别联动 文件管理 头像编辑 shiro redis
A 调用摄像头拍照,自定义裁剪编辑头像 B 集成代码生成器 [正反双向](单表.主表.明细表.树形表,开发利器)+快速构建表单; 技术:313596790freemaker模版技术 ,0个代码不用写 ...
- BPM体系文件管理解决方案分享
一.方案概述 企业管理在很大程度上是通过文件化的形式表现出来,体系文件管理是管理体系存在的基础和证据,是规范企业管理活动和全体人员行为,达到管理目标的管理依据.对与公司质量.环境.职业健康安全等体系有 ...
- 简单的学习心得:网易云课堂Android开发第五章SharedPreferences与文件管理
一.SharedPreferences (1)SharedPreferences能够用来保存一些属于基本数据类型的数据. (2)保存数据,删除数据都是由SharedPreferences的内部接口Ed ...
- 归档NSKeyedArchiver解归档NSKeyedUnarchiver与文件管理类NSFileManager (文件操作)
========================== 文件操作 ========================== 一.归档NSKeyedArchiver 1.第一种方式:存储一种数据. // 归档 ...
- 文本处理三剑客之sed命令
第十八章.文本处理三剑客之sed命令 目录 sed介绍 sed命令常用选项 sed常用编辑命令 sed使用示例 sed高级语法 18.1.sed简介 sed全名stream editor,流编辑器,s ...
- BZOJ 3289: Mato的文件管理[莫队算法 树状数组]
3289: Mato的文件管理 Time Limit: 40 Sec Memory Limit: 128 MBSubmit: 2399 Solved: 988[Submit][Status][Di ...
随机推荐
- 部分APP无法代理抓包的原因及解决方法
引言 HTTP应用层的抓包已经成为日常工作测试与调试中的重要一环,最近接触新项目突然之间发现之前的抓包手段都不好使了,顿时模块与模块之间的前端与服务之间的交互都变成了不可见,整个人都好像被蒙住了眼睛. ...
- json模块和pickle模块
json模块和pickle模块 一.json模块 作用:用python写了一个程序,用java写了一门程序,这两个程序需要数据之间交流,就产生了一种多种语言通用的数据类型,json串. 序列化:把对象 ...
- malloc和free
1.系统使用红黑树管理空闲堆空间,malloc是申请了堆一块内存的使用权,拿到了这个钥匙,然后红黑树该块的空闲标记被去除. 2.free后,红黑树重新标记该块内存为空闲,其他程序就可以申请到此块内存. ...
- 使用okHttp登录、Md5密码加密
1.使用okHttp3登录 2.Md5密码加密 3.完整代码 4.项目案例 使用okHttp3登录: 使用okHttp3之前要在build.gradle引入okHttp3的依赖(顺便引入解析数据的gs ...
- JQuery $.ajax(); 异步访问完整参数
$.ajax 完整参数 jquery中的ajax方法参数 url: 要求为String类型的参数,(默认为当前页地址)发送请求的地址. type: 要求为String类型的参数,请求方式(post ...
- Spring Cloud Zuul的动态路由怎样做?集成Nacos实现很简单
一.说明 网关的核心概念就是路由配置和路由规则,而作为所有请求流量的入口,在实际生产环境中为了保证高可靠和高可用,是尽量要避免重启的,所以实现动态路由是非常有必要的:本文主要介绍实现的思路,并且以Na ...
- HDU 5057
题意略. 开始想开一个三维的树状数组,但是一算空间不够,正解是离线操作,按位来计算,一共是10位,所以总共是扫10遍,第i遍只处理第i位的询问, 注意在修改后,要把当前这个位的值存下来(这就是cur数 ...
- Socket(套接字)在服务器端和客户端之间的基本工作原理
Socket之间的连接过程主要可以概括为以下三步: 服务器建立监听:客户端初始化Socket动态库后创建套接字,然后指定客户端Socket的地址,循环绑定Socket直至成功,然后开始建立监听,此时客 ...
- [企业微信通知系列]Jenkins发布后自动通知
一.前言 最近使用Jenkins进行自动化部署,但是部署后,并没有相应的通知,虽然有邮件发送通知,但是发现邮件会受限于接收方的接收设置,导致不能及时看到相关的发布内容.而由于公司使用的是企业微信,因此 ...
- in和exists过程对比
两者执行流程完全不一样. in的过程 select * from tableA a where a.id in (select b.a_id from tableB b); 1)首先子查询,查询B表中 ...