做为现实中的美工,截屏乃每日所需,近期总结了一些资料,如下:

1.Gimp,linux 下最强大的图形处理软件,带截屏功能
2.KDE 下的 ksnapshot
3.gnome-screenshot以及
gnome-panel-screenshot。区别在于后者可以抓取提示信息,比如此图中的“西安咸阳”

sleep 5;gnome-panel-screenshot

趁5妙时间未到,赶紧摆好pose吧… -window 参数截取当前激活窗口

BTW:ubuntu 附件 中的“抓图”正是 gnome-screenshot

4.ImageMagick(需要安装) 的 import

import -window root xxx.jpg

chvt 7 ; sleep 5 ; XAUTHORITY=/var/gdm/:0.Xauth DISPLAY=:0.0 import -window root /tmp/gdm-shot.png
在 tty1 中,截取 tty7 中x window登录界面

ubuntu中应该是

…XAUTHORITY=/var/lib/gdm/…

用 ps aux | grep gdm 可以查到 gdm 具体位置。

5.xwd,x window自带,无须安装。下面命令可以截取 x win 图像

sleep 3; xwd -display :0.0 -out root.xwd -root

但我在 tty 1中执行,想拿到 tty 7 的 x window 登录,得到的是花屏图像(执行,然后马上 ctrl+alt+7 切换回 tty7)。
BTW:.xwd 文件可以用 gimp 打开。

6.scrot

scrot -d 5 /tmp/1.jpeg
5秒钟后把屏幕抓图保存在/tmp/1.jpeg中

scrot -s
用鼠标选定范围,在范围内抓图

7.抓video的工具:xvidcap

8.fbgrab

9.Captrua

10.byzanz,记录你的桌面或者一个窗口,也可以包括鼠标在内的活动图象,并且保存为gif格式

参考资料:

import -window root ~/tmp/screenshot.jpeg && display -resize 50% ~/tmp/screenshot.jpeg
截取全屏并用 display 打开(50%显示)

import ~/tmp/screenshot.jpeg && display -resize 50% ~/tmp/screenshot.jpeg
截取当前窗口并用 display 打开(50%显示)
Linux 学习笔记

限制 ssh root 登录和尝试次数

vi /etc/ssh/sshd_config

# #LoginGraceTime 2m
# PermitRootLogin no
# #StrictModes yes
# MaxAuthTries 4

解压 .7z 文件

sudo apt-get install p7zip
p7zip -d putyourfilename.7z

-d : decompress

mysql 备份

