后台运行

python的输出有缓冲,导致日志文件并不能够马上看到输出
-u参数,使得python不启用缓冲
> 重定向到nohup.out
nohup python3 -u xxxx.py > nohup.out &

批量移动/删除

可以解决移动文件数目过大的问题(Argument list too long)
find test/ -name "*.jpg" -exec cp {} train \;
find test/ -name "*.jpg" | xargs -i rm {}

查看端口

  • netstat -ntlp # 简化
  • netstat -lnp|grep 88 # 详细
  • netstat -anp # 可以看到进程编号信息
  • firewall-cmd --query-port=666/tcp # 查看端口是否开启成功 成功返回yes

firewalld的基本使用

  • 启动: systemctl start firewalld
  • 关闭: systemctl stop firewalld
  • 查看状态: systemctl status firewalld
  • 开机禁用 : systemctl disable firewalld
  • 开机启用 : systemctl enable firewalld
  • 查看一个服务:systemctl status jenkins.service

开启一个端口

  • 添加:firewall-cmd --zone=public --add-port=80/tcp --permanent (--permanent永久生效,没有此参数重启后失效)
  • 重新载入:firewall-cmd --reload
  • 查看:firewall-cmd --zone=public --query-port=80/tcp
  • 删除:firewall-cmd --zone=public --remove-port=80/tcp --permanent

自启动

/etc/rc.d/init.d # 存放着自启动脚本 ,优先级比下面的高
/lib/systemd/system/  # 存放着自启动脚本
/etc/rc.local  # 直接加入即可

日志过滤

# more 分页查询
cat -n test.log |grep "地形" |more

crontab

, 和数组类似,指定数字,/ 每过多少个数字,- 从X到Z,* 取值范围内的所有数字
每五分钟执行      */5 * * * *
每小时执行        0 * * * *
每天执行          0 0 * * *
每周执行          0 0 * * 0
每月执行          0 0 1 * *
每年执行          0 0 1 1 *

curl

# 获取全部response信息
curl -i www.baidu.com

# 只返回response的头信息
curl -I www.baidu.com

# json
curl url -X POST -H "Content-Type:application/json" -d '{"parameterName1":"parameterValue1","parameterName2":"parameterValue2"}'

# 参数
curl url -X POST -d "parameterName1=parameterValue1&parameterName2=parameterValue2"

# 文件
curl url -F "file=@/Users/local/imgs/my.png"  -v

vim insert VISUAL模式

普通模式下输入“:set mouse-=a”,有效

权限

[20180412134052927.png]()

  • r可读,w可写,x可执行
  • + 表示增加权限,如u+x, u+r, u+w, g+w, g+r, o+r, a+r等
  • - 表示取消权限,如u-x, u-r, u-w, g-w, g-r, o-r, a-r等
  • = 表示赋予给定权限,并取消其他所有权限(如果有的话,如原来u是rwx,设置u=r,u就剩r)
  • chown/chmod
chown # 对文件夹或文件的所属权限变更
chmod # 直接变更

远程拷贝

# 文件
scp local_file remote_username@remote_ip:remote_folder 
# 目录
scp -r local_folder remote_username@remote_ip:remote_folder 

管道和数量

# 统计数量 可以统计管道过滤的数量和文件的行数
wc -l 

tail/head(语法一致)

# 会把文件里的最尾部的内容显示在屏幕上,并且不断刷新
tail -f notes.log
tail  -n  10  test.log

添加环境变量

# 临时
export PATH=$PATH:/usr/local/webserver/php/bin  
# 永久
vi /etc/profile  
PATH=$PATH:/usr/local/webserver/php/bin:/usr/local/webserver/mysql/bin
export PATH
source /etc/profile  # 编译一下
# 查看
echo $PATH

后台运行

nohup commond & 表示Ctrl+C也不会使其中断
&  表示任务在后台执行,如要在后台运行redis-server,则有  redis-server &
&& 表示前一条命令执行成功时,才执行后一条命令 ,如 echo '1‘ && echo '2'    
| 表示管道,上一条命令的输出,作为下一条命令参数,如 echo 'yes' | wc -l
|| 表示上一条命令执行失败后,才执行下一条命令,如 cat nofile || echo "fail"

管理员

su username # 切换用户
su  # 输入root账户的密码后切换到root身份,无时间限制
sudo su # 效果同su,只是不需要root的密码,而需要当前用户的密码

查看系统信息

