《linux、php常用命令》

LINUX不常用命令
1. sysctl
查看网络发送缓存大小
#sysctl -a | grep wmem
net.ipv4.tcp_wmem = 4096        16384   65536
net.core.wmem_default = 103424
net.core.wmem_max = 103424
vm.lowmem_reserve_ratio = 256   256     32
net.ipv4.tcp_wmem = 4096 16384 65536
第一个值是socket 的发送缓存区分配的最少字节数;
第二个值是默认值( 该值会被net.core.wmem_default 覆盖), 缓存区在系统负载不重的情况下可以增长到这个值;
第三个值是发送缓存区空间的最大字节数( 该值会被net.core.wmem_max 覆盖 )。
根据实际测试, 如果手工更改了net.ipv4.tcp_wmem 的值, 则会按更改的值来运行, 否则在默认情况下, 协议栈通常是按net.core.wmem_default 和net.core.wmem_max 的值来分配内存的。
 
2. mii-tool
显示网卡工作状态全双工/半双工模式
#mii-tool
eth0: no autonegotiation, 10baseT-HD, link ok
eth1: negotiated 100baseTx-FD flow-control, link
 
3. ethtool
设置网卡全双/半双工模式
#ethtool eth0
Settings for eth0:
        Supported ports: [ TP MII ]
        Supported link modes:   10baseT/Half 10baseT/Full
                                100baseT/Half 100baseT/Full
        Supports auto-negotiation: Yes
        Advertised link modes:  10baseT/Half 10baseT/Full
                                100baseT/Half 100baseT/Full
        Advertised auto-negotiation: Yes
        Speed: 100Mb/s
        Duplex: Full
        Port: MII
        PHYAD: 9
        Transceiver: external
        Auto-negotiation: on
        Link detected: yes
要保存修改的设置,Fedora下可以修改配置文件。
比如修改eth0的ethtool参数:
编辑 /etc/sysconfig/network-scripts/ifcfg-eth0, 加入:
ETHTOOL_OPTS=”speed 100 duplex full autoneg off”
 
 
3. nslookup
名称服务器查找(Name Server Lookup),用来查找DNS服务器上的DNS记录。这个命令可以指定查询的类型,可以查到DNS记录的生存时间,还可以指定使用哪个DNS服务器进行解释。
 
4. dig
向DNS服务器发送named查询,dig可以查询单一和多个域名服务器。
LINUX常用命令
1、cd命令
这是一个非常基本,也是大家经常需要使用的命令,它用于切换当前目录,它的参数是要切换到的目录的路径,可以是绝对路径,也可以是相对路径。如:
  1. cd /root/Docements # 切换到目录/root/Docements  
  2. cd ./path          # 切换到当前目录下的path目录中,“.”表示当前目录    
  3. cd ../path         # 切换到上层目录中的path目录中,“..”表示上一层目录  
2、ls命令
这是一个非常有用的查看文件与目录的命令,list之意,它的参数非常多,下面就列出一些我常用的参数吧,如下:

  1. -l :列出长数据串,包含文件的属性与权限数据等  
  2. -a :列出全部的文件,连同隐藏文件(开头为.的文件)一起列出来(常用)  
  3. -d :仅列出目录本身,而不是列出目录的文件数据  
  4. -h :将文件容量以较易读的方式(GB,kB等)列出来  
  5. -R :连同子目录的内容一起列出(递归列出),等于该目录下的所有文件都会显示出来  
注:这些参数也可以组合使用,下面举两个例子:

  1. ls -l #以长数据串的形式列出当前目录下的数据文件和目录  
  2. ls -lR #以长数据串的形式列出当前目录下的所有文件  
3、grep命令
该命令常用于分析一行的信息,若当中有我们所需要的信息,就将该行显示出来,该命令通常与管道命令一起使用,用于对一些命令的输出进行筛选加工等等,它的简单语法为

  1. grep [-acinv] [--color=auto] '查找字符串' filename  
它的常用参数如下:
4、find命令
find是一个基于查找的功能非常强大的命令,相对而言,它的使用也相对较为复杂,参数也比较多,所以在这里将给把它们分类列出
5、cp命令
该命令用于复制文件,copy之意,它还可以把多个文件一次性地复制到一个目录下,它的常用参数如下:
  1. -a :将文件的特性一起复制  
  2. -p :连同文件的属性一起复制,而非使用默认方式,与-a相似,常用于备份  
  3. -i :若目标文件已经存在时,在覆盖时会先询问操作的进行  
  4. -r :递归持续复制,用于目录的复制行为  
  5. -u :目标文件与源文件有差异时才会复制  
