Maven命令
连同源码部署第三方jar到私仓
mvn deploy:deploy-file -Dmaven.test.skip=true -DgroupId=com.gx -DartifactId=taobao-sdk-java-auto -Dversion=1.4.0-SNAPSHOT -Dpackaging=jar -Dfile=F:/taobao-sdk-java-auto-1.4.0-SNAPSHOT.jar -Dsources=F:/taobao-sdk-java-auto-1.4.0-SNAPSHOT-source.jar --settings F:\settings.xml -Durl=https://repo[私仓代理地址]snapshot-HmrAJI/ -DrepositoryId=maven-【私仓id】-snapshots
 Docker相关

   build              构建或重建服务
   bundle             从compose配置文件中产生一个docker绑定
   config             验证并查看compose配置文件
   create             创建服务
   down               停止并移除容器、网络、镜像和数据卷
   events             从容器中接收实时的事件
   exec               在一个运行中的容器上执行一个命令
   help               获取命令的帮助信息
   images             列出所有镜像
   kill               通过发送SIGKILL信号来停止指定服务的容器
   logs               从容器中查看服务日志输出
   pause              暂停服务
   port               打印绑定的公共端口
   ps                 列出所有运行中的容器
   pull               拉取并下载指定服务镜像
   push               Push service images
   restart            重启YAML文件中定义的服务
   rm                 删除指定已经停止服务的容器
   run                在一个服务上执行一条命令
   scale              设置指定服务运行容器的个数
   start              在容器中启动指定服务
   stop               停止已运行的服务
   top                显示各个服务容器内运行的进程
   unpause            恢复容器服务
   up                 创建并启动容器
   version            显示Docker-Compose版本信息以默认配置docker-compose.yml启动docker-compose
 docker-compose up -d
 docker-compose up -d --build 重新编译
 docker-compose -f docker-compose.yml -f docker-compose2.yml up -d
 docker-compose down 关闭所有
 docker-compose stop 停止服务
 docker-compose ps 查询正在运行的服务
 docker-compose restart 重启服务
 docker-compose exec container_name bash重启docker
 systemctl restart dockerdocker -h
 docker search image_name
 docker images
 docker pull image_name:image_version
 docker ps -a 查看已经创建的容器
 docker ps -s 查看已经启动的容器
 docker rename old_image_name new_image_name 重命名运行容器
 docker run -it my/python:v1 /bin/bash进入容器
 docker exec -it container_name或id /bin/bash
 docker attach db3 或者 docker attach d48b21a7e439
 指定名称映射端口后台启动镜像
 docker run -it --name dev_es -d -p 9200:9200 -p 9300:9300 -p 5601:5601 elasticsearch查看容器信息
 docker inspect container_id
 查看容器绑定ip
 docker inspect container_name | grep IPAddress
 查看日志
 docker logs container_name/container_id/image_id停止容器
 docker stop container_id
 删除所有未运行 Docker 容器
 docker rm $(docker ps -a -q)
 删除所有未打 tag 的镜像
 docker rmi $(docker images -q | awk '/^<none>/ { print $3 }')
 删除所有镜像
 docker rmi $(docker images -q)
 根据格式删除所有镜像
 docker rm $(docker ps -qf status=exited)
 删除所有已停止的容器
 docker rm $(docker ps -a -q)
 删除所有镜像(需要先删除容器,再删除镜像)
 docker rmi $(docker images -q)
 强制删除所有镜像 
 docker rmi -f $(docker images -q)docker rm $(docker ps -qf status=exited)
docker容器中拷贝文件到宿主机
 docker cp container_name:/home/nacos/conf/schema.sql /usr/local/ 
 
Linux
查看防火墙状态
 firewall-cmd --state
 关闭防火墙
 systemctl stop firewalld.service
 查看防火墙所有开放的端口
 firewall-cmd --zone=public --list-ports
 开放端口和关闭端口8088
 firewall-cmd --zone=public --add-port=8088/tcp --permanent
 firewall-cmd --zone=public --remove-port= 8088/tcp --permanent
 防火墙配置立即生效
 firewall-cmd --reload telnet测试端口是否畅通
 telnet 192.168.55.55 3306 
