1.Linux介绍\GNU\GLP\历史\发行版
2.VmWare 安装CnetOS7系统
3.Vmware快照
2.Bash
1.Bash能做什么
2.Bash怎么使用 单条命令 效率低 适合简单,或者少量的任务 Shell脚本 效率高 适合复杂,重复性的工作
3.Bash提示符[root@oldboyedu ~]# 当前登录系统的用户 --->root 当前系统的主机名称 --->oildboyedu 当前用户所在的家目录 ---> ~ 表示当前用户的家目录 通常情况下是超级管理员 # 普通用户 $
4.Bash基础语法命令
[选项] [参数] 命令 (打针) 选项 (轻重)参数 (往哪打) ls -la /home/ # 以长格式显示/home/所有内容,包括隐藏文件
5.Bash常用特性
1.tab补全 (必须)
2.快捷键 ctrl+a,e,c,l,w,u,k,r
3.命令别名 alias unalias
4.历史记录history
5.命令帮助 man --help
6.系统目录结构Windows C:\ D:\ E:\ Linux / ---> 单根组织结构
在Linux / 目录下有很多的二级目录,这么目录都是什么意思
/bin #存放都是二进制可执行的命令
/sbin #超级管理员可执行的二进制命令
/home #普通用户的家目录 /home/oldboy
/root # 超级管理员的家目录 (普通用户无权限)
/etc # 系统的配置文件存放路径,包括后续安装的一些服务
/dev # 存放设备目录
/dev/null #黑洞设备, 只进不出
/dev/random # 随机设备
/dev/zero # 能源源不断的产生数据, 取款机
/proc # 虚拟系统文件 (显示系统当前进程正在运行的状态)
/usr # 存放系统文件 和Windows的C盘下的WIndows目录一样
/usr/local #
/usr/bin # 和/bin一致,只不过/usr/bin才是真实的命令存放 路径
/usr/sbin # 和/sbin一致,只不过/usr/sbin才是真实的命令存 放路径/usr/lib # 库文件, 命令所依赖的库文件
/usr/lib64 # 64库文件, 命令所依赖的库文件
/boot # 系统启动时的引导目录 , 存放的是kernel,grub菜单
/run # 存放进程锁文件
/opt #早起第三方厂商安装软件存放的目录
/mnt # 挂载, 将目录与设备进行关联, 比如 硬盘,光盘
9.文件路径定位/etc/hostname 文件位置+文件名称=路径 换句话说: 路径则是对文件定 义的一种方式.
绝对路径: 只要以/ 开始的路径,.都算绝对路径
相对路径: 相对于当前目录来说的路径 . 当前目录 .. 当前目录的上 一级目录
小结: 到底使用相对路径还是绝对路径: 没有明确说法,取决于你当 前所在的位置
10.文件管理命令mkdir #创建目录 touch #创建文件 mv #移动或重新命名 rm # 删除文件
#2 今日内容 文件管理 --> 创建 移动 删除 复制----------------------------------------cp复制---------------------------------------#选项:
-v:详细显示命令执行的操作 # -r: 递归处理目录与子目录 # -p: 保留源文件或目录的属性
#1.将当前目录下的file文件,复制到/tmp/目录下,并重新命名为 file_copy
[root@oldboyedu ~]# cp file /tmp/file_copy
[root@oldboyedu ~]# ls /tmp/file_copy /tmp/file_copy#2.将file1复制到/tmp目录下,
[root@oldboyedu ~]# cp file1 /tmp/
[root@oldboyedu ~]# cp file1 /tmp/file1 #这种很少使用#3.在拷贝文件的过程中,如何保持文件原有的属性不发生变化
-rw-r--r--. 1 root root 0 Jul 29 10:07 file
#第一次修改
-rwxrwxrwx. 1 root root 0 Jul 29 10:03 file
#第二次修改
-rwxrwxrwx. 1 adm adm 0 Jul 29 10:03 file
#在拷贝的过程中,文件权限和身份都发生变化了
[root@oldboyedu ~]# cp file /tmp/
[root@oldboyedu ~]# ll /tmp/file
-rw-r--r--. 1 root root 0 Jul 29 10:11 /tmp/file#在拷贝过程中加上-p参数,保存文件原有的属性
[root@oldboyedu ~]# cp -p file /tmp/
[root@oldboyedu ~]# ll /tmp/file
-rwxrwxrwx. 1 adm adm 0 Jul 29 10:03 /tmp/file#4.如何拷贝一个文件夹,并且文件夹中有很多的子文件, -r递归复制 (文件夹===目录) [root@oldboyedu ~]# cp /etc/ /tmp/
cp: omitting directory ‘/etc/’
[root@oldboyedu ~]# cp /etc/ /tmp/ -r
2.文件管理之:查看文件内容(cat less more head tail grep ...)
#5.拷贝不同路径下的不同文件至同一个目录下 -v是显示详细过程
[root@oldboyedu ~]# cp file1 /etc/hostname /etc/hosts /opt/ -v
‘file1’ -> ‘/opt/file1’
‘/etc/hostname’ -> ‘/opt/hostname’
‘/etc/hosts’ -> ‘/opt/hosts’#6.拷贝不同路径下的不同文件+不同的目录 至同一个位置,怎么办?
[root@oldboyedu ~]# cp -rp file1 oldboy1/ file /etc/ /mnt/ /opt/
[root@oldboyedu ~]# ls /opt/ etc file file1 mnt oldboy1#7.在复制过程中频繁触发重复复制,提示确认操作?
[root@oldboyedu ~]# \cp -r /etc/ /opt/
[root@oldboyedu ~]# /bin/cp -r /etc/ /opt/
#8.扩展项
[root@oldboyedu ~]# cp {file5,file5-bak} -v
‘file5’ -> ‘file5-bak’
[root@oldboyedu ~]# cp /etc/sysconfig/networkscripts/{ifcfg-ens32,ifcfg-ens32-bak}
#------cat
[root@oldboyedu ~]# cp /etc/passwd ./pass
[root@oldboyedu ~]# cat pass #查看文件的所有内容,从 头到尾
[root@oldboyedu ~]# cat -n pass #查看一个文件有多少行 -n
[root@oldboyedu ~]# cat -A pass ##查看文件的特殊符号, 比如文件中存在tab键#cat扩展使用,创建一个文件,并往里写入内容
[root@oldboyedu ~]# cat >> test.txt < test1 test2 test3 EOF #EOF 代表结束 [root@oldboyedu ~]# cat test.txt test1 test2 test3#------less、more # less /etc/services #使用光标上下翻动,空格进行翻页,q退 出 #------more /etc/services #使用回车上下翻动,空格进行翻页,q退 出 #------head [root@oldboyedu ~]# head pass #查看头部内容,默认前十行 [root@oldboyedu ~]# head -n5 pass #查看头部5行,使用-n指定 [root@oldboyedu ~]# ps aux | head -5 #了解#------tail # tail pass #查看文件尾部默认十行[root@oldboyedu ~]# tail -20 /var/log/secure [root@oldboyedu ~]# tail -f /var/log/messages #-f查看文件尾部的变化 [root@oldboyedu ~]# tailf /var/log/messages #查看文件 尾部的变化 [root@oldboyedu ~]# ps aux | tail -5 #了解#------grep过滤文件内容#1. 过滤出pass文件中的root相关的行 [root@oldboyedu ~]# grep "root" pass root:x:0:0:root:/root:/bin/bash operator:x:11:0:operator:/root:/sbin/nologin#2.过滤pass文件中,匹配以root开头的行 [root@oldboyedu ~]# grep "^root" pass root:x:0:0:root:/root:/bin/bash #3.过滤pass文件中,匹配以bash结尾的行 [root@oldboyedu ~]# grep "bash$" pass root:x:0:0:root:/root:/bin/bash jack:x:1000:1000::/home/jack:/bin/bash#4.显示行号 [root@oldboyedu ~]# grep -n "bash$" pass 1:root:x:0:0:root:/root:/bin/bash 23:jack:x:1000:1000::/home/jack:/bin/bash#5.扩展了解 grep -n -A 2 "Failed" /var/log/secure #匹 配/var/log/secure文件中Failed字符串,并打印它的下2行 grep -n -B 2 "Failed" /var/log/secure #匹 配/var/log/secure文件中Failed字符串,并打印它的上2行 grep -n -C 2 "Failed" /var/log/secure #匹 配/var/log/secure文件中Failed字符串 #6.过滤出包含ftp的行 [root@oldboyedu ~]# grep "ftp" pass ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin#7.过滤除了ftp的行,其他的全部显示 [root@oldboyedu ~]# grep -v "ftp" pass #8.忽略大小写方式#2 今日总结 1.文件命令 cp cat [root@oldboyedu ~]# grep -i "ftp" pass ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin #9.过滤pass文件中以sync结尾的,或者ftp相关的行,打印出来.同时不区分大小写 grep -Ei "sync$|ftp" pass #grep筛选的目标,会将整行打印出来.##grep相关练习题 0、显示当前pass文件中,root、adm或ftp用户相关的信息 [root@oldboyedu ~]# grep -E "^root|^ftp|^adm" pass root:x:0:0:root:/root:/bin/bash adm:x:3:4:adm:/var/adm:/sbin/nologin ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin 1、显示/proc/meminfo文件中以不区分大小的s开头的行: [root@oldboyedu ~]# grep -i "^s" /proc/meminfo 2、显示/etc/passwd中以nologin结尾的行; [root@oldboyedu ~]# grep "nologin$" /etc/passwd 3、显示/etc/inittab中以#开头,而后又跟了任意字符的行; [root@oldboyedu ~]# grep -n "^# .*" /etc/inittab . 代表任意单个字符 [a-z] [A-Z] [0-9] .表示所有 .* 代表所有的任意字符 ^$代表任意空格 less more head tail tailf grep 明天: 文件的下载 wget curl 文件的上传 rz sz #不支持拷贝文件夹 文件内容进行 排序 sort ,去重uniq, 统计 文件的截取 cut awk sed ....