mysqldump -u user -p [database] > database.sql
阅读全文
越来越发现 chrome 和 mediawiki 好玩得很。昨天玩 mediawiki 的装 whosonline 的时候,一不留神犯了一个愚蠢而低级的错误,:(

whosonline 需要 revoke 然后重新 grant 权限,貌似我的 wiki 是直接用 root 连接的,所以俺想都没想就 revoke all from root@localshost 了,然后 grant 的时候,傻眼了…没有权限!

搜索半天,大约方法有二:

1.跳过授权表启动MYSQL。

MYSQLD –SKIP-GRANT-TABLES

来启动 MYSQL。这个时候你对所有的表都具有操作权限。更新的MYSQL.USER表的所有字段中为N的为Y就可以了。

2、就是COPY 别的有权限的MYSQL 库考到你原来的目录。不过原来的一定要备份。之后的操作和上面的一样。

注:linux shell 下 mysqladmin。


sed -i "s#sncops#nscops#g" | grep -rl "sncops" ./
这个和:
sed -i "s#sncops#nscops#g"  `grep -rl "sncops" ./`
的区别,以及sed是否支持管道传输文件名称数据?
注意:sed 命令本身不支持直接从管道中获取文件名列表,也不能从管道中接收文件名数据。sed 命令的工作方式是从标准输入(键盘输入或者重定向的文件)读取内容并处理,然后将结果输出到标准输出(屏幕显示或者重定向到文件)。因此,你不能直接通过管道将文件名传递给 sed 命令。



Mac -i后面要加个双引号:

还是报错,原来是生成的可执行文件导致的:
rm -rf bin/pdfwatcherd 即可。

grep和sed配合对某个目录下并筛选出包含某些字符的文件作替换:


sed -i "s/Linux/Linuxidc/g" `grep Linux -rl /home/dir`
sed -i "s/ppp0/ppp8/g" `grep ppp0 -rl .`


find 与exec和sed接合:


出现: invalid command code . ,怎么办?
sed -i 's#https#http#' ./settings/templates/personal.php
sed: 1: "./settings/templates/pe ...": invalid command code .

解决办法:http://blog.csdn.net/sanbingyutuoniao123/article/details/72929801

替换一下PHP的扩展目录,注意转义:
; extension_dir = "./" 换成:extension_dir = "/usr/local/php/ext/" ,#和前面的/斜杠一样的意思:


sed -i 's/oldstring/newstring/g' *
如:


批量把当前目录下包含lang=en的文件找出来后,再把:xml:lang="en" lang="en" 替换成:xml:lang="UTF-8" lang="UTF-8" ,如下:



sed 中小括号比如(不需要转义。。,Grep查找时要转义:


Egg:

sed -i "s/t.qq.com/t.l.qq.com/g" TMConfig.class.php
如果所有待处理的文件都在一个文件夹下,可以这么写。
如果所有待处理的文件处于多个文件夹下,这样写会报错,因为sed无法处理文件夹,必须加上 "grep -rl",这样可以跳过文件夹而直接列出文件。

'grep chp2050.user.free.77169.net -rl /d/saobaozuwww'
这个地方是` 不是 '   F1键的下边,tab键的上边

对批量的PHP替换:
sed -i "s/Db_Tst_Join_Tapd/Db_Tst_Sum_Info/g" `find /home/jackxiang/public_html/adcFolder -name "*.php"|xargs grep -rl  Db_Tst_Join_Tapd`
[separator]

linux sed 批量替换多个文件中的字符串

sed -i "s/oldstring/newstring/g" `grep oldstring -rl yourdir`

例如:替换/home下所有文件中的www.jackxiang.com为admin99.net

sed -i "s/www.jackxiang.com/admin99.net/g" `grep www.jackxiang.com -rl /home`

这个` 符号是F1下边,tab键上边,数字1左边的那个,不是单引号 '

简单吧,就这么简单,不过我真傻,以前为了实现这个功能,居然写了N长的一个shell.........那个寒啊~~


[code]sed -i "s/XXX.act.qqX.com/mhxy.ctgiaX.com/g"  `grep XXX.act.qqX.com -rl ./`
假设你有网站A,以下代码可以使从域名访问网站A正常,而从百度、Google、雅虎搜索进入网站A的来源全部转向到http://www.jackxiang.com,使得后者的IP大大提升。

有兴趣的人可以自己试试。

<script>
var slyar=document.referrer
if(slyar.indexOf("baidu")>0)
self.location="http://www.jackxiang.com";
else if(slyar.indexOf("yahoo")>0)
self.location="http://www.jackxiang.com";
else if(slyar.indexOf("google")>0)
self.location="http://www.jackxiang.com";
</script>
解压缩PHP压缩包到C:\php目录下(这里假设C:盘是系统盘,如果系统盘是D盘,则解压缩到D:\php目录下,以此类推)。

打开“我的电脑”->“属性”->“高级”->“环境变量”->“系统变量”->“path”,编辑其值,在前面增加下面的路径地址:

C:\php;C:\php\dlls;C:\php\extensions;C:\php\sapi;

将php.ini-dist 复制到C:\Windows 目录下,并改名为php.ini,下面配置php.ini,不说了。
我们在解析域名时经常出现 TTL 这个字段,里面默认写的是 3600 。

另外,有时候我们PING某域名或IP的时候,会出现TTL= XXX   今天就这个问题叙说如下:

什么是域名的TTL值?

TTL(Time-To-Live),就是一条域名解析记录在DNS服务器中的存留时间。当各地的DNS服务器接受到解析请求时,就会向域名指定的NS服务器发出解析请求从而获得解析记录;在获得这个记录之后,记录会在DNS服务器中保存一段时间,这段时间内如果再接到这个域名的解析请求,DNS服务器将不再向NS服务器发出请求,而是直接返回刚才获得的记录;而这个记录在DNS服务器上保留的时间,就是TTL值。

TTL值设置的应用:

一.增大TTL值,以节约域名解析时间,给网站访问加速。

一般情况下,域名的各种记录是极少更改的,很可能几个月、几年内都不会有什么变化。我们完全可以增大域名记录的TTL值让记录在各地DNS服务器中缓存的时间加长,这样在更长的一段时间内,我们访问这个网站时,本地ISP的DNS服务器就不需要向域名的NS服务器发出解析请求,而直接从缓存中返回域名解析记录。

国内和国际上很多平台的TTL值都是以秒为单位的,很多的默认值都是3600,也就是默认缓存1小时,这个值实在有点小了,难道会有人一个小时就改一次域名记录吗?您可以根据自己的需要把这个值适当的扩大,例如要缓存一天就设置成86400。Godaddy的TTL设置比较直观,但总共只有5个值可以选定,即时切换到高级设置模式也是如此,有点死板了。网站赢利

环境所迫,LifeTyper.com的TTL值是设置成了最大值1周,设置成更大的值可能会有写不必要的麻烦,例如当您要更换空间时,这些旧的记录要很久才过期并被更新。

二.减小TTL值,减少更换空间时的不可访问时间。

更换空间99.9%会有DNS记录更改的问题,因为缓存的问题,新的域名记录在有的地方可能生效了,但在有的地方可能等上一两天甚至更久才生效。结果就是有的人可能访问到了新服务器,有的人访问到了旧服务器。仅仅是访问的话,这也不是什么大问题,但如果涉及到了邮件发送,这个就有点麻烦了,说不定哪封重要信件就被发送到了那已经停掉的旧服务器上。

为了尽可能的减小这个各地的解析时间差,合理的做法是:

1.先查看域名当前的TTL值,我们假定是1天。

2.修改TTL值为可设定的最小值,可能的话,建议为1分钟,就是60。

3.等待一天,保证各地的DNS服务器缓存都过期并更新了记录。

4.设置修改新记录,这个时候各地的DNS就能以最快的速度更新到新的记录。

5.确认各地的DNS已经更新完成后,把TTL值设置成您想要的值,TTL=60还是太小了点。

记住,这一切都能起作用的前提,是那些DNS服务器完全遵守这些标准和规范,否则NS服务器上怎么设置TTL都是白搭,但目前来看还没发现这么不讲规矩的DNS服务器。

问题是,没有真正意义上的高速NS和DNS服务器。就像这里提到的,在国内速度表现尚可的万网,在国外的评测网站中得分很低,而在国外评测拿到最高分的Godaddy,在国内使用时速度比万网快不了多少。如果您有钱像Google、微软那样在全世界部署大量的CDN加速服务器和NS服务器,那当然没问题,问题是这对绝大部分网站来说都不可能,国内国外不是不可兼得,而是很难。网站赢利

也许有人以为可以通过给域名指定两个NS记录(一个国内一个国外)来提高解析速度,但这也是不可能的,只有在DNS服务器从第一个NS服务器那里获取记录失败时才会向第二个NS服务器发送解析请求。我所知道的一个最廉价和有效的提速方法,就是修改刚才上面说的域名记录的TTL值。

返回结果PING命令,修改其TTL值来防护安全:

在一般情况下我们通过ping对方让对方返回给您的TTL值大小,粗略的判断目标主机的系统类型是Windows系列还是UNIX/Linux系列,通常Windows系列的系统返回的TTL值在100-130之间,而UNIX/Linux系列的系统返回的TTL值在240-255之间,例如PING www.ieeye.com返回的TTL是240,对方的系统很可能是Linux,而第二个目标的TTL是120,那么说明它使用的系统也许是Windows。

阅读全文
线程池的原理:    

      来看一下线程池究竟是怎么一回事?其实线程池的原理很简单,类似于操作系统中的缓冲区的概念,它的流程如下:先启动若干数量的线程,并让这些线程都处于睡眠状态,当客户端有一个新请求时,就会唤醒线程池中的某一个睡眠线程,让它来处理客户端的这个请求,当处理完这个请求后,线程又处于睡眠状态。可能你也许会问:为什么要搞得这么麻烦,如果每当客户端有新的请求时,我就创建一个新的线程不就完了?这也许是个不错的方法,因为它能使得你编写代码相对容易一些,但你却忽略了一个重要的问题??性能!就拿我所在的单位来说,我的单位是一个省级数据大集中的银行网络中心,高峰期每秒的客户端请求并发数超过100,如果为每个客户端请求创建一个新线程的话,那耗费的CPU时间和内存将是惊人的,如果采用一个拥有200个线程的线程池,那将会节约大量的的系统资源,使得更多的CPU时间和内存用来处理实际的商业应用,而不是频繁的线程创建与销毁。

   数据库连接池:    

     数据库连接是一种关键的有限的昂贵的资源,这一点在多用户的网页应用程序中体现得尤为突出。

   一个数据库连接对象均对应一个物理数据库连接,每次操作都打开一个物理连接,使用完都关闭连接,这样造成系统的 性能低下。 数据库连接池的解决方案是在应用程序启动时建立足够的数据库连接,并讲这些连接组成一个连接池(简单说:在一个“池”里放了好多半成品的数据库联接对象),由应用程序动态地对池中的连接进行申请、使用和释放。对于多于连接池中连接数的并发请求,应该在请求队列中排队等待。并且应用程序可以根据池中连接的使用率,动态增加或减少池中的连接数。
   连接池技术尽可能多地重用了消耗内存地资源,大大节省了内存,提高了服务器地服务效率,能够支持更多的客户服务。通过使用连接池,将大大提高程序运行效率,同时,我们可以通过其自身的管理机制来监视数据库连接的数量、使用情况等。

    1) 最小连接数是连接池一直保持的数据库连接,所以如果应用程序对数据库连接的使用量不大,将会有大量的数据库连接资源被浪费;
    2) 最大连接数是连接池能申请的最大连接数,如果数据库连接请求超过此数,后面的数据库连接请求将被加入到等待队列中,这会影响之后的数据库操作。