更新服务器时间
date -s “2018-11-18 12:00:00”
ntpdate 0.asia.pool.ntp.org
-----------------------------------------
 arch 显示机器的处理器架构(1) 
 uname -m 显示机器的处理器架构(2) 
 uname -r 显示正在使用的内核版本 
 dmidecode -q 显示硬件系统部件 - (SMBIOS / DMI) 
 hdparm -i /dev/hda 罗列一个磁盘的架构特性 
 hdparm -tT /dev/sda 在磁盘上执行测试性读取操作 
 cat /proc/cpuinfo 显示CPU info的信息 
 cat /proc/interrupts 显示中断 
 cat /proc/meminfo 校验内存使用 
 cat /proc/swaps 显示哪些swap被使用 
 cat /proc/version 显示内核的版本 
 cat /proc/net/dev 显示网络适配器及统计 
 cat /proc/mounts 显示已加载的文件系统 
 lspci -tv 罗列 PCI 设备 
 lsusb -tv 显示 USB 设备 
 date 显示系统日期 
 cal 2007 显示2007年的日历表 
 date 041217002007.00 设置日期和时间 - 月日时分年.秒 
 clock -w 将时间修改保存到 BIOS 关机 (系统的关机、重启以及登出 ) 
 shutdown -h now 关闭系统(1) 
 init 0 关闭系统(2) 
 telinit 0 关闭系统(3) 
 shutdown -h hours:minutes & 按预定时间关闭系统 
 shutdown -c 取消按预定时间关闭系统 
 shutdown -r now 重启(1) 
 reboot 重启(2) 
 logout 注销 ps参数
 -A :所有的进程均显示出来
 -a :不与terminal有关的所有进程
 -u :有效用户的相关进程
 -x :一般与a参数一起使用,可列出较完整的信息
 -l :较长,较详细地将PID的信息列出文件和目录 
 cd /home 进入 '/ home' 目录' 
 cd .. 返回上一级目录 
 cd ../.. 返回上两级目录 
 cd 进入个人的主目录 
 cd ~user1 进入个人的主目录 
 cd - 返回上次所在的目录 
 pwd 显示工作路径 
 ls 查看目录中的文件 
 ls -F 查看目录中的文件 
 ls -l 显示文件和目录的详细资料 
 ls -a 显示隐藏文件 
 ls *[0-9]* 显示包含数字的文件名和目录名 
 ls参数
 -l :列出长数据串,包含文件的属性与权限数据等
 -a :列出全部的文件,连同隐藏文件(开头为.的文件)一起列出来(常用)
 -d :仅列出目录本身,而不是列出目录的文件数据
 -h :将文件容量以较易读的方式(GB,kB等)列出来
 -R :连同子目录的内容一起列出(递归列出),等于该目录下的所有文件都会显示出来tree 显示文件和目录由根目录开始的树形结构(1) 
 lstree 显示文件和目录由根目录开始的树形结构(2) 
 mkdir dir1 创建一个叫做 'dir1' 的目录' 
 mkdir dir1 dir2 同时创建两个目录 
 mkdir -p /tmp/dir1/dir2 创建一个目录树(创建多级目录) 
 rm -f file1 删除一个叫做 'file1' 的文件' 
 rmdir dir1 删除一个叫做 'dir1' 的目录' 
 rm -rf dir1 删除一个叫做 'dir1' 的目录并同时删除其内容 
 rm -rf dir1 dir2 同时删除两个目录及它们的内容 
 mv dir1 new_dir 重命名/移动 一个目录 
 cp file1 file2 复制一个文件 
 cp dir/* . 复制一个目录下的所有文件到当前工作目录 
 cp -a /tmp/dir1 . 复制一个目录到当前工作目录 
 cp -a dir1 dir2 复制一个目录 
 ln -s file1 lnk1 创建一个指向文件或目录的软链接 
 ln file1 lnk1 创建一个指向文件或目录的物理链接 
 touch -t 0712250000 file1 修改一个文件或目录的时间戳 - (YYMMDDhhmm) 
 file file1 outputs the mime type of the file as text 
 iconv -l 列出已知的编码 
 iconv -f fromEncoding -t toEncoding inputFile > outputFile creates a new from the given input file by assuming it is encoded in fromEncoding and converting it to toEncoding. 
 find . -maxdepth 1 -name *.jpg -print -exec convert "{}" -resize 80x60 "thumbs/{}" \; batch resize files in the current directory and send them to a thumbnails directory (requires convert from Imagemagick) 文件搜索 
 find / -name file1 从 '/' 开始进入根文件系统搜索文件和目录 
 find / -user user1 搜索属于用户 'user1' 的文件和目录 
 find /home/user1 -name \*.bin 在目录 '/ home/user1' 中搜索带有'.bin' 结尾的文件 
 find /usr/bin -type f -atime +100 搜索在过去100天内未被使用过的执行文件 
 find /usr/bin -type f -mtime -10 搜索在10天内被创建或者修改过的文件 
 find / -name \*.rpm -exec chmod 755 '{}' \; 搜索以 '.rpm' 结尾的文件并定义其权限 
 find / -xdev -name \*.rpm 搜索以 '.rpm' 结尾的文件,忽略光驱、捷盘等可移动设备 
 locate \*.ps 寻找以 '.ps' 结尾的文件 - 先运行 'updatedb' 命令 
 whereis halt 显示一个二进制文件、源码或man的位置 
 which halt 显示一个二进制文件或可执行文件的完整路径 挂载一个文件系统 
 mount /dev/hda2 /mnt/hda2 挂载一个叫做hda2的盘 - 确定目录 '/ mnt/hda2' 已经存在 
 umount /dev/hda2 卸载一个叫做hda2的盘 - 先从挂载点 '/ mnt/hda2' 退出 
 fuser -km /mnt/hda2 当设备繁忙时强制卸载 
 umount -n /mnt/hda2 运行卸载操作而不写入 /etc/mtab 文件- 当文件为只读或当磁盘写满时非常有用 
 mount /dev/fd0 /mnt/floppy 挂载一个软盘 
 mount /dev/cdrom /mnt/cdrom 挂载一个cdrom或dvdrom 
 mount /dev/hdc /mnt/cdrecorder 挂载一个cdrw或dvdrom 
 mount /dev/hdb /mnt/cdrecorder 挂载一个cdrw或dvdrom 
 mount -o loop file.iso /mnt/cdrom 挂载一个文件或ISO镜像文件 
 mount -t vfat /dev/hda5 /mnt/hda5 挂载一个Windows FAT32文件系统 
 mount /dev/sda1 /mnt/usbdisk 挂载一个usb 捷盘或闪存设备 
 mount -t smbfs -o username=user,password=pass //WinClient/share /mnt/share 挂载一个windows网络共享 磁盘空间 
 df -h 显示已经挂载的分区列表 
 ls -lSr |more 以尺寸大小排列文件和目录 
 du -sh dir1 估算目录 'dir1' 已经使用的磁盘空间' 
 du -sk * | sort -rn 以容量大小为依据依次显示文件和目录的大小 
 rpm -q -a --qf '%10{SIZE}t%{NAME}n' | sort -k1,1n 以大小为依据依次显示已安装的rpm包所使用的空间 (fedora, redhat类系统) 
 dpkg-query -W -f='${Installed-Size;10}t${Package}n' | sort -k1,1n 以大小为依据显示已安装的deb包所使用的空间 (ubuntu, debian类系统) 用户和群组 
 groupadd group_name 创建一个新用户组 
 groupdel group_name 删除一个用户组 
 groupmod -n new_group_name old_group_name 重命名一个用户组 
 useradd -c "Name Surname " -g admin -d /home/user1 -s /bin/bash user1 创建一个属于 "admin" 用户组的用户 
 useradd user1 创建一个新用户 
 userdel -r user1 删除一个用户 ( '-r' 排除主目录) 
 usermod -c "User FTP" -g system -d /ftp/user1 -s /bin/nologin user1 修改用户属性 
 passwd 修改口令 
 passwd user1 修改一个用户的口令 (只允许root执行) 
 chage -E 2005-12-31 user1 设置用户口令的失效期限 
 pwck 检查 '/etc/passwd' 的文件格式和语法修正以及存在的用户 
 grpck 检查 '/etc/passwd' 的文件格式和语法修正以及存在的群组 
 newgrp group_name 登陆进一个新的群组以改变新创建文件的预设群组 文件的权限 - 使用 "+" 设置权限,使用 "-" 用于取消 
 ls -lh 显示权限 
 ls /tmp | pr -T5 -W$COLUMNS 将终端划分成5栏显示 
 chmod ugo+rwx directory1 设置目录的所有人(u)、群组(g)以及其他人(o)以读(r )、写(w)和执行(x)的权限 
 chmod go-rwx directory1 删除群组(g)与其他人(o)对目录的读写执行权限 
 chown user1 file1 改变一个文件的所有人属性 
 chown -R user1 directory1 改变一个目录的所有人属性并同时改变改目录下所有文件的属性 
 chgrp group1 file1 改变文件的群组 
 chown user1:group1 file1 改变一个文件的所有人和群组属性 
 find / -perm -u+s 罗列一个系统中所有使用了SUID控制的文件 
 chmod u+s /bin/file1 设置一个二进制文件的 SUID 位 - 运行该文件的用户也被赋予和所有者同样的权限 
 chmod u-s /bin/file1 禁用一个二进制文件的 SUID位 
 chmod g+s /home/public 设置一个目录的SGID 位 - 类似SUID ,不过这是针对目录的 
 chmod g-s /home/public 禁用一个目录的 SGID 位 
 chmod o+t /home/public 设置一个文件的 STIKY 位 - 只允许合法所有人删除文件 
 chmod o-t /home/public 禁用一个目录的 STIKY 位 文件的特殊属性 - 使用 "+" 设置权限,使用 "-" 用于取消 
 chattr +a file1 只允许以追加方式读写文件 
 chattr +c file1 允许这个文件能被内核自动压缩/解压 
 chattr +d file1 在进行文件系统备份时,dump程序将忽略这个文件 
 chattr +i file1 设置成不可变的文件,不能被删除、修改、重命名或者链接 
 chattr +s file1 允许一个文件被安全地删除 
 chattr +S file1 一旦应用程序对这个文件执行了写操作,使系统立刻把修改的结果写到磁盘 
 chattr +u file1 若文件被删除,系统会允许你在以后恢复这个被删除的文件 
 lsattr 显示特殊的属性 打包和压缩文件 
 bunzip2 file1.bz2 解压一个叫做 'file1.bz2'的文件 
 bzip2 file1 压缩一个叫做 'file1' 的文件 
 gunzip file1.gz 解压一个叫做 'file1.gz'的文件 
 gzip file1 压缩一个叫做 'file1'的文件 
 gzip -9 file1 最大程度压缩 
 rar a file1.rar test_file 创建一个叫做 'file1.rar' 的包 
 rar a file1.rar file1 file2 dir1 同时压缩 'file1', 'file2' 以及目录 'dir1' 
 rar x file1.rar 解压rar包 
 unrar x file1.rar 解压rar包 
 tar -cvf archive.tar file1 创建一个非压缩的 tarball 
 tar -cvf archive.tar file1 file2 dir1 创建一个包含了 'file1', 'file2' 以及 'dir1'的档案文件 
 tar -tf archive.tar 显示一个包中的内容 
 tar -xvf archive.tar 释放一个包 
 tar -xvf archive.tar -C /tmp 将压缩包释放到 /tmp目录下 
 tar -cvfj archive.tar.bz2 dir1 创建一个bzip2格式的压缩包 
 tar -xvfj archive.tar.bz2 解压一个bzip2格式的压缩包 
 tar -cvfz archive.tar.gz dir1 创建一个gzip格式的压缩包 
 tar -xvfz archive.tar.gz 解压一个gzip格式的压缩包 
 zip file1.zip file1 创建一个zip格式的压缩包 
 zip -r file1.zip file1 file2 dir1 将几个文件和目录同时压缩成一个zip格式的压缩包 
 unzip file1.zip 解压一个zip格式压缩包 RPM 包 - (Fedora, Redhat及类似系统) 
 rpm -ivh package.rpm 安装一个rpm包 
 rpm -ivh --nodeeps package.rpm 安装一个rpm包而忽略依赖关系警告 
 rpm -U package.rpm 更新一个rpm包但不改变其配置文件 
 rpm -F package.rpm 更新一个确定已经安装的rpm包 
 rpm -e package_name.rpm 删除一个rpm包 
 rpm -qa 显示系统中所有已经安装的rpm包 
 rpm -qa | grep httpd 显示所有名称中包含 "httpd" 字样的rpm包 
 rpm -qi package_name 获取一个已安装包的特殊信息 
 rpm -qg "System Environment/Daemons" 显示一个组件的rpm包 
 rpm -ql package_name 显示一个已经安装的rpm包提供的文件列表 
 rpm -qc package_name 显示一个已经安装的rpm包提供的配置文件列表 
 rpm -q package_name --whatrequires 显示与一个rpm包存在依赖关系的列表 
 rpm -q package_name --whatprovides 显示一个rpm包所占的体积 
 rpm -q package_name --scripts 显示在安装/删除期间所执行的脚本l 
 rpm -q package_name --changelog 显示一个rpm包的修改历史 
 rpm -qf /etc/httpd/conf/httpd.conf 确认所给的文件由哪个rpm包所提供 
 rpm -qp package.rpm -l 显示由一个尚未安装的rpm包提供的文件列表 
 rpm --import /media/cdrom/RPM-GPG-KEY 导入公钥数字证书 
 rpm --checksig package.rpm 确认一个rpm包的完整性 
 rpm -qa gpg-pubkey 确认已安装的所有rpm包的完整性 
 rpm -V package_name 检查文件尺寸、 许可、类型、所有者、群组、MD5检查以及最后修改时间 
 rpm -Va 检查系统中所有已安装的rpm包- 小心使用 
 rpm -Vp package.rpm 确认一个rpm包还未安装 
 rpm2cpio package.rpm | cpio --extract --make-directories *bin* 从一个rpm包运行可执行文件 
 rpm -ivh /usr/src/redhat/RPMS/`arch`/package.rpm 从一个rpm源码安装一个构建好的包 
 rpmbuild --rebuild package_name.src.rpm 从一个rpm源码构建一个 rpm 包 YUM 软件包升级器 - (Fedora, RedHat及类似系统) 
 yum install package_name 下载并安装一个rpm包 
 yum localinstall package_name.rpm 将安装一个rpm包,使用你自己的软件仓库为你解决所有依赖关系 
 yum update package_name.rpm 更新当前系统中所有安装的rpm包 
 yum update package_name 更新一个rpm包 
 yum remove package_name 删除一个rpm包 
 yum list 列出当前系统中安装的所有包 
 yum search package_name 在rpm仓库中搜寻软件包 
 yum clean packages 清理rpm缓存删除下载的包 
 yum clean headers 删除所有头文件 
 yum clean all 删除所有缓存的包和头文件 DEB 包 (Debian, Ubuntu 以及类似系统) 
 dpkg -i package.deb 安装/更新一个 deb 包 
 dpkg -r package_name 从系统删除一个 deb 包 
 dpkg -l 显示系统中所有已经安装的 deb 包 
 dpkg -l | grep httpd 显示所有名称中包含 "httpd" 字样的deb包 
 dpkg -s package_name 获得已经安装在系统中一个特殊包的信息 
 dpkg -L package_name 显示系统中已经安装的一个deb包所提供的文件列表 
 dpkg --contents package.deb 显示尚未安装的一个包所提供的文件列表 
 dpkg -S /bin/ping 确认所给的文件由哪个deb包提供 APT 软件工具 (Debian, Ubuntu 以及类似系统) 
 apt-get install package_name 安装/更新一个 deb 包 
 apt-cdrom install package_name 从光盘安装/更新一个 deb 包 
 apt-get update 升级列表中的软件包 
 apt-get upgrade 升级所有已安装的软件 
 apt-get remove package_name 从系统删除一个deb包 
 apt-get check 确认依赖的软件仓库正确 
 apt-get clean 从下载的软件包中清理缓存 
 apt-cache search searched-package 返回包含所要搜索字符串的软件包名称 查看文件内容 
 cat file1 从第一个字节开始正向查看文件的内容 
 tac file1 从最后一行开始反向查看一个文件的内容 
 more file1 查看一个长文件的内容 
 less file1 类似于 'more' 命令,但是它允许在文件中和正向操作一样的反向操作 
 head -2 file1 查看一个文件的前两行 
 tail -2 file1 查看一个文件的最后两行 
 tail -f /var/log/messages 实时查看被添加到一个文件中的内容 文本处理 
 cat file1 file2 ... | command <> file1_in.txt_or_file1_out.txt general syntax for text manipulation using PIPE, STDIN and STDOUT 
 cat file1 | command( sed, grep, awk, grep, etc...) > result.txt 合并一个文件的详细说明文本,并将简介写入一个新文件中 
 cat file1 | command( sed, grep, awk, grep, etc...) >> result.txt 合并一个文件的详细说明文本,并将简介写入一个已有的文件中 grep [-acinv] [--color=auto] '查找字符串' filename
grep Aug /var/log/messages 在文件 '/var/log/messages'中查找关键词"Aug" 
 grep ^Aug /var/log/messages 在文件 '/var/log/messages'中查找以"Aug"开始的词汇 
 grep [0-9] /var/log/messages 选择 '/var/log/messages' 文件中所有包含数字的行 
 grep Aug -R /var/log/* 在目录 '/var/log' 及随后的目录中搜索字符串"Aug" 
 sed 's/stringa1/stringa2/g' example.txt 将example.txt文件中的 "string1" 替换成 "string2" 
 sed '/^$/d' example.txt 从example.txt文件中删除所有空白行 
 sed '/ *#/d; /^$/d' example.txt 从example.txt文件中删除所有注释和空白行 
 echo 'esempio' | tr '[:lower:]' '[:upper:]' 合并上下单元格内容 
 sed -e '1d' result.txt 从文件example.txt 中排除第一行 
 sed -n '/stringa1/p' 查看只包含词汇 "string1"的行 
 sed -e 's/ *$//' example.txt 删除每一行最后的空白字符 
 sed -e 's/stringa1//g' example.txt 从文档中只删除词汇 "string1" 并保留剩余全部 
 sed -n '1,5p;5q' example.txt 查看从第一行到第5行内容 
 sed -n '5p;5q' example.txt 查看第5行 
 sed -e 's/00*/0/g' example.txt 用单个零替换多个零 
 cat -n file1 标示文件的行数 
 cat example.txt | awk 'NR%2==1' 删除example.txt文件中的所有偶数行 
 echo a b c | awk '{print $1}' 查看一行第一栏 
 echo a b c | awk '{print $1,$3}' 查看一行的第一和第三栏 
 paste file1 file2 合并两个文件或两栏的内容 
 paste -d '+' file1 file2 合并两个文件或两栏的内容,中间用"+"区分 
 sort file1 file2 排序两个文件的内容 
 sort file1 file2 | uniq 取出两个文件的并集(重复的行只保留一份) 
 sort file1 file2 | uniq -u 删除交集,留下其他的行 
 sort file1 file2 | uniq -d 取出两个文件的交集(只留下同时存在于两个文件中的文件) 
 comm -1 file1 file2 比较两个文件的内容只删除 'file1' 所包含的内容 
 comm -2 file1 file2 比较两个文件的内容只删除 'file2' 所包含的内容 
 comm -3 file1 file2 比较两个文件的内容只删除两个文件共有的部分  
