巧用1
一句话修改或者给用户设置密码,并且防止历史命令记住设置的密码
echo "qqxde:ioj123"|passwd --stdin Dicky && history -c
巧用2
用下面的命令找出僵死进程
命令注解:
-A 参数列出所有进程
-o 自定义输出字段 我们设定显示字段为 stat(状态), ppid(进程父id), pid(进程id),cmd(命令)这四个参数
-C 用来指定所执行的命令名称,你这里也就是让ps仅仅显示php命令所产生的进程的信息
最近又遇到了个问题,一台服务器上产生了100多少僵死进程,而且每一僵死进程的父进程都不一样,如果用上面的方法,一条一条的杀,那还不得累死我啊。
那么就应该想一条简单的命令,直接查找僵死进程,然后将父进程杀死~
ps -A -o stat,ppid,pid,cmd | grep -e '^[Zz]' | awk '{print $2}' | xargs kill -9
巧用三:
时间与时间戳的转换
[root@iZ940ao463eZ ~]# date -d "2014-09-10" +%s [root@iZ940ao463eZ ~]# date -d @ '+%Y-%m-%d'
--
[root@iZ940ao463eZ ~]#
巧用四
在linux下使用python增加补全功能,脚本如下:
#!/usr/bin/env python
# coding: UTF-
# python tab file import sys
import readline
import rlcompleter
import atexit
import os
#tab completion
readline.parse_and_bind('tab: complete')
#history file
histfile = os.path.join(os.environ['HOME'],'.pythonhistory')
try:
readline.read_history_file(histfile)
except IOError:
pass
atexit.register(readline.write_history_file,histfile) del os,histfile,readline,rlcompleter
将上面这段代码插入到python的环境变量,我的路径如下
>>>
>>> sys.path
['', '/usr/lib64/python26.zip', '/usr/lib64/python2.6', '/usr/lib64/python2.6/plat-linux2', '/usr/lib64/python2.6/lib-tk', '/usr/lib64/python2.6/lib-old', '/usr/lib64/python2.6/lib-dynload', '/usr/lib64/python2.6/site-packages', '/usr/lib/python2.6/site-packages', '/usr/lib/python2.6/site-packages/setuptools-0.6c11-py2.6.egg-info']
>>>
将脚本考到目录下
cp tab.py /usr/lib64/python2./site-packages/
测试:
>>> import tab
>>> import json
>>> json.
json.JSONDecoder( json.__doc__ json.__new__( json.__sizeof__( json.dump(
json.JSONEncoder( json.__file__ json.__package__ json.__str__( json.dumps(
json.__all__ json.__format__( json.__path__ json.__subclasshook__( json.encoder
json.__author__ json.__getattribute__( json.__reduce__( json.__version__ json.load(
json.__class__( json.__hash__( json.__reduce_ex__( json._default_decoder json.loads(
json.__delattr__( json.__init__( json.__repr__( json._default_encoder json.scanner
json.__dict__ json.__name__ json.__setattr__( json.decoder
>>> json.
带宽:
网络服务商声称光纤的速度为“ 3M”,一般的情况下,“3M”实际上就是3000Kbit/s(按千进位计算)这就存在一个换算的问题。
Byte和bit是不同的。1Byte=8bit.而我们常说的下载速度都指的是Byte/s 因此电信所说的“3M”经过还换算后就成为了(3000/8)KByte/s=375KByte/s这样我们平时下载速度最高就是375KByte/s常常表示375KB/S.
3M是3Mbps的缩写,M表示10的6次方,3M全部含义是3000000bit/s = 3000K bit/s,364K/s 是364K Bit/s的缩写,1 Bit = 8bit,所以3Mbps=3000K/8 Bit/s=375K/s,
巧记五
cat -v install.sh|tr -d "^M" v 去除空格
巧用六根据inode删除文件
find ./ -inum 919306 -exec rm -i {} \;
巧用七
pip的安装
cat pip_an.sh
#!/bin/bash
wget http://pypi.python.org/packages/source/s/setuptools/setuptools-0.6c11.tar.gz
tar zxvf setuptools-.6c11.tar.gz
cd setuptools-.6c11
python setup.py build
python setup.py install
wget "https://pypi.python.org/packages/source/p/pip/pip-1.5.4.tar.gz#md5=834b2904f92d46aaa33326"
tar -xzvf pip-1.5..tar.gz
cd pip-1.5.
python setup.py install
巧用八
Linux下文件的特殊权限
setcap
详情:
https://wiki.archlinux.org/index.php/Capabilities_(%E7%AE%80%E4%BD%93%E4%B8%AD%E6%96%87)
http://kibazen.cn/2016/linux-file-specical-permission/
知识记录
linux版本,包版本
带i386、i486、i586、i686、x86等的一般是32位的,带x64、amd64、x86_64、x86-64等的一般是64位的
知识补充:
Linux的/etc/services文件简析
主要在tcpdump中,解析端口号用的到
cat /etc/services|grep xxx
/etc/services文件是记录网络服务名和它们对应使用的端口号及协议。文件中的每一行对应一种服务,它由4个字段组成,中间用TAB或空格分隔,分别表示“服务名称”、“使用端口”、“协议名称”以及“别名”。
如图所示:
总结:/etc/services文件包含了服务名和端口号之间的映射,很多的系统程序要使用这个文件。一般情况下,不要修改该文件的内容,因为这些设置都是Internet标准的设置。一旦修改,可能会造成系统冲突,使用户无法正常访问资源。Linux系统的端口号的范围为0–65535,不同范围有不同的意义。
- 0 不使用
- 1--1023 系统保留,只能由root用户使用
- 1024---4999 由客户端程序*分配
- 5000---65535 由服务器端程序*分配