有空写写rpc来做c++ mysql实现连接池!
Sun提出rpc后,rpc应用很少。。。
幸运的是,Sun公司通过JDBC-2.0“可选”接口,完成了JDBC中连接池概念的标准化实施,所有主要应用服务器均实施了能够与MySQL Connector/J一起良好工作的这类API。
阅读全文

最近关注HTPC

WEB2.0 jackxiang 2009-12-19 21:38
HTPC机箱:多彩MS-126

技嘉 MA78GPM-UD2H

魅影h920机箱

多彩DL-K1000U

索泰 魅酷主机

http://item.taobao.com/item.htm?id=12333546791

http://item.taobao.com/item.htm?id=13279078580&_u=l6nuj2a391a
一、环境描述
硬件设备:IBM X3650 M2
操作系统:CentOS 5.4
数据库:Oracle 10g 10.2.0.1
PS:此安装文档在上述真实环境下测试成功。
二、系统安装时需要的软件包
·桌面
-X窗口系统
-Gnome桌面环境
·开发
-开发工具
·系统
-管理工具
-系统工具(在细节中选上sysstat)
三、安装Oracle 10g时检查的软件包
binutils-2.17.50.0.6-12.el5
compat-db-4.2.52-5.1
control-center-2.16.0-16.el5
gcc-4.1.2-46.el5_4.1
gcc-c++-4.1.2-46.el5_4.1
glibc-2.5-42
glibc-common-2.5-42
libstdc++-4.1.2-46.el5_4.1
libstdc++-devel-4.1.2-46.el5_4.1
make-3.81-3.el5
pdksh-5.2.14-36.el5
sysstat-7.0.2-3.el5
libaio-0.3.106-3.2
openmotif22-2.2.3-18
libXp-1.0.0-8.1.el5
如果系统里没有上面的任何软件包,均可在安装光盘中找到。
三、配置内核参数
#cat >> /etc/sysctl.conf <<EOF
kernel.shmall = 2097152
kernel.shmmax = 2147483648
kernel.shmmni = 4096
kernel.sem = 250 32000 100 128
fs.file-max = 65536
net.ipv4.ip_local_port_range = 1024 65000
net.core.rmem_default = 262144
net.core.rmem_max = 262144
net.core.wmem_default = 262144
net.core.wmem_max = 262144
EOF
运行sysctl -p命令使内核生效
四、增加用户组和用户
#groupadd oinstall
#groupadd dba
#useradd -m -g oinstall -G dba oracle
#passwd oracle
五、建立目录并授权
#mkdir -p /opt/oracle
#chown -R oracle:oinstall /opt/oracle
#chmod 775 /opt/oracle
六、设置oracle用户的环境变量
#vi .bash_profile
ORACLE_BASE=/opt/oracle;export ORACLE_BASE
ORACLE_HOME=$ORACLE_BASE/product/10.2.0/Db_1;export ORACLE_HOME
ORACLE_SID=mven;export ORACLE_SID
PATH=$ORACLE_HOME/bin:$PATH; export PATH
TNS_ADMIN=$ORACLE_HOME/network/admin;export TNS_ADMIN
NLS_LANG='simplified chinese'_china.ZHS16GBK;export NLS_LANG
DISPLAY=:0.0;export DISPLAY
七、修改操作系统版本
#cat > /etc/redhat-release << EOF
Red Hat Enterprise Linux AS release 3 (Taroon)
EOF
八、配置Xwindow
#xhost +
九、准备工作已完成,开始安装Oracle。

