一、日常使用命令/常用快捷键命令开关机命令 1、shutdown –h now:立刻进行关机 2、shutdown –r now:现在重新启动计算机 3、reboot:现在重新启动计算机 4、su -:切换用户;passwd:修改用户密码 5、logout:用户注销 常用快捷命令 1、tab = 补全 2、ctrl + l -:清屏,类似clear命令 3、ctrl + r -:查找历史命令(history);ctrl+c = 终止 4、ctrl+k = 删除此处至末尾所有内容 5、ctrl+u = 删除此处至开始所有内容 常用工具命令man:帮助命令 wc:文本统计统计 wordcount 3 5 29 a.txt 行数 单词数 字符数 文件名 常见参数: -l:只查看行数 -w: 只查看单词数 -c:只查看字符数 du:文件大小统计 格式:du [选项参数] dir_path 常见参数: -s:只统计该文件目录的大小,不递归 -h:人性化的显示单位 find:文件检索命令find path -option [ -print ] [ -exec -ok command ] {} \; find 根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部份为 path,之后的是 expression。如果 path 是空字串则使用目前路径,如果 expression 是空字串则使用 -print 为预设 expression。 expression 中可使用的选项有二三十个之多,在此只介绍最常用的部份。 -mount, -xdev : 只检查和指定目录在同一个文件系统下的文件,避免列出其它文件系统中的文件 -anewer file : 比文件 file 更晚被读取过的文件 -cnewer file :比文件 file 更新的文件 -empty : 空的文件-gid n or -group name : gid 是 n 或是 group 名称是 name -ipath p, -path p : 路径名称符合 p 的文件,ipath 会忽略大小写 -name name, -iname name : 文件名称符合 name 的文件。iname 会忽略大小写 -size n : 文件大小 是 n 单位,b 代表 512 位元组的区块,c 表示字元数,k 表示 kilo bytes,w 是二个位元组。-type c : 文件类型是 c 的文件。 -pid n : process id 是 n 的文件 你可以使用 ( ) 将运算式分隔,并使用下列运算。 将目前目录及其子目录下所有延伸档名是 c 的文件列出来。 将目前目录及其子目录下所有最近 20 天内更新过的文件列出 查找/var/log目录中更改时间在7日以前的普通文件,并在删除之前询问它们: # find /var/log -type f -mtime +7 -ok rm {} \; 查找前目录中文件属主具有读、写权限,并且文件所属组的用户和其他用户具有读权限的文件: # find . -type f -perm 644 -exec ls -l {} \; 为了查找系统中所有文件长度为0的普通文件,并列出它们的完整路径: # find / -type f -size 0 -exec ls -l {} \;
二、常用目录/文件操作命令1.展示目录列表命令ls(list) ls 展示当前目录下的可见文件 ls -a 展示当前目录下所有的文件(包括隐藏的文件) ls -l(ll) 展示当前目录下文件的详细信息 ll -a 展示当前目录下所有文件的详细信息 ll -h 友好的显示当前目录下文件的详细信息(其实就是文件的大小可读性更强了) pwd:显示目前的目录 2.切换目录命令cd(change directory) cd test 切换到test目录下 cd .. 切换到上一级目录 cd / 切换到系统根目录下 cd ~ 切换到当前用户的根目录下 cd - 切换到上一级所在的目录 3.目录的创建(mkdir)和删除(rmdir)命令 mkdir test 在当前目录下创建一个test目录 mkdir -p test/a/b 在test目录下的a目录下创建一个b目录,如果上一级目录不存在,则连它的父目录一起创建 rmdir test 删除当前目录下的test目录(注意:该命令只能够删除空目录) 4.文件的创建(touch)和删除(rm)命令 touch test.txt 在当前目录下创建一个test.txt的文件 rm test.txt 删除test.txt的文件(带询问的删除,需输入y才能删除) rm -f test.txt 直接删除text.txt文件 rm -r test 递归删除,即删除test目录以及其目录下的子目录(带询问的删除) rm -rf test 直接删除test目录以及其目录下的子目录 5.文件打包或解压命令tar
打包并压缩文件
Linux中的打包文件一般是以.tar结尾的,压缩的命令一般是以.gz结尾的。 而一般情况下打包和压缩是一起进行的,打包并压缩后的文件的后缀名一般.tar.gz。 命令:tar -zcvf 打包压缩后的文件名 要打包压缩的文件 其中:z:调用gzip压缩命令进行压缩 c:打包文件 v:显示运行过程 f:指定文件名 示例:打包并压缩/test下的所有文件 压缩后的压缩包指定名称为xxx.tar.gz tar -zcvf xxx.tar.gz aaa.txt bbb.txt ccc.txt 或:tar -zcvf xxx.tar.gz /test/*
解压压缩包(重点)
命令:tar [-xvf] 压缩文件 其中:x:代表解压 示例:将/test下的xxx.tar.gz解压到当前目录下 tar -xvf xxx.tar.gz
示例:将/test下的xxx.tar.gz解压到根目录/usr下 tar -xvf xxx.tar.gz -C /usr------C代表指定解压的位置 Linux的权限命令
权限是Linux中的重要概念,每个文件/目录等都具有权限,通过ls -l命令我们可以 查看某个目录下的文件或目录的权限 文件的类型: d:代表目录 -:代表文件 l:代表链接(可以认为是window中的快捷方式) 后面的9位分为3组,每3位置一组,分别代表属主的权限,与当前用户同组的 用户的权限,其他用户的权限 r:代表权限是可读,r也可以用数字4表示 w:代表权限是可写,w也可以用数字2表示 x:代表权限是可执行,x也可以用数字1表示 属主(user) | 属组(group) | 其他用户 | r | w | x | r | w | x | r | w | x | 4 | 2 | 1 | 4 | 2 | 1 | 4 | 2 | 1 |
linux中用户的分类 小李 小李对象 老王 所有者u 同组用户g 其他人o linux中文件权限 读r 写w 执行x 没有权限- 文件详情信息: -rw-r--r--. 1 root root 5 Aug 28 02:27 a.txt d rwx r-x r-x. 2 root root 4096 Aug 27 08:52 test 第一位:d:目录,-:文件 rw- r-- r-- 所有者 同组用户 其他人 只有读写 只有读 只有读 1:该文件的链接数 root:文件所属者 root:文件所属组 5 Aug 28 02:27:最后的修改时间 修改文件/目录的权限的命令:chmod 示例:修改/test下的aaa.txt的权限为属主有全部权限,属主所在的组有读写权限, 其他用户只有读的权限 chmod u=rwx,g=rw,o=r aaa.txt 上述示例还可以使用数字表示: chmod 764 aaa.txt 修改文件的所属用户和所属组 chown chown username:groupName aa.txt chown username: aa.txt chown :groupName aa.txt -R:递归子目录修改所属者和所属组 三、文件/文件夹的cp rm及文件的查看cp (复制文件或目录)cp 即拷贝文件和目录。 语法: [root@www ~]# cp [-adfilprsu] 来源档(source) 目标档(destination)
[root@www ~]# cp [options] source1 source2 source3 .... directory 选项与参数: -a:相当於 -pdr 的意思,至於 pdr 请参考下列说明;(常用) -d:若来源档为连结档的属性(link file),则复制连结档属性而非文件本身; -f:为强制(force)的意思,若目标文件已经存在且无法开启,则移除后再尝试一次; -i:若目标档(destination)已经存在时,在覆盖时会先询问动作的进行(常用) -l:进行硬式连结(hard link)的连结档创建,而非复制文件本身; -p:连同文件的属性一起复制过去,而非使用默认属性(备份常用); -r:递归持续复制,用於目录的复制行为;(常用) -s:复制成为符号连结档 (symbolic link),亦即『捷径』文件; -u:若 destination 比 source 旧才升级 destination !
用 root 身份,将 root 目录下的 .bashrc 复制到 /tmp 下,并命名为 bashrc [root@www ~]# cp ~/.bashrc /tmp/bashrc
[root@www ~]# cp -i ~/.bashrc /tmp/bashrc
cp: overwrite `/tmp/bashrc'? n <==n不覆盖,y为覆盖 rm (移除文件或目录)语法: rm [-fir] 文件或目录 选项与参数: 将刚刚在 cp 的实例中创建的 bashrc 删除掉! [root@www tmp]# rm -i bashrc
rm: remove regular file `bashrc'? y 如果加上 -i 的选项就会主动询问喔,避免你删除到错误的档名! mv (移动文件与目录,或修改名称)语法: [root@www ~]# mv [-fiu] source destination
[root@www ~]# mv [options] source1 source2 source3 .... directory 选项与参数: -f :force 强制的意思,如果目标文件已经存在,不会询问而直接覆盖; -i :若目标文件 (destination) 已经存在时,就会询问是否覆盖! -u :若目标文件已经存在,且 source 比较新,才会升级 (update)
复制一文件,创建一目录,将文件移动到目录中 [root@www ~]# cd /tmp
[root@www tmp]# cp ~/.bashrc bashrc
[root@www tmp]# mkdir mvtest
[root@www tmp]# mv bashrc mvtest 将某个文件移动到某个目录去,就是这样做! 将刚刚的目录名称更名为 mvtest2 [root@www tmp]# mv mvtest mvtest2
Linux 文件内容查看Linux系统中使用以下命令来查看文件的内容: 你可以使用 man [命令]来查看各个命令的使用文档,如 :man cp。 cat由第一行开始显示文件内容 语法: cat [-AbEnTv] 选项与参数: -A :相当於 -vET 的整合选项,可列出一些特殊字符而不是空白而已; -b :列出行号,仅针对非空白行做行号显示,空白行不标行号! -E :将结尾的断行字节 $ 显示出来; -n :列印出行号,连同空白行也会有行号,与 -b 的选项不同; -T :将 [tab] 按键以 ^I 显示出来; -v :列出一些看不出来的特殊字符
检看 /etc/issue 这个文件的内容: [root@www ~]# cat /etc/issue
CentOS release 6.4 (Final)
Kernel \r on an \m tactac与cat命令刚好相反,文件内容从最后一行开始显示,可以看出 tac 是 cat 的倒着写!如: [root@www ~]# tac /etc/issue
Kernel \r on an \m
CentOS release 6.4 (Final) nl显示行号 语法: nl [-bnw] 文件 选项与参数: 实例一:用 nl 列出 /etc/issue 的内容 [root@www ~]# nl /etc/issue
1 CentOS release 6.4 (Final)
2 Kernel \r on an \m more一页一页翻动 [root@www ~]# more /etc/man.config
#
# Generated automatically from man.conf.in by the
# configure script.
#
# man.conf from man-1.6d
....(中间省略)....
--More--(28%) <== 重点在这一行喔!你的光标也会在这里等待你的命令 在 more 这个程序的运行过程中,你有几个按键可以按的: 空白键 (space):代表向下翻一页; Enter :代表向下翻『一行』; /字串 :代表在这个显示的内容当中,向下搜寻『字串』这个关键字; :f :立刻显示出档名以及目前显示的行数; q :代表立刻离开 more ,不再显示该文件内容。 b 或 [ctrl]-b :代表往回翻页,不过这动作只对文件有用,对管线无用。
less一页一页翻动,以下实例输出/etc/man.config文件的内容: [root@www ~]# less /etc/man.config
#
# Generated automatically from man.conf.in by the
# configure script.
#
# man.conf from man-1.6d
....(中间省略)....
: <== 这里可以等待你输入命令! less运行时可以输入的命令有: head取出文件前面几行 语法: head [-n number] 文件 选项与参数: [root@www ~]# head /etc/man.config 默认的情况中,显示前面 10 行!若要显示前 20 行,就得要这样: [root@www ~]# head -n 20 /etc/man.config tail取出文件后面几行 语法: tail [-n number] 文件 选项与参数: [root@www ~]# tail /etc/man.config
# 默认的情况中,显示最后的十行!若要显示最后的 20 行,就得要这样:
[root@www ~]# tail -n 20 /etc/man.config
系统常用操作命令visudo:编辑sudo命令的配置 编辑第98行 ## Allow root to run any commands anywhere root ALL=(ALL) ALL 用户名 登录的主机=(以什么样的身份运行) 可以执行什么命令 如果想让huadian用户也居于root相关权限。。 huadian ALL=(root) NOPASSWD:service iptables status huadian ALL=(root) NOPASSWD:service iptables start 推荐用法 huadian ALL=(root) NOPASSWD:ALL 使用权限:sudo service iptables status ----(检查防火墙状态)网络管理:ping、ifconfig 服务管理命令: service:必须掌握 格式: service s_name start|stop|status|restart linux系统所有自带服务名称:/etc/init.d/ 常用: 关闭防火墙服务 service iptables stop 重启网络服务: service network restart mysql数据库服务的名称: mysql版本低于5.5 mysqld mysql版本高于5.5 mysql chkconfig:设置是否开机启动 :必须掌握 判定是否开机启动 chkconfig iptables --list 2.3.4.5是on表示开机启动 设置 chkconfig iptables on|off 进程管理:ps ps:查当前进程 查看java的进程 ps -ef | grep java jps:==(ps -ef | grep java) 只有在linux中安装了JDK才能用 kill :杀死某个进程 kill -9 pid 端口管理 nststat:查看端口开放情况 -a:表示列举所有的连接、服务器监听 -t:列出所有tcp协议的服务 -u:列出所有udp协议的服务 -n:使用端口号来显示 -l:列出所有的监听 -p:列出所有服务的进程id(pid) 常用:netstat -atunlp redhat的selinux安全机制 关闭selinux安全机制 vim /etc/selinux/config SELINUX=disabled 重启机器生效
|