1、cd命令
 这是一个非常基本,也是大家经常需要使用的命令,它用于切换当前目录,它的参数是要切换到的目录的路径,可以是绝对路径,也可以是相对路径。如:
 cd /root/Docements # 切换到目录/root/Docements
 cd ./path          # 切换到当前目录下的path目录中,“.”表示当前目录  
 cd ../path         # 切换到上层目录中的path目录中,“..”表示上一层目录
 2、ls命令
 这是一个非常有用的查看文件与目录的命令,list之意,它的参数非常多,下面就列出一些我常用的参数吧,如下:
 -l :列出长数据串,包含文件的属性与权限数据等
 -a :列出全部的文件,连同隐藏文件(开头为.的文件)一起列出来(常用)
 -d :仅列出目录本身,而不是列出目录的文件数据
 -h :将文件容量以较易读的方式(GB,kB等)列出来
 -R :连同子目录的内容一起列出(递归列出),等于该目录下的所有文件都会显示出来
 注:这些参数也可以组合使用,下面举两个例子:
 ls -l #以长数据串的形式列出当前目录下的数据文件和目录
 ls -lR #以长数据串的形式列出当前目录下的所有文件
 3、grep命令
 该命令常用于分析一行的信息,若当中有我们所需要的信息,就将该行显示出来,该命令通常与管道命令一起使用,用于对一些命令的输出进行筛选加工等等,它的简单语法为
 grep [-acinv] [--color=auto] '查找字符串' filename
 它的常用参数如下:
 -a :将binary文件以text文件的方式查找数据
 -c :计算找到‘查找字符串’的次数
 -i :忽略大小写的区别,即把大小写视为相同
 -v :反向选择,即显示出没有‘查找字符串’内容的那一行
 # 例如:
 # 取出文件/etc/man.config中包含MANPATH的行,并把找到的关键字加上颜色
 grep --color=auto 'MANPATH' /etc/man.config
 # 把ls -l的输出中包含字母file(不区分大小写)的内容输出
 ls -l | grep -i file
 4、find命令
 find是一个基于查找的功能非常强大的命令,相对而言,它的使用也相对较为复杂,参数也比较多,所以在这里将给把它们分类列出,它的基本语法如下:
 find [PATH] [option] [action]# 与时间有关的参数:
 -mtime n : n为数字,意思为在n天之前的“一天内”被更改过的文件;
 -mtime +n : 列出在n天之前(不含n天本身)被更改过的文件名;
 -mtime -n : 列出在n天之内(含n天本身)被更改过的文件名;
 -newer file : 列出比file还要新的文件名
 # 例如:
 find /root -mtime 0 # 在当前目录下查找今天之内有改动的文件# 与用户或用户组名有关的参数:
 -user name : 列出文件所有者为name的文件
 -group name : 列出文件所属用户组为name的文件
 -uid n : 列出文件所有者为用户ID为n的文件
 -gid n : 列出文件所属用户组为用户组ID为n的文件
 # 例如:
 find /home/ljianhui -user ljianhui # 在目录/home/ljianhui中找出所有者为ljianhui的文件# 与文件权限及名称有关的参数:
 -name filename :找出文件名为filename的文件
 -size [+-]SIZE :找出比SIZE还要大(+)或小(-)的文件
 -tpye TYPE :查找文件的类型为TYPE的文件,TYPE的值主要有:一般文件(f)、设备文件(b、c)、
              目录(d)、连接文件(l)、socket(s)、FIFO管道文件(p);
 -perm mode :查找文件权限刚好等于mode的文件,mode用数字表示,如0755;
 -perm -mode :查找文件权限必须要全部包括mode权限的文件,mode用数字表示
 -perm +mode :查找文件权限包含任一mode的权限的文件,mode用数字表示
 # 例如:
 find / -name passwd # 查找文件名为passwd的文件
 find . -perm 0755 # 查找当前目录中文件权限的0755的文件
 find . -size +12k # 查找当前目录中大于12KB的文件,注意c表示byte
 5、cp命令
 该命令用于复制文件,copy之意,它还可以把多个文件一次性地复制到一个目录下,它的常用参数如下:
 -a :将文件的特性一起复制
 -p :连同文件的属性一起复制,而非使用默认方式,与-a相似,常用于备份
 -i :若目标文件已经存在时,在覆盖时会先询问操作的进行
 -r :递归持续复制,用于目录的复制行为
 -u :目标文件与源文件有差异时才会复制
 例如 :
 cp -a file1 file2 #连同文件的所有特性把文件file1复制成文件file2
 cp file1 file2 file3 dir #把文件file1、file2、file3复制到目录dir中
 6、mv命令
 该命令用于移动文件、目录或更名,move之意,它的常用参数如下:
 -f :force强制的意思,如果目标文件已经存在,不会询问而直接覆盖
 -i :若目标文件已经存在,就会询问是否覆盖
 -u :若目标文件已经存在,且比目标文件新,才会更新
 注:该命令可以把一个文件或多个文件一次移动一个文件夹中,但是最后一个目标文件一定要是“目录”。例如:
 mv file1 file2 file3 dir # 把文件file1、file2、file3移动到目录dir中
 mv file1 file2 # 把文件file1重命名为file2
 7、rm命令
 该命令用于删除文件或目录,remove之间,它的常用参数如下:
 -f :就是force的意思,忽略不存在的文件,不会出现警告消息
 -i :互动模式,在删除前会询问用户是否操作
 -r :递归删除,最常用于目录删除,它是一个非常危险的参数
 例如:
 rm -i file # 删除文件file,在删除之前会询问是否进行该操作
 rm -fr dir # 强制删除目录dir中的所有文件
 8、ps命令
 该命令用于将某个时间点的进程运行情况选取下来并输出,process之意,它的常用参数如下:
 -A :所有的进程均显示出来
 -a :不与terminal有关的所有进程
 -u :有效用户的相关进程
 -x :一般与a参数一起使用,可列出较完整的信息
 -l :较长,较详细地将PID的信息列出
 其实我们只要记住ps一般使用的命令参数搭配即可,它们并不多,如下:
 ps aux # 查看系统所有的进程数据
 ps ax # 查看不与terminal有关的所有进程
 ps -lA # 查看系统所有的进程数据
 ps axjf # 查看连同一部分进程树状态
 9、kill命令
 该命令用于向某个工作(%jobnumber)或者是某个PID(数字)传送一个信号,它通常与ps和jobs命令一起使用,它的基本语法如下:
 kill -signal PID
 signal的常用参数如下:
 注:最前面的数字为信号的代号,使用时可以用代号代替相应的信号。
 1:SIGHUP,启动被终止的进程
 2:SIGINT,相当于输入ctrl+c,中断一个程序的进行
 9:SIGKILL,强制中断一个进程的进行
 15:SIGTERM,以正常的结束进程方式来终止进程
 17:SIGSTOP,相当于输入ctrl+z,暂停一个进程的进行
 例如:
 # 以正常的结束进程方式来终于第一个后台工作,可用jobs命令查看后台中的第一个工作进程
 kill -SIGTERM %1 
 # 重新改动进程ID为PID的进程,PID可用ps命令通过管道命令加上grep命令进行筛选获得
 kill -SIGHUP PID
 10、killall命令
 该命令用于向一个命令启动的进程发送一个信号,它的一般语法如下:
 killall [-iIe] [command name]
 它的参数如下:
 -i :交互式的意思,若需要删除时,会询问用户
 -e :表示后面接的command name要一致,但command name不能超过15个字符
 -I :命令名称忽略大小写
 # 例如:
 killall -SIGHUP syslogd # 重新启动syslogd
 11、file命令
 该命令用于判断接在file命令后的文件的基本数据,因为在Linux下文件的类型并不是以后缀为分的,所以这个命令对我们来说就很有用了,它的用法非常简单,基本语法如下:
 file filename
 #例如:
 file ./test
 12、tar命令
 该命令用于对文件进行打包,默认情况并不会压缩,如果指定了相应的参数,它还会调用相应的压缩程序(如gzip和bzip等)进行压缩和解压。它的常用参数如下:
 -c :新建打包文件
 -t :查看打包文件的内容含有哪些文件名
 -x :解打包或解压缩的功能,可以搭配-C(大写)指定解压的目录,注意-c,-t,-x不能同时出现在同一条命令中
 -j :通过bzip2的支持进行压缩/解压缩
 -z :通过gzip的支持进行压缩/解压缩
 -v :在压缩/解压缩过程中,将正在处理的文件名显示出来
 -f filename :filename为要处理的文件
 -C dir :指定压缩/解压缩的目录dir
 上面的解说可以已经让你晕过去了,但是通常我们只需要记住下面三条命令即可:
 压缩:tar -jcv -f filename.tar.bz2 要被处理的文件或目录名称
 查询:tar -jtv -f filename.tar.bz2
 解压:tar -jxv -f filename.tar.bz2 -C 欲解压缩的目录
 注:文件名并不定要以后缀tar.bz2结尾,这里主要是为了说明使用的压缩程序为bzip213、cat命令
 该命令用于查看文本文件的内容,后接要查看的文件名,通常可用管道与more和less一起使用,从而可以一页页地查看数据。例如:
 cat text | less # 查看text文件中的内容
 # 注:这条命令也可以使用less text来代替
 14、chgrp命令
 该命令用于改变文件所属用户组,它的使用非常简单,它的基本用法如下:
 chgrp [-R] dirname/filename
 -R :进行递归的持续对所有文件和子目录更改
 # 例如:
 chgrp users -R ./dir # 递归地把dir目录下中的所有文件和子目录下所有文件的用户组修改为users
 15、chown命令
 该命令用于改变文件的所有者,与chgrp命令的使用方法相同,只是修改的文件属性不同,不再详述。16、chmod命令
 该命令用于改变文件的权限,一般的用法如下:
 chmod [-R] xyz 文件或目录
 -R:进行递归的持续更改,即连同子目录下的所有文件都会更改
 同时,chmod还可以使用u(user)、g(group)、o(other)、a(all)和+(加入)、-(删除)、=(设置)跟rwx搭配来对文件的权限进行更改。# 例如:
 chmod 0755 file # 把file的文件权限改变为-rxwr-xr-x
 chmod g+w file # 向file的文件权限中加入用户组可写权限