程序员常用linux命令汇总 (2012-02-17 10:12)
1. 启动samba: rcsmb start
2. 开启ftp : /etc/rc.d/vsftpd start
3. 两机器间拷贝 scp root@192.168.2.51:/usr/bin/gdb* /usr/bin/ 拷贝192.168.2.51机器 /usr/bin/gdb* 到本机/usr/bin下
4. 如何使用samba
第1步: 增加samba用户:
smbpasswd -a b033
然后根据提示输入密码;
第2步: 编辑/etc/samba/smb.conf文件, 增加下面的内容
[b033]
comment = share b033 user directory
path = /home/b033
writable = Yes
create mask = 0640
read only = No
directory mask = 0750
printable = No
browseable = Yes
valid users = b033
第3步: 执行/etc/init.d/smb start
关闭的命令就是 /etc/init.d/smb stop
2. 开启ftp : /etc/rc.d/vsftpd start
3. 两机器间拷贝 scp root@192.168.2.51:/usr/bin/gdb* /usr/bin/ 拷贝192.168.2.51机器 /usr/bin/gdb* 到本机/usr/bin下
4. 如何使用samba
第1步: 增加samba用户:
smbpasswd -a b033
然后根据提示输入密码;
第2步: 编辑/etc/samba/smb.conf文件, 增加下面的内容
[b033]
comment = share b033 user directory
path = /home/b033
writable = Yes
create mask = 0640
read only = No
directory mask = 0750
printable = No
browseable = Yes
valid users = b033
第3步: 执行/etc/init.d/smb start
关闭的命令就是 /etc/init.d/smb stop
5. 程序段错误时生成coredump文件
a. 在/etc/profile中加入以下一行,这将允许生成coredump文件
ulimit -c unlimited
b. 在rc.local中加入以下一行,这将使程序崩溃时生成的coredump文件位于/tmp目录下:
echo /tmp/core.%e.%p > /proc/sys/kernel/core_pattern
a. 在/etc/profile中加入以下一行,这将允许生成coredump文件
ulimit -c unlimited
b. 在rc.local中加入以下一行,这将使程序崩溃时生成的coredump文件位于/tmp目录下:
echo /tmp/core.%e.%p > /proc/sys/kernel/core_pattern
6. 设置系统时间命令
date -s "20100527 16:08:30"
7. 查看目录占用大小
du -sh /usr/bin
查看系统时区 date -R
8. 修改时区方法:比如将8区改为0区
cp /usr/share/zoneinfo/Europe/london /etc/localtime
使用date -R可看到时区变成了0区。
date -s "20100527 16:08:30"
7. 查看目录占用大小
du -sh /usr/bin
查看系统时区 date -R
8. 修改时区方法:比如将8区改为0区
cp /usr/share/zoneinfo/Europe/london /etc/localtime
使用date -R可看到时区变成了0区。
9. wind下断开samba连接
首先断开你的网络链接,win客户端机器(开始->运行->输入cmd)在dos下输入命令net use * /delete /y,就可以断开所有网络用户的链接了。
如果登录的时候勾选了保存用户,就(开始->运行->输入control keymgr.dll,在弹出的对话框中选择你samba服务器的主机名删除即可。
首先断开你的网络链接,win客户端机器(开始->运行->输入cmd)在dos下输入命令net use * /delete /y,就可以断开所有网络用户的链接了。
如果登录的时候勾选了保存用户,就(开始->运行->输入control keymgr.dll,在弹出的对话框中选择你samba服务器的主机名删除即可。
10. 查看当前某程序的内存,CPU等资源消耗情况,比如查看init程序和cpuset程序,使用如下命令
top -d 1 -p `pgrep -d -p 'cpuset|init'`
top -d 1 -p `pgrep -d -p 'cpuset|init'`
11. 在当前目录下查找包含'uImage'字符的文件并输出相关行。
find ./ | xargs grep uImage
find ./ | xargs grep uImage
一、安装RPM包RPM软件包通常具有类似foo-1.0-1.i386.rpm的文件名。
其中包括软件包的名称(foo),版本号(1.0),发行号(1),和硬件平台(i386)。
安装一个软件包只需简单的键入以下命令:
$rpm -ivh foo-1.0-1.i386.rpm
foo ####################################
RPM安装完毕后会打印出软件包的名字(并不一定与文件名相同),而后打印一连串的#号以表示安装进度。
虽然软件包的安装被设计的尽量简单易行,但还是可能会发生如下的错误:
$rpm -e foo
注意这里使用软件包的名字foo,而不是软件包文件的名字foo-1.0-1.i386.rpm。
如果其它软件包依赖于您要卸载的软件包,卸载时则会产生错误信息;如:
$rpm -e foo
removing these packages would break dependencies:foo is needed by bar-1.0-1
若让RPM忽略这个错误继续卸载(这可不是一个好主意,因为依赖于该软件包的程序可能无法运行),请使用--nodeps命令行选项。
三、升级RPM包升级软件包和安装软件包十分类似:
$rpm -Uvh foo-2.0-1.i386.rpm
foo ####################################
RPM将自动卸载已安装的老板本的foo软件包,您不会看到有关信息。事实上您可能总是使用-U来安装软件包,因为即便以往未安装过该软件包,也能正常运行。
因为RPM执行智能化的软件包升级,自动处理配置文件,您将会看到如下信息:
saving /etc/foo.conf as /etc/foo.conf.rpm save
这表示您对配置文件的修改不一定能向上兼容。
因此,RPM会先备份老文件再安装新文件。您应当尽快解决这两个配置文件的不同之处,以使系统能持续正常运行。
因为升级实际包括软件包的卸载与安装两个过程,所以您可能会碰到由这两个操作引起的错误。
另一个你可能碰到的问题是:当您使用旧版本的软件包来升级新版本的软件时,RPM会产生以下错误信息:
$rpm -Uvh foo-1.0-1.i386.rpm
foo package foo-2.0-1(whichisnewer) is already installed error:foo-1.0-1.i386.rpm cannot be installed
如果你确有需要将该软件包降级,加入--oldpackage命令选项就可以了。
四、查询已安装的软件包使用命令rpm-q来查询已安装软件包的数据库。
简单的使用命令rpm -q foo会打印出foo软件包的包名,版本号,和发行号:
$rpm -q foo
foo-2.0-1
除了指定软件包名以外,您还可以使用以下选项来指明要查询哪些软件包的信息。
这些选项被称之为“软件包指定选项“。
-a:查询所有已安装的软件包
-f:将查询包含有文件.的软件包
-p:查询软件包文件名为的软件包还可以指定查询软件包时所显示的信息。它们被称作信息选择选项:
-i:显示软件包信息,如描述,发行号,尺寸,构建日期,安装日期,平台,以及其它一些各类信息。
-l:显示软件包中的文件列表。
-s:显示软件包中所有文件的状态。
-d:显示被标注为文档的文件列表(man手册,info手册,READMEs,etc)。
-c:显示被标注为配置文件的文件列表。这些是您要在安装完毕以后加以定制的文件(sendmail.cf,passwd,inittab,etc)。
对于那些要显示文件列表的文件,您可以增加-v命令行选项以获得如同ls-l格式的输出。
五、验证软件包验证软件包是通过比较已安装的文件和软件包中的原始文件信息来进行的。验证主要是比较文件的尺寸,MD5校验码,文件权限,类型,属主和用户组等。
rpm -V 命令用来验证一个软件包。您可以使用任何包选择选项来查询您要验证的软件包。
命令rpm -V foo将用来验证foo软件包。
又如:验证包含特定文件的软件包:rpm -Vf /bin/vi
验证所有已安装的软件包:rpm -Va
根据一个RPM包来验证:rpm -Vp foo-1.0-1.i386.rpm
如果您担心你的RPM数据库已被破坏,就可以使用这种方式。如果一切均校验正常将不会产生任何输出。如果有不一致的地方,就会显示出来。输出格式是8位长字符串,8位字符的每一个用以表示文件与RPM数据库中一种属性的比较结果。.(点)表示测试通过。
下面的字符表示对RPM软件包进行的某种测试失败:显示字符 -> 错误源,对照关系如下:
5:MD5校验码
S:文件尺寸
L:符号连接
T:文件修改日期
D:设备
U:用户
G:用户组
M:模式e(包括权限和文件类型)如果有错误信息输出,您应当认真加以考虑,是通过删除还是重新安装来解决出现的问题。
其中包括软件包的名称(foo),版本号(1.0),发行号(1),和硬件平台(i386)。
安装一个软件包只需简单的键入以下命令:
$rpm -ivh foo-1.0-1.i386.rpm
foo ####################################
RPM安装完毕后会打印出软件包的名字(并不一定与文件名相同),而后打印一连串的#号以表示安装进度。
虽然软件包的安装被设计的尽量简单易行,但还是可能会发生如下的错误:
- 软件包已被安装如果您的软件包已被安装,将会出现以下信息:
$rpm -ivh foo-1.0-1.i386.rpm
foo package foo-1.0-1 is already installed error:foo-1.0-1.i386.rpm cannot beinstalled
如果您仍旧要安装该软件包,可以在命令行上使用--replacepkgs选项,RPM将忽略该错误信息强行安装。 - 文件冲突如果您要安装的软件包中有一个文件已在安装其它软件包时安装,会出现以下错误信息:
$rpm -ivh foo-1.0-1.i386.rpm
foo /usr/bin/foo conflicts with file from bar-1.0-1 error:foo-1.0-1.i386.rpm cannot be installed
要想让RPM忽略该错误信息,请使用--replacefiles命令行选项。 - 未解决依赖关系RPM软件包可能依赖于其它软件包,也就是说要求在安装了特定的软件包之后才能安装该软件包。如果在您安装某个软件包时存在这种未解决的依赖关系。会产生以下信息:
$rpm -ivh bar-1.0-1.i386.rpm failed dependencies:foo is needed by bar-1.0-1
您必须安装完所依赖的软件包,才能解决这个问题。如果您想强制安装(这是个坏主意,因为安装后的软件包未必能正常运行),请使用--nodeps命令行选项。
$rpm -e foo
注意这里使用软件包的名字foo,而不是软件包文件的名字foo-1.0-1.i386.rpm。
如果其它软件包依赖于您要卸载的软件包,卸载时则会产生错误信息;如:
$rpm -e foo
removing these packages would break dependencies:foo is needed by bar-1.0-1
若让RPM忽略这个错误继续卸载(这可不是一个好主意,因为依赖于该软件包的程序可能无法运行),请使用--nodeps命令行选项。
三、升级RPM包升级软件包和安装软件包十分类似:
$rpm -Uvh foo-2.0-1.i386.rpm
foo ####################################
RPM将自动卸载已安装的老板本的foo软件包,您不会看到有关信息。事实上您可能总是使用-U来安装软件包,因为即便以往未安装过该软件包,也能正常运行。
因为RPM执行智能化的软件包升级,自动处理配置文件,您将会看到如下信息:
saving /etc/foo.conf as /etc/foo.conf.rpm save
这表示您对配置文件的修改不一定能向上兼容。
因此,RPM会先备份老文件再安装新文件。您应当尽快解决这两个配置文件的不同之处,以使系统能持续正常运行。
因为升级实际包括软件包的卸载与安装两个过程,所以您可能会碰到由这两个操作引起的错误。
另一个你可能碰到的问题是:当您使用旧版本的软件包来升级新版本的软件时,RPM会产生以下错误信息:
$rpm -Uvh foo-1.0-1.i386.rpm
foo package foo-2.0-1(whichisnewer) is already installed error:foo-1.0-1.i386.rpm cannot be installed
如果你确有需要将该软件包降级,加入--oldpackage命令选项就可以了。
四、查询已安装的软件包使用命令rpm-q来查询已安装软件包的数据库。
简单的使用命令rpm -q foo会打印出foo软件包的包名,版本号,和发行号:
$rpm -q foo
foo-2.0-1
除了指定软件包名以外,您还可以使用以下选项来指明要查询哪些软件包的信息。
这些选项被称之为“软件包指定选项“。
-a:查询所有已安装的软件包
-f:将查询包含有文件.的软件包
-p:查询软件包文件名为的软件包还可以指定查询软件包时所显示的信息。它们被称作信息选择选项:
-i:显示软件包信息,如描述,发行号,尺寸,构建日期,安装日期,平台,以及其它一些各类信息。
-l:显示软件包中的文件列表。
-s:显示软件包中所有文件的状态。
-d:显示被标注为文档的文件列表(man手册,info手册,READMEs,etc)。
-c:显示被标注为配置文件的文件列表。这些是您要在安装完毕以后加以定制的文件(sendmail.cf,passwd,inittab,etc)。
对于那些要显示文件列表的文件,您可以增加-v命令行选项以获得如同ls-l格式的输出。
五、验证软件包验证软件包是通过比较已安装的文件和软件包中的原始文件信息来进行的。验证主要是比较文件的尺寸,MD5校验码,文件权限,类型,属主和用户组等。
rpm -V 命令用来验证一个软件包。您可以使用任何包选择选项来查询您要验证的软件包。
命令rpm -V foo将用来验证foo软件包。
又如:验证包含特定文件的软件包:rpm -Vf /bin/vi
验证所有已安装的软件包:rpm -Va
根据一个RPM包来验证:rpm -Vp foo-1.0-1.i386.rpm
如果您担心你的RPM数据库已被破坏,就可以使用这种方式。如果一切均校验正常将不会产生任何输出。如果有不一致的地方,就会显示出来。输出格式是8位长字符串,8位字符的每一个用以表示文件与RPM数据库中一种属性的比较结果。.(点)表示测试通过。
下面的字符表示对RPM软件包进行的某种测试失败:显示字符 -> 错误源,对照关系如下:
5:MD5校验码
S:文件尺寸
L:符号连接
T:文件修改日期
D:设备
U:用户
G:用户组
M:模式e(包括权限和文件类型)如果有错误信息输出,您应当认真加以考虑,是通过删除还是重新安装来解决出现的问题。
crontab
上面说了那么多的常用命令,还有一个功能我们也经常用到,就是定时器、日程表,一般通过crontab来运行;crontab 指定在固定时间或固定间隔执行特定的脚本;crontab的常用参数有如下3个:
-e :执行文字编辑器来设定日程表,一般默认的编辑器是VI;
-r :删除目前所有的日程表;
-l :列出目前所有的日程表;
设置日程表时,需要有固定的格式,共6部分,各部分间用空格间隔;其中第6个部分是要执行的命令,前5个部分是设置执行时间或者时间间隔的,具体取值范围和意义如下:
分钟【0-59】 小时【0-23】 日【1-31】 月份【1-12】 星期【0-6】
在设置的时候可以每项有4种指定方式,如下:
* :表示每 分钟/.../星期 都需要执行;
a-b :表示从第 a 分钟/.../星期 到第 b 分钟/.../星期 这段期间都需要执行;
*/n :表示每 n个 分钟/.../星期 时间间隔执行一次;
a,b,c :表示第 a,b,c 分钟/.../星期 时需要执行,也即指定多个具体时间点;
举个例子来说,比如要指定每日早上7点执行脚本mysh的crontab设置如下:
0 7 * * * /home/admin/mysh >/home/admin/mylog.txt 2>&1
上面说了那么多的常用命令,还有一个功能我们也经常用到,就是定时器、日程表,一般通过crontab来运行;crontab 指定在固定时间或固定间隔执行特定的脚本;crontab的常用参数有如下3个:
-e :执行文字编辑器来设定日程表,一般默认的编辑器是VI;
-r :删除目前所有的日程表;
-l :列出目前所有的日程表;
设置日程表时,需要有固定的格式,共6部分,各部分间用空格间隔;其中第6个部分是要执行的命令,前5个部分是设置执行时间或者时间间隔的,具体取值范围和意义如下:
分钟【0-59】 小时【0-23】 日【1-31】 月份【1-12】 星期【0-6】
在设置的时候可以每项有4种指定方式,如下:
* :表示每 分钟/.../星期 都需要执行;
a-b :表示从第 a 分钟/.../星期 到第 b 分钟/.../星期 这段期间都需要执行;
*/n :表示每 n个 分钟/.../星期 时间间隔执行一次;
a,b,c :表示第 a,b,c 分钟/.../星期 时需要执行,也即指定多个具体时间点;
举个例子来说,比如要指定每日早上7点执行脚本mysh的crontab设置如下:
0 7 * * * /home/admin/mysh >/home/admin/mylog.txt 2>&1
SCP
SCP命令是在linux中用来跨服务器拷贝文件的常用工具,用法非常简单;如下:
scp -options [[user@]host1:]file1 [[user@]host2:]file2
options里面我们一般用得很少,主要用-v来查看命令执行过程中的详细信息,这在复制失败时差错非常有用;
另外一个常用option就是-r,用以深度复制,包括子目录下面的所有目录和文件;
上面的语法可以灵活使用,他可以在host1和host2之间互相copy,而不仅限于从host1中copy文件到host2;
该命令虽然好用,但是由于采用的是ssh协议来对传输内容进行加密,而且在访问另外服务器时需要手工输入密码;下面我们就介绍一种方法来避免每次都输入密码,也即我们常说的 服务期间打通通道;
1、用命令 ssh-keygen -t rsa在serverA中生成密钥对,-t rsa表示采用RSA算法来生成密钥对,也可以用DSA算法来生成,支持的算法集可以参考openssh的文档;至于ssh-keygen的详细命令参数这里不做详细介绍,有兴趣的可以参考man或help;
生成的密钥对默认存放在~/.ssh/目录中,id_rsa.pub中存放公钥,id_rsa存放私钥;
注意:在生成密钥对的时候 系统会提示输入密钥对的密码,这里请直接回车,不要输入密码,否则后面打通通道之后仍然需要密码,只不过是用这里设置的密码而已;
2、将id_rsa.pub中的公钥拷贝出来,追加到serverB中的 ~/.ssh/authorized_keys文件中;
这样就大功告成啦,以后从serverA到serverB就无需每次输入密码了,基于ssh协议的ssh、scp、sftp等命令均会受益;
PS:中间过程中可能需要设置.ssh目录下面的各文件的权限,视具体情况而定;
SCP命令是在linux中用来跨服务器拷贝文件的常用工具,用法非常简单;如下:
scp -options [[user@]host1:]file1 [[user@]host2:]file2
options里面我们一般用得很少,主要用-v来查看命令执行过程中的详细信息,这在复制失败时差错非常有用;
另外一个常用option就是-r,用以深度复制,包括子目录下面的所有目录和文件;
上面的语法可以灵活使用,他可以在host1和host2之间互相copy,而不仅限于从host1中copy文件到host2;
该命令虽然好用,但是由于采用的是ssh协议来对传输内容进行加密,而且在访问另外服务器时需要手工输入密码;下面我们就介绍一种方法来避免每次都输入密码,也即我们常说的 服务期间打通通道;
1、用命令 ssh-keygen -t rsa在serverA中生成密钥对,-t rsa表示采用RSA算法来生成密钥对,也可以用DSA算法来生成,支持的算法集可以参考openssh的文档;至于ssh-keygen的详细命令参数这里不做详细介绍,有兴趣的可以参考man或help;
生成的密钥对默认存放在~/.ssh/目录中,id_rsa.pub中存放公钥,id_rsa存放私钥;
注意:在生成密钥对的时候 系统会提示输入密钥对的密码,这里请直接回车,不要输入密码,否则后面打通通道之后仍然需要密码,只不过是用这里设置的密码而已;
2、将id_rsa.pub中的公钥拷贝出来,追加到serverB中的 ~/.ssh/authorized_keys文件中;
这样就大功告成啦,以后从serverA到serverB就无需每次输入密码了,基于ssh协议的ssh、scp、sftp等命令均会受益;
PS:中间过程中可能需要设置.ssh目录下面的各文件的权限,视具体情况而定;