主要是记录一下Linux的基础知识及常用命令:
Linux的目录结构:
root管理员的home目录root,其他用户的home目录home目录中
切换目录命令cd:
cd app 切换到app目录 cd .. 切换到上一层目录 cd / 切换到系统根目录 cd ~ 切换到用户主目录 cd - 切换到上一个所在目录
列出文件列表:ls ll dir(*****):
ls(list)是一个非常有用的命令,用来显示当前目录下的内容。配合参数的使用,能以不同的方式显示目录内容。
格式:ls[参数] [路径或文件名]
在linux中以 . 开头的文件都是隐藏的文件 * ls * ls -a 显示所有文件或目录(包含隐藏的文件) * ls -l 缩写成ll *ls -alh 查询目录中内容 -a 显示所有文件,包括隐藏文件,-l 显示详细信息, -h 人性化显示文件大小
创建目录和移除目录:mkdir rmdir:
mkdir(make directory)命令可用来创建子目录。 mkdir app 在当前目录下创建app目录 mkdir –p app2/test 级联创建aap2以及test目 rmdir(remove directory) 命令可用来删除“空”的子目录: rmdir app 删除app目录
浏览文件:【cat、more、less】
cat 用于显示文件的内容。 格式:cat[参数]<文件名> * cat yum.conf more 一般用于要显示的内容会超过一个画面长度的情况。按空格键显示下一个画面。 回车显示下一行内容。 按 q 键退出查看。 * more yum.conf * 空格显示下一页数据 回车显示下一行的数据 less 用法和more类似,不同的是less可以通过PgUp、PgDn键来控制。 * less yum.conf * PgUp 和 PgDn 进行上下翻页.
【tail】
tail命令是在实际使用过程中使用非常多的一个命令,它的功能是:用于显示文件后几行的内容。 用法: tail -10 /etc/passwd 查看后10行数据 tail -f catalina.log 动态查看日志(*****) ctrl+c 结束查看
文件操作:
【rm】 删除:
rm 删除文件 用法:rm [选项]... 文件... rm a.txt 删除a.txt文件 删除需要用户确认,y/n rm 删除不询问 rm -f a.txt 不询问,直接删除 rm 删除目录 rm -r a 递归删除 不询问递归删除(慎用) rm -rf a 不询问递归删除 rm -rf * 删除所有文件 rm -rf /* 自杀
【cp、mv】:
cp(copy)命令可以将文件从一处复制到另一处。一般在使用cp命令时将一个文件复制成另一个文件或复制到某目录时,需要指定源文件名与目标文件名或目录。 cp a.txt b.txt 将a.txt复制为b.txt文件 cp a.txt ../ 将a.txt文件复制到上一层目录中 mv 移动或者重命名 mv a.txt ../ 将a.txt文件移动到上一层目录中 mv a.txt b.txt 将a.txt文件重命名为b.txt
【tar】命令:(***** 打包或解压)
tar命令位于/bin目录下,它能够将用户所指定的文件或目录打包成一个文件,但不做压缩。一般Linux上常用的压缩方式是选用tar将许多文件打包成一个文件,再以gzip压缩命令压缩成xxx.tar.gz(或称为xxx.tgz)的文件。
.zip:
压缩单个文件:zip + 压缩文件名.zip + 源文件 压缩目录:zip -r + 压缩文件名(目录) + 源文件 解压: unzip + 要解压的文件名
gz:
gzip + 源文件 压缩为.gz格式的压缩文件,源文件会消失 gzip -c + 源文件 > 压缩文件 压缩为.gz格式,源文件保留 gzip -r + 源文件(压缩目录,压缩目录下所有的子文件,但是不能压缩目录) 解压:gzip -d 压缩文件 gunzip 压缩文件 gunzip -r 解压目录
.bz2:
bzip2 + 源文件 压缩为.bz2格式,不保留源文件 bzip2 -k + 源文件 压缩之后保留源文件 注意:bzip2命令不能压缩目录 解压: bizp2 -d + 压缩文件 -k 保留压缩文件
tar:
压缩:tar -cvf 文件名.tar 源文件 -c :打包 -v :显示过程 -f :指定打包后的文件名 解压: tar -xvf 打包文件名 压缩 tar.gz tar -zcvf + 压缩名.tar.gz + 源文件 -z :压缩为.tar.gz格式 解压缩tar.gz tar -zxvf + 压缩名.tar.gz 压缩:tar.bz2 tar -jcvf + 压缩名.tar.bz2 + 源文件 解压缩:tar.gz tar -jxvf + 压缩名.tar.gz
【grep】命令:查找符合条件的字符串。
用法: grep [选项]... PATTERN [FILE]...
示例: grep lang anaconda-ks.cfg 在文件中查找lang grep lang anaconda-ks.cfg –color 高亮显示
其他常用命令:
【pwd】:显示当前所在目录
【touch】:创建一个空文件 * touch a.txt
【ll -h】:友好显示文件大小
【wget】:wget http://nginx.org/download/nginx-1.9.12.tar.gz
vi 和 vim 编辑器:
在Linux下一般使用vi编辑器来编辑文件。vi既可以查看文件也可以编辑文件。三种模式:命令行、插入、底行模式。
切换到命令行模式:按Esc键;切换到插入模式:按 i 、o、a键;
i 在当前位置生前插入 I 在当前行首插入 a 在当前位置后插入 A 在当前行尾插入 o 在当前行之后插入一行 O 在当前行之前插入一行 切换到底行模式:按 :(冒号); 打开文件:vim file 退出:esc :q 修改文件:输入i进入插入模式 保存并退出:esc:wq 不保存退出:esc:q! 快捷键: dd – 快速删除一行 R – 替换
重定向输出>和>>:
> 重定向输出,覆盖原有内容;
>> 重定向输出,又追加功能;示例:
cat /etc/passwd > a.txt 将输出定向到a.txt中
cat /etc/passwd >> a.txt 输出并且追加
ifconfig > ifconfig.txt
管道:管道是Linux命令中重要的一个概念,其作用是将一个命令的输出用作另一个命令的输入。
ls --help | more 分页查询帮助信息 ps –ef | grep java 查询名称中包含java的进程 ifconfig | more cat index.html | more ps –ef | grep aio
&&命令执行控制:
命令之间使用 && 连接,实现逻辑与的功能。
只有在 && 左边的命令返回真(命令返回值 $? == 0),&& 右边的命令才会被执行。
只要有一个命令返回假(命令返回值 $? == 1),后面的命令就不会被执行。
mkdir test && cd test
网络通讯命令:
ifconfig 显示或设置网络设备。 ifconfig 显示网络设备 ifconfig eth0 up 启用eth0网卡 ifconfig eth0 down 停用eth0网卡 ping 探测网络是否通畅。 ping 192.168.0.1 netstat 查看网络端口。 netstat -an | grep 3306 查询3306端口占用情况
系统管理命令:
date 显示或设置系统时间 date 显示当前系统时间 date -s “2014-01-01 10:10:10“ 设置系统时间 df 显示磁盘信息 df –h 友好显示大小 free 显示内存状态 free –m 以mb单位显示内存组昂头 top 显示,管理执行中的程序 clear 清屏幕 ps 正在运行的某个进程的状态 ps –ef 查看所有进程 ps –ef | grep ssh 查找某一进程 kill 杀掉某一进程 kill 2868 杀掉2868编号的进程 kill -9 2868 强制杀死进程 du 显示目录或文件的大小。 du –h 显示当前目录的大小 who 显示目前登入系统的用户信息。 hostname 查看当前主机名 修改:vi /etc/sysconfig/network uname 显示系统信息。 uname -a 显示本机详细信息。 依次为:内核名称(类别),主机名,内核版本号,内核版本,内核编译日期,硬件名,处理器类型,硬件平台类型,操作系统名称
Linux的用户和组:
useradd 添加一个用户 useradd test 添加test用户 useradd test -d /home/t1 指定用户home目录 passwd 设置、修改密码 passwd test 为test用户设置密码 切换登录: ssh -l test -p 22 192.168.19.128 su – 用户名 userdel 删除一个用户 userdel test 删除test用户(不会删除home目录) userdel –r test 删除用户以及home目录
组管理:
当在创建一个新用户user时,若没有指定他所属于的组,就建立一个和该用户同名的私有组
创建用户时也可以指定所在组 groupadd 创建组 groupadd public 创建一个名为public的组 useradd u1 –g public 创建用户指定组groupdel 删除组,如果该组有用户成员,必须先删除用户才能删除组。 groupdel public
id 命令:
功能:查看一个用户的UID和GID
用法:id [选项]... [用户名]
直接使用id
直接使用id 用户名
【su命令】:功能:切换用户
用法:su [选项]... [-] [用户 [参数]... ]
示例:
su u1 切换到u1用户
su - u1 切换到u1用户,并且将环境也切换到u1用户的环境(推荐使用)
【账户文件】
/etc/passwd 用户文件
/etc/shadow 密码文件
/etc/group 组信息文件
【用户文件】:
root:x:0:0:root:/root:/bin/bash 账号名称: 在系统中是唯一的 用户密码: 此字段存放加密口令 用户标识码(User ID): 系统内部用它来标示用户 组标识码(Group ID): 系统内部用它来标识用户属性用 户相关信息: 例如用户全名等 用户目录: 用户登录系统后所进入的目录 用户环境: 用户工作的环境
【密码文件】:
shadow文件中每条记录用冒号间隔的9个字段组成. 用户名:用户登录到系统时使用的名字,而且是惟一的 口令: 存放加密的口令 最后一次修改时间: 标识从某一时刻起到用户最后一次修改时间 最大时间间隔: 口令保持有效的最大天数,即多少天后必须修改口令 最小时间间隔: 再次修改口令之间的最小天数 警告时间:从系统开始警告到口令正式失效的天数 不活动时间: 口令过期少天后,该账号被禁用 失效时间:指示口令失效的绝对天数(从1970年1月1日开始计算) 标志:未使用
组文件:
root:x:0: 组名:用户所属组 组口令:一般不用 GID:组ID 用户列表:属于该组的所有用户
Linux的权限文件:
Linux三种文件类型:
普通文件: 包括文本文件、数据文件、可执行的二进制程序文件等。 目录文件: Linux系统把目录看成是一种特殊的文件,利用它构成文件系统的树型结构。 设备文件: Linux系统把每一个设备都看成是一个文件
文件类型标识:
普通文件(-) 目录(d) 符号链接(l) * 进入etc可以查看,相当于快捷方式 字符设备文件(c) 块设备文件(s) 套接字(s) 命名管道(p)
文件权限管理:
chmod 变更文件或目录的权限。 chmod 755 a.txt chmod u=rwx,g=rx,o=rx a.txt chmod 000 a.txt / chmod 777 a.txt chown 变更文件或目录改文件所属用户和组 chown u1:public a.txt :变更当前的目录或文件的所属用户和组 chown -R u1:public dir :变更目录中的所有的子目录及文件的所属用户和组
服务重启:
shutdown -r now 是立即重启
shutdown -h now 是立即关机
service vsftpd stop 关闭vsftp
service vsftpd start 启动vsftp
service vsftpd status 查看vsftp状态
搜索:
1.搜索文件:locate 文件名 运行之前先更新一下数据库updatedb 然后再搜索
find [搜索范围] [搜索条件] find搜索 是完全匹配搜索
find 命令常见用法:
find /var/log/ -mtime +10 查找10天前修改的文件 -10 10天内 10 10天当前 +10 10天前
find /etc -size +20k -a -size -50k 查找/etc/目录下,大于20KB并且小于50KB的文件 -a and -o or
查找tnsnames.ora文件: find / -name tnsnames.ora
2.搜索命令:whereis 命令名 which 文件名
软连接与硬链接:
ln [源文件] [目标文件] 功能描述:生成链硬接文件
ln -s [源文件] [目标文件] 功能描述:生成软硬接文件
硬链接和软链接的区别:
硬链接特征:拥有相同的i节点和存储block块,可以看作是同一个文件;不能跨分区;不能针对目录使用;删除原文件,硬链接依然可以使用;
软链接特征:软链接拥有自己的I节点和Block块,但是数据块中只保存原有文件的文件名和I节点号,并没有实际的文件数据;
软链接文件权限都为 rwxrwxrwx;修改任意文件,另一个都改变;删除原文件,软链接不能使用;
日志查询命令(生产很常用):
grep -8 --color=always '要查询的关键字' gw-check-adapter.2019-02-08_0.log | more
grep --color=always -C 8 '要查询的关键字1' /data/appLogs/ gw-check-adapter.2019-02-08_0.log|grep --color=always -C 8 '要查询的关键字2'|more