linux写入命令

人气:484 ℃/2022-11-29 19:20:40

linux系统下写入命令是什么呢?下面是具体介绍:

linux系统下写入命令是:echo命令。

1、echo命令的主要作用功能是在屏幕上显示文字,也可以直接在文件中写入要写的内容。

2、常用选项:

echo命令经常使用到的选项有两个。

一个是-n,表示输出之后不换行。

另一个是-e,表示对于转义字符按对应的方式进行处理,假设不加-e,那么在输出时转义字符会按照普通字符进行处理,并不会达到自己想要达到的目的。转义字符是指,用一些普通字符的组合来代替一些特殊字符,由于其组合改变了原来字符所表示的含义,因此称为转义字符。

3、echo输出时的转义字符:

\b 表示删除前面的空格

\n 表示换行

\t 表示水平制表符

\v 表示垂直制表符

\c \c后面的字符将不会输出,同一时候,输出完毕后也不会换行

\r 输出回车符

\a 表示输出一个警告的声音

4、ehco的重定向:

命令:

echo “想要的内容”> 文件名

echo “想要的内容”>> 文件名

第一个的定向是将想要的内容覆盖到对应的文件当中去,文件当中之前的内容不复存在了,也就是说修改了原文件的内容,而第二个是将想要的内容追加到文件后,对文件之前的内容不修改,只进行增添,也叫追加重定向。

以上就是小编今天的分享了,希望可以帮助到大家。

linux中写入文件的命令

Linux查看日志文件写入速度的4种方法

原创:扣钉日记(微信公众号ID:codelogs),欢迎分享,转载请保留出处。

简介

有时,我们需要查看某个文件的增长速度,如日志文件,以此来感受系统的负载情况,因为一般情况下,日志写入越快,说明系统负载越重。

本文就来介绍下Linux中查看日志增长速度的几种方法,如下:

使用dd

首先要介绍的是dd,因为dd命令几乎所有主流发行版都自带,无需额外安装,如下:

$ tail -F app.log | dd of=/dev/null status=progress3875840 bytes (3.9 MB) copied, 8.228797 s, 471 kB/s

如上,使用tail -F获取新写入的数据,然后用管道将数据交给dd,dd将数据拷贝到/dev/null,其中status=progress是用来显示拷贝速度的,可见,我们日志的写入速度是471 kB/s。

使用pv

pv命令可以看做是带进度的cp,如下:

$ yum install -y pv$ tail -F app.log | pv >/dev/null2.05MiB 0:00:03 [ 330kiB/s] [ <=> ]

原理与dd类似,不过命令换成了pv。

使用cv命令

由于日志数据都是程序(如java)写入的,而在如下的伪文件中,存放着程序打开的文件信息,如下:

于是定期的读取这个offset就可以知道文件的写入速度了,这也是cv命令的实现原理,如下:

$ yum install -y cv$ cv -mc java[ 1] java app.log 100.0% (6.1 GiB / 6.1 GiB) 390.2 KiB/s# 实际上,由于Linux上大多数命令(如cp)没自带进度查看功能,而cv就成了很好的补充# 比如查看cp复制文件的进度$ cp app.log app.log.bak & cv -mc cp

新版cv命令已经改名为progress,安装不到cv包时,可试着安装progress包。

编写小脚本

通过写一个小脚本,定期观察文件大小,也可查看文件写入速度,如下:

# 每秒获取文件大小,通过减去上一秒的大小,即可计算出速度while sleep 1; do \ sz=`stat -c %s app.log`; \ numfmt --from=auto --to=iec $((sz-psz)); \ psz=$sz; \done492K750K370K

通过watch再加上观察,也能大致看出速度,如下:

watch -d -t -n1 du app.log

举一反三

其实转念一想,如果我们在某个函数中打上日志,然后通过grep过滤出此日志,然后我们只要计算每秒输出的日志行数,这岂不就是函数执行的QPS了!

# 使用grep过滤出日志,tr删除非换行符,所以dd显示的是换行符的个数!$ tail -F app.log \ | grep --line-buffered '/order/get' \ | stdbuf -oL tr -dc '\n' \ | dd of=/dev/null bs=1 status=progress151 bytes (151 B) copied, 15.523018 s, 0.0 kB/s

这里可以通过151/15计算出QPS是10,由于没有超过1000,所以看到的是0.0kB/s,如果使用pv命令,会更简单一些,如下:

$ tail -F app.log \ | grep --line-buffered '/order/get' \ | pv -l >/dev/null 144 0:00:03 [11.5 /s] [ <=> ]

推荐

首页/电脑版/网名
© 2025 NiBaKu.Com All Rights Reserved.