arch  # 用于centos查看32位还是64位
dpkg  #用于查看 Debian/ Ubuntu 操作系统是 32 位还是 64 位
cat /etc/issue  # 查看系统架构   # centos/Debian/Ubuntu
getconf LONG_BIT # 直接返回操作系统是32还是64
file /lib/systemd/systemd # 输出详细的具体信息

安装

apt install package   # 乌班图
yum install  package  # centos

下载

wget  # 直接下载
wget -b # 后台下载

netstat命令

netstat -ntlp # 仅显示端口
netstat -anp # 查看防火墙端口

ps/kill

ps -A 显示进程信息
ps -u root //显示root进程用户信息

运行级别

# 0 - 停机(千万别把initdefault设置为0,否则系统永远无法启动)
# 1 - 单用户模式
# 2 - 多用户,没有 NFS
# 3 - 完全多用户模式(标准的运行级)
# 4 – 系统保留的
# 5 - X11 (x window)
# 6 - 重新启动 (千万不要把initdefault 设置为6,否则将一直在重启 )

重定向

#一个>表示覆盖写,两个>>表示追加写
ls -l > list.txt  # ls -l 的结果保存在了list.txt文件中

开机/关机

重启命令:
    1、reboot  / init6
    2、shutdown -r now 立刻重启(root用户使用)
    3、shutdown -r 10 过10分钟自动重启(root用户使用) 
    4、shutdown -r 20:35 在时间为20:35时候重启(root用户使用)
    如果是通过shutdown命令设置重启的话,可以用shutdown -c命令取消重启
    
关机命令:
    1、halt / init 0 立刻关机  
    2、poweroff  立刻关机
    3、shutdown -h now 立刻关机(root用户使用)
    4、shutdown -h 10 10分钟后自动关机
    如果是通过shutdown命令设置关机的话,可以用shutdown -c命令取消重启

返回

./  #指在当前目录
../ #指返回上一级目录

管道/查看进程

grep a *.txt  # 模糊查询
ps -ef | grep mysql  # 组合使用-->查看进程

进入

cd -  # 返回上次的工作目录
cd ~ #进入当前用户
cd / #进入根目录

磁盘

  • df -kh #查看磁盘大小

目录

pwd   #显示当前目录
dirs #显示当前目录
tree  # 目录树
.
├── jjjj
│   └── j.txt
└── kkk

查看

ls -a # 显示隐藏
ls -l  # 单列格式输出详细信息,简写ll
cat  # 查看文件内容的全部
tail/head # 查看指定的行
tail -f filename # 不断刷新读取新内容

软连接

在执行ln命令之前,目录/usr/liu中不存在a2.c文件。执行ln之后,在/usr/liu目录中才有a2.c这一项,表明m2.c和a2.c链接起来(注意,二者在物理上是同一文件),利用ls -l命令可以看到链接数的变化。
ln /mub1/m2.c /usr/liu/a2.c  #将目录/usr/mengqc/mub1下的文件m2.c链接到目录/usr/liu下的文件a2.c
ln -s Lte.V120 Lte  #  迭代版本在前
ln -snf # 修改软连接  
ln -s /usr/local/python3/bin/python3.6 /usr/bin/python3

复制

cp # 只能移动文件
cp -r #包括文件夹一块移动

移动/改名

mv ex3 new1 #将文件ex3改名为new1
mv /lianxi/kkk/* /lianxi/jjjj/  #移动文件

解压/打包

tar -zxvf XXX.tar.gz
tar -zcvf 包名 将要打包文件  #打包
tar -jxvf XXX.tar.bz2 
tar -ztvf 包名  #查看包中的文件

删除

rm -r #可以删除文件夹
rm -rf #强制删除

文件夹

mkdir #建立空白文件夹
rmdir #删除空白文件夹

文件

touch  filename

搜索

whereis #搜索程序名称
whereis -b #搜索二进制文件
whereis -m #搜索说明文件
whereis -s #搜索源代码

find . #列出当前目录及子目录下所有文件和文件夹
find  / -name "*.k"  # 在根目录下搜索后缀为.k的文件

which
which python
/usr/bin/python

释放swap

swapon -s 查看到swap分区挂载在哪儿
swapoff  /dev/sda2  #停止/释放
swapon -a  #再次开启

dos2unix

dos2unix  windowsfile  # Windows格式文本转换为Unix&Linux格式文件

远程拷贝

scp -r root@172.16.16.103:/root/nbiot /root/

遇到的问题

  • 出现^H,使用Ctrl+回车即可

嘉美伯爵
56 声望7 粉丝

健身和旅行必须有一个在路上