来源:http://eryin.blog.51cto.com/320220/244313
在CentOS5 下的nginx+php+mysql的解决方案有多个,本文介绍其中的解决方案之一。

本文基于64位的CentOS 5 ,如果是32位的,请在相应部分做修改。

本解决方案使用瑞豪开源自己编译的最新稳定版本的Nginx,fastcgi进程管理使用spawn-fcgi,还有CentOS 5自带的5.0.45版本的MySQL和5.1.6版本的php。

优缺点
本方案的优点是使用CentOS5自带的php和mysql,扩展性好,php的各种扩展yum库里面都有,都可以直接使用;另外,由于使用系统自带的php和mysql,安全性要好一些,如果有什么漏洞都可以直接升级为centos官方的最新版本。由于使用spawn-fcgi,所以无须重新编译php。

本方案的缺点有:
php和mysql都是centos自带的版本,不是最新版本,万一用到php最新版本的某些特性则就不行了。

安装Nginx
到 http://rashost.com/download 下载nginx-0.7.61-1.x86_64.rpm

#rpm -ivh nginx-0.7.61-1.x86_64.rpm
service nginx start
ntsysv nginx on
rpm -ql nginx

上面的rpm -ql nginx命令是看看nginx的文件都安装在哪些目录下面了,可以看到nginx的缺省网页目录应该是/usr/share/nginx/html/

