xargs与tar合并查询文件并打包问题检查

今天在整理服务器上的日志的时候,希望能将日志打包保存之后再删除,然后就出现了问题了。

find /debugLog -mmin +21600 -type f -print | xargs tar cvf /debugLog_$(date +”%Y%m%d%H%M%S”).tar

会出现提示:

tar: Exiting with failure status due to previous errors

大意是上一步中存在错误,怎么查看错误是啥?

查一下,在《Linux常见问题解答–如何修复“tar:Exiting with failure status due to previous errors”》找到答案,只需要将v参数去掉就行。

使用下面的命令查看:

find /debugLog -mmin +21600 -type f -print | xargs tar cf /debugLog_$(date +”%Y%m%d%H%M%S”).tar

然后打印出好多的错误信息了:

tar: Removing leading `/’ from member names
tar: /debugLog/efast/20171204_b2c_apiv_apis_response_goods: Cannot stat: No such file or directory
tar: -: Cannot stat: No such file or directory
tar: get_all_list.txt: Cannot stat: No such file or directory
tar: /debugLog/wxauth/20180103_wxauth_115.239.174.134,: Cannot stat: No such file or directory
tar: 10.53.26.130.txt: Cannot stat: No such file or directory
tar: /debugLog/wxauth/20180103_wxauth_115.239.174.134,: Cannot stat: No such file or directory
tar: 10.53.29.194.txt: Cannot stat: No such file or directory
tar: Exiting with failure status due to previous errors

对于第一行的错误,百度了一下,在《“tar: Removing leading `/’ from member names”的错误》找到答案,这个因为是相对路径的缘故,需要增加P参数。

命令改为:

# find /debugLog -mmin +21600 -type f -print | xargs tar cfP /debugLog_$(date +”%Y%m%d%H%M%S”).tar

然后,继续出现下面的错误了:

tar: /debugLog/efast/20171204_b2c_apiv_apis_response_goods: Cannot stat: No such file or directory
tar: -: Cannot stat: No such file or directory
tar: get_all_list.txt: Cannot stat: No such file or directory
tar: /debugLog/wxauth/20180103_wxauth_115.239.174.134,: Cannot stat: No such file or directory
tar: 10.53.26.130.txt: Cannot stat: No such file or directory
tar:/debugLog/wxauth/20180103_wxauth_115.239.174.134,: Cannot stat: No such file or directory
tar: 10.53.29.194.txt: Cannot stat: No such file or directory
tar: Exiting with failure status due to previous errors

根据实际查看错误的文件名发现,这两个文件其实都有特殊:

/debugLog/efast/20171204_b2c_apiv_apis_response_goods – get_all_list.txt

/debugLog/wxauth/20180103_wxauth_115.239.174.134, 10.53.29.194.txt

因为xargs默认分割符是空格,所以,上面的就被分为5个文件了。

/debugLog/efast/20171204_b2c_apiv_apis_response_goods

get_all_list.txt

/debugLog/wxauth/20180103_wxauth_115.239.174.134,

10.53.29.194.txt

所以,我们需要将分割符换一下,代码改为下面形式就OK了~

find /debugLog -mmin +21600 -type f -print0 | xargs -0 tar cfP /debugLog_$(date +”%Y%m%d%H%M%S”).tar

完美解决,如果你需要压缩完毕后就直接删除文件,则需要增加参数

find /debugLog -mmin +21600 -type f -print0 | xargs -0 tar cfP /debugLog_$(date +”%Y%m%d%H%M%S”).tar –remove-files

就可以了。

介于上面的文件名问题,我比较不赞同直接增加参数,毕竟,架不住有时候文件名里面出现个/被解析为根目录呢?

使用下面命令麻烦了点,但是稍微比较保险,你说呢?

find /debugLog -mmin +21600 -type f -print -exec rm -rf {} \;

MySQL-怎么知道一张表那个字段是必填的呢?

今天在开发ShopNC的功能的时候,需要插入商品表的信息,那么就有一个问题了,怎么知道这个表的字段是否必填呢?因为必填项我们没有传入数据的话,是会报错的喔。

好吧,用下面的办法就能获取必填项的信息了。

执行下面的SQL语句,然后,得到的字段清单都是必填项。

SELECT
COLUMN_NAME,COLUMN_DEFAULT,DATA_TYPE,CHARACTER_SET_NAME,COLUMN_KEY,COLUMN_TYPE,COLUMN_COMMENT
FROM `information_schema`.`COLUMNS`
WHERE TABLE_SCHEMA='ecstore' AND `TABLE_NAME` = 'sdb_b2c_orders' AND IS_NULLABLE='NO'
ORDER BY ORDINAL_POSITION ASC

快去试试看呗。

Node.js-云转码的使用日记

最近在用云转码作为上传视频的平台,然后测试代码出现点问题,就做个日记,以防忘记。

尝试不断更新,更新时间为:2017.12.13 18.49

1.上传错误:上传密钥错误!

原因:因为上传平台设置了上传的“上传密钥”。

解决:登录后台,系统设置,然后下面“上传密钥”复制一下密钥,然后打开“安装目录\work\public\upload\js\upload.js”找到里面的userId: “我是一串字符”,将“我是一串字符”替换成上面复制的就行。

吐槽:这个密钥设置等于没设置,这样子有意义?

2.上传之后完成,但是后台就是没看到文件

原因:设置了上传允许的域名了,需要开启

解决:登录后台,系统设置,然后下面“允许域名”将需要允许的填写进去就可以了,或者全部清空。

3.

LINUX服务器安全之SSH默认端口号修改

服务器的安骑士提示服务器有安全隐患需要建议修改SSH默认的端口号,哎呀,照做吧~

第一步我们肯定是要确定一个新的端口号,这个新的端口号,不能有程序在用噢,请用下面的命令检查一下吧~

SETP 01
# 1234 为新的端口号,请换成你需要修改的端口号码
netstat -anp | grep 1234

确定完新的端口号没有被占用,然后就可以修改配置文件了,命令如下:

SETP 02
# vim改为你喜欢的编辑器就可以了
vim /etc/ssh/sshd_config

然后你会看到

SETP 03
Port 22
或者
#Port 22

不管是第一种还是第二种,请都改为如下:

SETP 04
# 2017.06.05
Port 22
Port 1234

然后保存退出,进行下一步。

用下面的命令重启一下SSH服务:

SETP 05
service sshd restart
# 或者
/etc/init.d/sshd restart

如果找不到这个命令就查找一下/etc/init.d/这个目录下面ssh相关的命令尝试一下呗,查找命令是:

SETP 06
cd /etc/init.d/
find ./ -name ssh

然后就能看到了噢~

用SSH连一下新的端口号,可以的话,重复操作SETP 02中的操作,将之前的参数修改为:

SETP 07
# 2017.06.05
# Port 22
Port 1234

然后依次重复SETP 03,04,05,然后连接一下端口22就会发现,端口号22已经不能够连接了,只能用新的端口号连接。