例如 :
  1. cp -a file1 file2 #连同文件的所有特性把文件file1复制成文件file2  
  2. cp file1 file2 file3 dir #把文件file1、file2、file3复制到目录dir中  
  1. -a :将binary文件以text文件的方式查找数据  
  2. -c :计算找到‘查找字符串’的次数  
  3. -i :忽略大小写的区别,即把大小写视为相同  
  4. -v :反向选择,即显示出没有‘查找字符串’内容的那一行  
  5. # 例如:  
  6. # 取出文件/etc/man.config中包含MANPATH的行,并把找到的关键字加上颜色  
  7. grep --color=auto 'MANPATH' /etc/man.config  
  8. # 把ls -l的输出中包含字母file(不区分大小写)的内容输出  
  9. ls -l | grep -i file  
6、mv命令
该命令用于移动文件、目录或更名,move之意,它的常用参数如下:

  1. -f :force强制的意思,如果目标文件已经存在,不会询问而直接覆盖  
  2. -i :若目标文件已经存在,就会询问是否覆盖  
  3. -u :若目标文件已经存在,且比目标文件新,才会更新  
注:该命令可以把一个文件或多个文件一次移动一个文件夹中,但是最后一个目标文件一定要是“目录”。
例如:
  1. mv file1 file2 file3 dir # 把文件file1、file2、file3移动到目录dir中  
  2. mv file1 file2 # 把文件file1重命名为file2 
7、rm命令
该命令用于删除文件或目录,remove之间,它的常用参数如下:

  1. -f :就是force的意思,忽略不存在的文件,不会出现警告消息  
  2. -i :互动模式,在删除前会询问用户是否操作  
  3. -r :递归删除,最常用于目录删除,它是一个非常危险的参数  
例如:

  1. rm -i file # 删除文件file,在删除之前会询问是否进行该操作  
  2. rm -fr dir # 强制删除目录dir中的所有文件  
8、ps命令
该命令用于将某个时间点的进程运行情况选取下来并输出,process之意,它的常用参数如下:
  1. -A :所有的进程均显示出来  
  2. -a :不与terminal有关的所有进程  
  3. -u :有效用户的相关进程  
  4. -x :一般与a参数一起使用,可列出较完整的信息  
  5. -l :较长,较详细地将PID的信息列出  
9、kill命令
该命令用于向某个工作(%jobnumber)或者是某个PID(数字)传送一个信号,它通常与ps和jobs命令一起使用
10、killall命令
该命令用于向一个命令启动的进程发送一个信号
11、file命令
该命令用于判断接在file命令后的文件的基本数据,因为在Linux下文件的类型并不是以后缀为分的,所以这个命令对我们来说就很有用了,它的用法非常简单,基本语法如下:

  1. file filename  
  2. #例如:  
  3. file ./test  
12、tar命令
该命令用于对文件进行打包,默认情况并不会压缩,如果指定了相应的参数,它还会调用相应的压缩程序(如gzip和bzip等)进行压缩和解压。它的常用参数如下:

  1. -c :新建打包文件  
  2. -t :查看打包文件的内容含有哪些文件名  
  3. -x :解打包或解压缩的功能,可以搭配-C(大写)指定解压的目录,注意-c,-t,-x不能同时出现在同一条命令中  
  4. -j :通过bzip2的支持进行压缩/解压缩  
  5. -z :通过gzip的支持进行压缩/解压缩  
  6. -v :在压缩/解压缩过程中,将正在处理的文件名显示出来  
  7. -f filename :filename为要处理的文件  
  8. -C dir :指定压缩/解压缩的目录dir  
上面的解说可以已经让你晕过去了,但是通常我们只需要记住下面三条命令即可:

  1. 压缩:tar -jcv -f filename.tar.bz2 要被处理的文件或目录名称  
  2. 查询:tar -jtv -f filename.tar.bz2  
  3. 解压:tar -jxv -f filename.tar.bz2 -C 欲解压缩的目录 
13、cat命令
该命令用于查看文本文件的内容,后接要查看的文件名,通常可用管道与more和less一起使用,从而可以一页页地查看数据。例如:

  1. cat text | less # 查看text文件中的内容  
  2. # 注:这条命令也可以使用less text来代替 