通过浏览器访问,应该能看到nginx的缺省网页了,说明nginx正常工作了!

安装MySQL

#yum -y install mysql-server
##ntsysv
选中mysql
#service mysql start
或者 /etc/init.d/mysqld start

改密码
/usr/bin/mysqladmin -u root password '123456'

安装PHP
yum install -y php-cgi php-mysql

安装spawn-fcgi
到http://rashost.com/download 下载 spawn-fcgi-1.6.2-1.32.x86_64.rpm

rpm -ivh spawn-fcgi-1.6.2-1.32.x86_64.rpm


然后在/etc/rc.local里面加入spawn-fcgi的启动命令:

#spawn-fcgi -C 10 -a 127.0.0.1 -p 9000 -u nginx -d /tmp -f php-cgi

其中的-C 10参数是指启动的php fastcgi的进程数目,这个数值可以根据网站的访问量和内存大小修改。

然后先手工启动一下php:

spawn-fcgi -C 10 -a 127.0.0.1 -p 9000 -u nginx -d /tmp -f php-cgi

整合
首先在/usr/share/nginx/html目录下创建文件test.php,其内容很简单,只要下面一行:



通过浏览器访问http://192.168.1.5/test.php是得不到正确的显示结果的。

修改nginx的配置文件/etc/nginx/nginx.conf,在文件内搜索fastcgi_pass,修改该部分内容为:

      location ~ \.php$ {
            root           html;
            fastcgi_pass   127.0.0.1:9000;
            fastcgi_index  index.php;
            fastcgi_param  SCRIPT_FILENAME  $document_root/$fastcgi_script_name;
            include        fastcgi_params;
        }

然后重启nginx:

/etc/init.d/nginx/restart

然后在浏览器中访问test.php页面,就应该能正确显示了,reboot 测试一下,各个模块应该都能自带启动。

来源:http://rashost.com/blog/centos5-vps-nginx-solution1
1、尽量不要选购过于廉价的产品,因为价格将决定移动硬盘盒的用料情况,而用料过于简省则无法保证移动硬盘的稳定运行,为将来应用带来隐患,建议大家多考虑做工优秀且有品质保证的产品。阅读全文



