在Linux中创建临时文件(随机文件名)的方法总结
1. mktemp (推荐使用)
自动在/tmp文件夹下建立暂存文件,返回其文件名(包括路径/tmp)。该命令创建的临时文件的文件名比较随机,能保证一定的安全性。
发行版中所属包:
Fedora: coreutils
Ubuntu: debianutils
可以看出,它们都属核心、默认安装的软件包,所以此命令比较通用。 使用范例:使用mktemp 命令生成临时文件时,文件名参数可以“文件名.XXXX”的模板形式给出,mktemp 会根据模板在当前目录建立一个临时文件。
[root@wkh11 ~]$ mktemp -d mktemp_test.XXXX
mktemp_test.UkW9
[root@wkh11 ~]$ cd mktemp_test.UkW9/
[root@wkh11 mktemp_test.UkW9]$ mktemp tekkaman.XX
mktemp: too few X's in template 'tekkaman.XX'
[root@wkh11 mktemp_test.UkW9]$ mktemp tekkaman.XXX
tekkaman.Mvs
[root@wkh11 mktemp_test.UkW9]$ ll
total 0
-rw-------. 1 root root 0 Jul 2 11:51 tekkaman.Mvs
由此可见:
-d 参数用于创建临时目录
如果你使用“文件名.XXXX”的模版 ,其中的“X”数量必须大于等于3。且文件会创建在相对于当前目录的路径下。
不使用模版,则会在默认的 /tmp 目录下创建临时文件(夹),文件名为tmp.XXXXXXXXXX
[root@wkh11 ~]$ mktemp -d
/tmp/tmp.dnLatv8jm6
[root@wkh11 ~]$ mktemp
/tmp/tmp.SZOntyaitQ
2. $RANDOM
编程中,随机数是经常要用到的,BASH 中也提供了这个功能:$RANDOM 变量
它是Bash的一个返回伪随机整数(范围为0 - 32767)的内部函数(而不是一个常量或变量),它不应该用于产生加密的密钥。
[root@wkh11 ~]$ echo $RANDOM
1493
[root@wkh11 ~]$ echo $RANDOM
32185
[root@wkh11 ~]$ echo $RANDOM
8003
这个程序可以在每次执行的时候随机的打印出一个大小在 1 到 65536 之间的整数。
我们可以用他生成一个“随机”的文件名,例如:
[root@wkh11 ~]$ temp_file_name="/tmp/file_$RANDOM"
[root@wkh11 ~]$ touch $temp_file_name
[root@wkh11 ~]$ echo $temp_file_name
/tmp/file_31435
[root@wkh11 ~]$ ll /tmp/
total 0
......
-rw-rw-r--. 1 root root 0 Jul 2 14:44 file_31435
......
3. $$变量(非随机文件名)
shell 中的变量 $$ 保存所运行的当前进程的进程号。可以使用它在我们运行的脚本中创建一个唯一的临时文件,因为该脚本在运行时的进程号是唯一的。在脚本结束时,只需删除带有$$扩展的临时文件即可。Shell将会把 $$ 解析为当前的进程号,并删除相应的文件,而不会影响以其他进程号做后缀的文件。
#!/bin/sh
#tempfiles
#name the temp files
HOLD1=/tmp/hold1.$$
HOLD2=/tmp/hold2.$$
#do some processing using the files
df -tk >$HOLD1
cat $HOLD1 >$HOLD2
#now delete them
rm /tmp/*.$$
这种方法并不属于生成随机文件名,但是在许多网络文章中都有,就在这里随便提一下,可以说这是一种生成进程相关临时文件的好方法。
4.tempfile命令(仅限Debian系的发行版)
tempfile 命令只有在基于Debian发行版中才默认自带,比如Ubuntu,其他发行版没有这个命令,甚至没有包含这个命令的软件包。
由于已经有了mktemp,这个命令就比较多余,但是它包含了mktemp没有的一些选项(当然,通过命令组合,mktemp 可以实现一样的功能)。
root@wkh11:~$ tempfile
/tmp/file1vBLBK
root@wkh11:~$ ll /tmp/file*
-rw------- 1 root root 0 Jul 2 14:52 /tmp/file1vBLBK