14、chgrp命令
该命令用于改变文件所属用户组,它的使用非常简单,
15、chown命令
该命令用于改变文件的所有者,与chgrp命令的使用方法相同,只是修改的文件属性不同,不再详述。
16、chmod命令
该命令用于改变文件的权限,
18、vim命令
该命令主要用于文本编辑,它接一个或多个文件名作为参数,如果文件存在就打开,如果文件不存在就以该文件名创建一个文件。vim是一个非常好用的文本编辑器,它里面有很多非常好用的命令,在这里不再多说。你可以从这里下载 vim常用操作 的详细说明。
20、time命令
该命令用于测算一个命令(即程序)的执行时间。它的使用非常简单,就像平时输入命令一样,
PHP常用命令
   数组函数  
函数名 描述 实例 输入 输出 备注
数组创建:          
array() 生成一个数组 $a=array("Dog","Cat","Horse");
print_r($a);
数组值或,键=>值 一个数组型变量  
array_combine() 生成一个数组,用一个数组的值作为键名,另一个数组值作为值 $a1=array("a","b","c","d");
$a2=array("Cat","Dog","Horse","Cow");
print_r(array_combine($a1,$a2));
$a1为提供键,$a2提供值 合成后的数组  
range() 创建并返回一个包含指定范围的元素的数组。 $number = range(0,50,10);
print_r ($number);
0是最小值,50是最大值,10是步长 合成后的数组  
compact() 创建一个由参数所带变量组成的数组 $firstname = "Peter";
$lastname = "Griffin";
$age = "38";
$result = compact("firstname", "lastname", "age");
print_r($result);
变量或数组 返回由变量名为键,变量值为值的数组,变量也可以为多维数组.会递归处理  
array_fill() 用给定的填充(值生成)数组 $a=array_fill(2,3,"Dog");
print_r($a);
2是键,3是填充的数量,'Dog'为填充内容 返回完成的数组  
数组合并和拆分:          
array_chunk() 把一个数组分割为新的数组块 $a=array("a"=>"Cat","b"=>"Dog","c"=>"Horse","d"=>"Cow");
print_r(array_chunk($a,2));
一个数组 分割后的多维数组,规定每个新数组包含2个元素  
array_merge() 把两个或多个数组合并为一个数组。 $a1=array("a"=>"Horse","b"=>"Dog");
$a2=array("c"=>"Cow","b"=>"Cat");
print_r(array_merge($a1,$a2));
两个数组 返回完成后的数组  
array_slice() 在数组中根据条件取出一段值,并返回。 $a=array(0=>"Dog",1=>"Cat",2=>"Horse",3=>"Bird");
print_r(array_slice($a,1,2));
一个数组 1为从'Cat'开始,2为返回两个元素  
数组比较:          
array_diff() 返回两个数组的差集数组 $a1=array(0=>"Cat",1=>"Dog",2=>"Horse");
$a2=array(3=>"Horse",4=>"Dog",5=>"Fish");
print_r(array_diff($a1,$a2));
两个或多个数组 返回'Cat',$a1与$a2的不同之处  
array_intersect() 返回两个或多个数组的交集数组     返回'Dog'和'Horse',$a1与$a2的相同之处  
数组查找替换:          
array_search() 在数组中查找一个键值 $a=array("a"=>"Dog","b"=>"Cat","c"=>"Horse");
echo array_search("Dog",$a);
一个数组 成功返回键名,失败返回false 等同于in_array()
array_splice() 把数组中一部分删除用其他值替代 $a1=array(0=>"Dog",1=>"Cat",2=>"Horse",3=>"Bird");
$a2=array(0=>"Tiger",1=>"Lion");
array_splice($a1,0,2,$a2);
print_r($a1);
一个或多个数组 $a1被移除的部分由$a2补全 将原数组替换,注意替换后数组中键名不保留
array_sum() 返回数组中所有值的总和 $a=array(0=>"5",1=>"15",2=>"25");
echo array_sum($a);
一个数组 返回和  
in_array() 在数组中搜索给定的值,区分大小写 $people = array("Peter", "Joe", "Glenn", "Cleveland");
if (in_array("Glenn",$people){
echo "Match found";}else{
echo "Match not found";}
需要搜索的值|数组 true/false  
array_key_exists() 判断某个数组中是否存在指定的 key   需要搜索的键名|数组    
数组指针操作:          
key() 返回数组内部指针当前指向元素的键名        
current() 返回数组中的当前元素(单元)。       别名pos()
next() 把指向当前元素的指针移动到下一个元素的位置,并返回当前元素的值
prev() 把指向当前元素的指针移动到上一个元素的位置,并返回当前元素的值
end() 将数组内部指针指向最后一个元素,并返回该元素的值(如果成功)
reset() 把数组的内部指针指向第一个元素,并返回这个元素的值
list() 用数组中的元素为一组变量赋值 $my_array=array("Dog","Cat","Horse");
list($a, $b, $c) = $my_array;
$a, $b, $c为需要赋值的变量 变量分别匹配数组中的值  
array_shift() 删除数组中的第一个元素,并返回被删除元素的值 $a=array("a"=>"Dog","b"=>"Cat","c"=>"Horse");
echo array_shift($a);
print_r ($a);
     
array_unshift() 在数组开头插入一个或多个元素 $a=array("a"=>"Cat","b"=>"Dog");
array_unshift($a,"Horse");
print_r($a);
     
array_push() 向数组最后压入一个或多个元素 $a=array("Dog","Cat");
array_push($a,"Horse","Bird");
print_r($a);
目标数组|需要压入的值 返回新的数组  
array_pop() 删除数组中的最后一个元素 $a=array("Dog","Cat","Horse");
array_pop($a);
print_r($a);
$a为目标数组 返回数组剩余元素 可赋给一个变量输出被弹出的元素
数组键值操作:          
shuffle() 将数组打乱,保留键名 $my_array = array("a" => "Dog", "b" => "Cat");
shuffle($my_array);
print_r($my_array);
一个或多个数组 顺序打乱后的数组 打乱顺序后键名不会有变化
count() 计算数组中的单元数目或对象中的属性个数 $people = array("Peter", "Joe", "Glenn", "Cleveland");
$result = count($people);
echo $result;
数组 输出元素个数  
array_flip() 返回一个键值反转后的数组 $a=array(0=>"Dog",1=>"Cat",2=>"Horse");print_r(array_flip($a));   返回完成后的数组  
array_keys() 返回数组所有的键,组成一个数组 $a=array("a"=>"Horse","b"=>"Cat","c"=>"Dog");
print_r(array_keys($a));
  返回由键名组成的数组  
array_values() 返回数组中所有值,组成一个数组 同上   返回由键值组成的数组  
array_reverse() 返回一个元素顺序相反的数组 同上   元素顺序相反的一个数组,键名和键值依然匹配  
array_count_values() 统计数组中所有的值出现的次数 $a=array("Cat","Dog","Horse","Dog");
print_r(array_count_values($a));
  原键值为新键名,次数为新键值  
array_rand() 从数组中随机抽取一个或多个元素,注意是键名!!! $a=array("a"=>"Dog","b"=>"Cat","c"=>"Horse");
print_r(array_rand($a,1));
$a为目标数组,1为抽取第几个元素的键名 返回第1个元素的键名b  
each() 从数组传回key/value        
array_unique() 删除重复值,返回剩余数组 $a=array("a"=>"Cat","b"=>"Dog","c"=>"Cat");
print_r(array_unique($a));
数组 返回无重复值数组,键名不变 当几个数组元素的值相等时,只保留第一个元素,其他的元素被删除
数组排序:          
sort() 按升序对给定数组的值排序,不保留键名 $my_array = array("a" => "Dog", "b" => "Cat", "c" => "Horse");
sort($my_array);
print_r($my_array);
  true/false 对数组元素进行重排,同时改变键名
rsort() 对数组逆向排序,不保留键名       对数组元素进行重排,同时改变键名
asort() 对数组排序,保持索引关系       对数组进行排序,保留原来的索引或键
arsort() 对数组逆向排序,保持索引关系        
ksort() 按键名对数组排序       对键名排序,保留键值对应关系
krsort() 将数组按照键逆向排序       保留原来的键
natsort() 用自然顺序算法对数组中的元素排序       对值进行自然排序,保留键值对应关系
natcasesort() 自然排序,不区分大小写       不区分大小写的对值进行自然法排序,保持键值对应关系

去空格或或其他字符
trim() 删除字符串两端的空格或其他预定义字符
rtrim() 删除字符串右边的空格或其他预定义字符
chop() rtrim()的别名
str_pad() 把字符串填充为指定的长度
str_repeat() 重复使用指定字符串
str_split() 把字符串分割到数组中
wordwrap()
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值