本文共 8021 字,大约阅读时间需要 26 分钟。
Linux下用vim打开配置文件乱码,在终端输入:“LANG=”即可。
查看端口是否被占用:
netstat -anp | grep port
netstat -ltn
lsof -i:port
$# 是传给脚本的参数个数
$0 是脚本本身的名字
$1 是传递给该shell脚本的第一个参数
$2 是传递给该shell脚本的第二个参数
$@ 是传给脚本的所有参数的列表
$* 是以一个单字符串显示所有向脚本传递的参数,与位置变量不同,参数可超过个
$$ 是脚本运行的当前进程ID号
$? 是显示最后命令的退出状态,0表示没有错误,其他表示有错误
find . -type f -name "*.sh" -type 查找某一类型的文件,诸如:b - 块设备文件。d - 目录。c - 字符设备文件。p - 管道文件。l - 符号链接文件。f - 普通文件。
:n,$s/vivian/sky/g 替换第 n 行开始到最后一行中每一行所有 vivian 为 sky
chown 用户名 文件路径
chmod 777 test
adduser password
在PC机器上不能进行点播操作(只是针对没有添加域名解析的PC机器),但是在别的电脑上可以,那么就需要把别人的C:\Windows\System32\drivers\etc\hosts 覆盖自己的这个目录下的hosts文件。
12.C++中经常有代码后面加了”\” 表示换行,说明下面一句和上面是同一行的。
du –sh 查看文件大小。
shell 2>&1: & 1 更准确的说应该是文件描述符1, 而1一般代表的就是STDOUT_FILENO,实际上这个操作就是一个dup2(2)调用.他标准输出到all_result,然后复制标准输出到文件描述符2(STDERR_FILENO),其后果就是文件描述符1和2指向同一个文件表项,也可以说错误的输出被合并了.其中0表示键盘输入 1表示屏幕输出2表示错误输出.把标准出错重定向到标准输出,然后扔到/DEV/NULL下面去。通俗的说,就是把所有标准输出和标准出错都扔到垃圾桶里面。
try_files $uri $uri/ /index.php?q=$uri&$args;
按顺序检查文件是否存在,返回第一个找到的文件。结尾的斜线表示为文件夹 -$uri/。如果所有的文件都找不到,会进行一个内部重定向到最后一个参数。
date +%s 可以显示UTC的大整数时间相当于OS:Millionseconds()。
date -d @1411266453 可以将时间转换成当前的年月日格式。
date -d "1970-01-01 UTC 1411261790 seconds" 将一个随意的UTC时间转换为当前时间。
ulimit -c unlimited 可以使系统产生core文件
“grep -v #” 获取不包含#号的所有行,其中“\”是转译字符,
cut -d: -f1 获取的文本以“:”为分隔符,并且获取第一区域的值。
成功,返回0;
失败,文件存在,模板字符串不存在,返回1;
失败,文件不存在,返回2;
try_files $uri $uri/ /index.php?q=$uri&$args;
按顺序检查文件是否存在,返回第一个找到的文件。结尾的斜线表示为文件夹 -$uri/。如果所有的文件都找不到,会进行一个内部重定向到最后一个参数。
umout .tmp可以解决因为在工程挺值前删除文件,造成的原有文件夹不能删除的问题。
相关函数:fstat, lstat, chmod, chown, readlink, utime
头文件:#include <sys/stat.h> #include <unistd.h>
定义函数:int stat(const char file_name, struct stat buf);
用来将参数file_name 所指的文件状态, 复制到参数buf 所指的结构中,函数的返回值可以用于判断文件是否存在。
int fd = inotify_init ();
int wd = inotify_add_watch (fd, path, mask);
int ret = inotify_rm_watch (fd, wd);
最后,再举几个不是很恰当的例子来说明这四个IO Model:
有A(同步阻塞),B(同步非阻塞),C(异步阻塞),D(异步非阻塞)四个人在钓鱼:
A用的是最老式的鱼竿,所以呢,得一直守着,等到鱼上钩了再拉杆;
B的鱼竿有个功能,能够显示是否有鱼上钩,所以呢,B就和旁边的MM聊天,隔会再看看有没有鱼上钩,有的话就迅速拉杆;
C用的鱼竿和B差不多,但他想了一个好办法,就是同时放好几根鱼竿,然后守在旁边,一旦有显示说鱼上钩了,它就将对应的鱼竿拉起来;
D是个有钱人,干脆雇了一个人帮他钓鱼,一旦那个人把鱼钓上来了,就给D发个短信。
command参数是一个字符串指针,指向的是一个以null结束符结尾的字符串,这个字符串包含一个shell命令.这个命令被送到/bin/sh以-c参数执行,即由shell来执行.type参数也是一个指向以null结束符结尾的字符串的指针,这个字符串必须是'r'或者'w’来指明是读还是写.
popen()函数的返回值是一个普通的标准I/O流,它只能用pclose()函数来关闭,而不是fclose().函数.向这个流的写入被转化为对command命令的标准输入;而command命令的标准输出则是和调用popen(),函数的进程相同,除非这个被command命令自己改变.相反的,读取一个“被popen了的”流,就相当于读取command命令的标准输出,而command的标准输入则是和调用popen,函数的进程相同.
注意,popen函数的输出流默认是被全缓冲的.
pclose函数等待相关的进程结束并返回一个command命令的退出状态,就像wait4函数一样方
可以用来在程序中返回命令结果:popen( "ls -l", "r" );可以返回文件列表;
popen( "du -sk", "r" )可以用来返回剩余空间。
libaio工作流程:
io_prep_pread()/io_prep_pwrite() 设置读写操作参数
io_submit() 提交
io_getevents() 检查结果
uname –a 查看系统所有信息,-r查看所有,如果是红帽子,可以用cat /etc/issue
匹配所有空行:^[ \t]*$[\n\r]
解压命令 tar -zvxf ***
通过ulimit -n,我们可以得到一个进程所能够打开的fd的最大数.
pwdx pid用来查看正在运行的线程所在的目录
stun服务器的启动方法:./server -v -b -h 121.14.85.205 -a 121.14.85.206
pstack可以用来查看Linux程序运行过程中的堆栈。
rpm -qa|grep -i mysql用来检查是否已经安装了mysql
rm -f /etc/my.cnf 删除mysql其他路径下的配置和数据文件
rm -rf /var/lib/mysql删除mysql其他路径下的配置和数据文件
mysql> set GLOBAL max_connections=300;设置mysql的最大连接数
mysqladmin -uroot -pcoship variables检查mysql的最大连接数。
tar -xzvf Redis_2.4.7.tar.gz解压缩包。
getenforce 检查seLinux的状态
vi /etc/selinux/config在配置中关闭seLinux
setenforce 0使上面的配置生效。
service iptables status检查防火墙状态
chkconfig iptables off关闭防火墙,重启后生效
service iptables stop 关闭防火墙及时生效 iptables –F也可以生效
rpm -ivh vsftpd-2.0.5-16.el5_4.1.x86_64.rpm强制安装vsftp
/sbin/chkconfig --list vsftpd检查ftp的启动状态
/sbin/chkconfig --level 2345 vsftpd on开启或者关闭ftp的某个状态
adduser -g ftp -s /sbin/nologin -d /mpeg cdnftper添加ftp用户
chkconfig --list mysql检查mysql是否随机启动
chkconfig --add mysql让mysql随机启动。
tcpdump -i eth0 -t tcp -s 60000 -w diaoxian.cap 抓包
查看电脑配置
free -m 查看内存
fdisk -l查看硬盘分区
df -h 查看挂载目录
ifconfig查看网卡信息
ethtool eth0查看详西的网卡工作模式
lspic列出所有芯片信息,比如声卡,显卡,网卡等。
cat /etc/issue 查看当前系统的发布版本
uname –a查看当前系统的内核信息
rpm -e --nodeps mysql-libs-5.1.73-3.el6_5.x86_64强制卸载mysql
select table_name,table_rows from tables where TABLE_SCHEMA = 'olaj' order by table_rows desc;
netstat –tnl | grep 3306
%s/((http|ftp|https)://)(([a-zA-Z0-9.-]+.[a-zA-Z]{2,6})|([0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}))(:[0-9]{1,4})*(/[a-zA-Z0-9\&%./-~-]*)?/\ / 匹配链接。
grep -r -n '._LOG.[LoadXML|parse]' ./ grep的用法,-n表示行号, -i表示忽略大小写。
rm -rf /var/log/*.gz
rm -rf /var/log/*.1
echo "" > /var/log/dmesg
echo "" > /var/log/kern.log
echo "" > /var/log/messages
echo "" > /var/log/syslog
du -lh --max-depth=1
g++ hello.cpp -save-temps 可以保存编译时产生的临时文件。
添加网络邻居:netsh -c "i i" add neighbors 13 "172.30.25.246" "b8-ca-3a-f2-f4-c8"
查看当前网络的发送接收:dstat
71-73 略
/etc/passwd /etc/shadow存放Linux系统的用户和密码
netstat -n | awk '/^tcp/ {++y[$NF]} END {for(w in y) print w, y[w]} 统计所有TCP链接的状态数
CenterOS 设置防火墙firewall-cmd --zone=public --add-port=5000/tcp --permanent
firewall-cmd –reload转载于:https://blog.51cto.com/qibingtuan/2134739