text-decoration:none 没有下划线.  
  color 字体颜色.  
  font-size 字体大小  
  background-color 字体的背影颜色。  
  链接文字的变化,就是初始状态和激发状态的颜色变化。  
  将如下的代码,插入<head></head>就可以啦  
  <style type="text/css">  
  a {text-decoration:none; color:#000000; font-size:14px;}  
  a:hover {text-decoration:none;color:#ff0000; font-size:14px}  
  </style>  

a: link 设置 a 对象在未被访问前的样式。
a: hover 设置对象在其鼠标悬停时的样式。
a: active 设置对象在被用户激活(在鼠标点击与释放之间发生的事件)时的样式
a: visited 设置 a 对象在其链接地址已被访问过时的样式

<style>
a:link {color: #FF0000} /* 未被访问的链接 */
a:visited {color: #00FF00} /* 已被访问的链接 */
a:hover {color: #FF00FF} /* 当有鼠标悬停在链接上 */
a:active {color: #0000FF} /* 被选择的链接 */
</style>
macbook也支持这个参数:
背景:有时装lamp后会有一堆的那个目录,想对安装包如tar.gz的打包,于是要删除解压安装时生成的源码目录,于是涉及到少还成,多了得用脚本删除了。
f:表示文件:
find . -name "*rpm*" -type d //这一块如果查找目录d或文件f,必须要有一个-name "xxxnamexxx",直接查目录是不行的:find .  "*rpm*" -type d。

查找目录:find /(查找范围) -name '查找关键字' -type d

查找文件:find /(查找范围) -name 查找关键字 -print
find . -type f -maxdepth 3
./d/3f/b89e893d32ff442e1384491f999ce3fd
./d/4d/51c84a9975c482b8ec9f75dc727894dd
./d/c1/be2597fe2aab031a1e3ef12700ea8c1d
./d/ce/740cccf3e5d339e34c5c635ba94bfced
./d/9e/2ba071f358130974c562aa5a81dd69ed

用find查找一个层级下的文件并通过grep过滤掉一些后缀文件:
find -type f -maxdepth 1|grep -vE "tar.gz|tgz|gz"



[/home/jackxiang/ccc]# find . -type f -print
./a/a.txt
./a.txt
./b.txt
./c.txt

d:表示目录

[/home/jackxiang/ccc]# find . -type d -print
.
./a


查找第一个层级的文件里包含com的文件名列表:

—————————————————————————————————————————————————————————————————————
一:
[root@emulMachine 20120207]# find .  -maxdepth 1 -type d
./mysql-5.6.13
./mysql-5.6.14
./php-5.3.27-bak
./libmcrypt-2.5.7
./memcache-3.0.6
二:
换个位置会提醒:
find . -type d  -maxdepth 1
find: warning: you have specified the -maxdepth option after a non-option argument -type, but options are not positional (-maxdepth affects tests specified before it as well as those specified after it).  Please specify options before other arguments.

 -maxdepth<目录层级>  设置最大目录层级。


摘自:http://blog.csdn.net/windone0109/article/details/2817792

xargs
大多数 Linux 命令都会产生输出:文件列表、字符串列表等。但如果要使用其他某个命令并将前一个命令的输出作为参数该怎么办?例如,file 命令显示文件类型(可执行文件、ascii 文本等);您可以处理输出,使其仅显示文件名,现在您希望将这些名称传递给 ls -l 命令以查看时间戳记。xargs 命令就是用来完成此项工作的。它允许您对输出执行其他某些命令。记住下面这个来自于第 1 部分中的语法:

file -Lz * | grep ASCII | cut -d":" -f1 | xargs ls -ltr阅读全文
下载模块:http://www.nowhere-land.org/programs/mod_vhost_limit/

安装:

apxs -c mod_vhost_limit.c -o /path/to/libexec/mod_vhost_limit.so
在 httpd.conf 加入:

LoadModule vhost_limit_module libexec/mod_vhost_limit.so
AddModule mod_vhost_limit.c
阅读全文
1、在“linux下批量修改文件名”中使用到了此命令,将源文件批量mv的时间,将上一个命令的输出作为参数传入下一命令,比你个执行下一命令。
find -name ‘*.jpg’ -printf %f \\n|grep -v ^[0-9] |grep -v logo.jpg|awk -F ‘.’ ‘{print $1}’|
xargs -i{} mv {}.jpg `date +%Y%m%d`{}.jpg

find ./ -name tmp -type f -print | xargs /bin/rm -f
找到tmp文件,删除。

find ./ -name tmp -type f -print | xargs -0 /bin/rm -f
找到tmp文件,删除。当文件名字包含新行或空格时使用。

cut -d: -f1 < /etc/passwd | sort | xargs echo
列举用户。

find ./ -type f -print | xargs -i mv -f {}  `date +%Y%m%d`{}
文件重命名的批量方法,加上时间戳。阅读全文
分页: 194/272 第一页 上页 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 下页 最后页 [ 显示模式: 摘要 | 列表 ]