1. 程式人生 > >linux文件管理之bash shell

linux文件管理之bash shell

重命名 不能 secure 沒有 atime cli data tail des

BASH Shell 對文件進行管理


========================================================
創建、復制、刪除、移動、查看、編輯、壓縮、查找

內容提要:
Linux目錄結構
文件定位 路徑
文件管理


一、Linux目錄結構
Windows: 以多根的方式組織文件 C:\ D:\ E:\
Linux: 以單根的方式組織文件 /

/目錄結構: FSH (Filesystem Hierarchy Standard)
[root@localhost ~]# ls /
bin dev lib media net root srv usr

boot etc lib64 misc opt sbin sys var
cgroup home lost+found mnt proc selinux tmp

註:下圖為Centos7目錄結構
技術分享圖片

bin 普通用戶使用的命令 /bin/ls, /bin/date
sbin 管理員使用的命令 /sbin/service
dev 設備文件 /dev/sda,/dev/sda1,/dev/tty1,/dev/tty2,/dev/pts/1, /dev/zero, /dev/null, /dev/random
root root用戶的HOME
home 存儲普通用戶家目錄
lost+found fsck修復時,存儲沒有鏈接的文件或目錄
proc 虛擬的文件系統,反映出來的是內核,進程信息或實時狀態

usr 系統文件,相當於C:\Windows
/usr/local 軟件安裝的目錄,相當於C:\Program
/usr/bin 普通用戶使用的應用程序
/usr/sbin 管理員使用的應用程序
/usr/lib 庫文件Glibc
/usr/lib64 庫文件Glibc
boot 存放的系統啟動相關的文件,例如kernel,grub(引導裝載程序)
etc 配置文件(系統相關如網絡/etc/sysconfig/network,應用相關配置文件如/etc/ssh/sshd_config...)
lib 庫文件Glibc
lib64 庫文件Glibc
tmp 臨時文件(全局可寫:進程產生的臨時文件)
var 存放的是一些變化文件,比如數據庫,日誌,郵件....
mysql: /var/lib/mysql
vsftpd: /var/ftp
mail: /var/spool/mail
cron: /var/spool/cron
log: /var/log
臨時文件: /var/tmp(進程產生的臨時文件)

==設備(主要指存儲設備)掛載目錄==
media 移動設備默認的掛載點
mnt 手工掛載設備的掛載點
misc automount進程掛載
net automount進程掛載


命令存儲位置:
/bin 普通用戶使用的命令 /bin/ls, /bin/date RHEL7淘汰
/sbin 管理員使用的命令 RHEL7淘汰
/usr/bin 普通用戶使用的應用程序
/usr/sbin 管理員使用的應用程序

庫文件存儲位置:
/lib 庫文件Glibc RHEL7淘汰
/lib64 庫文件Glibc RHEL7淘汰
/usr/lib 庫文件Glibc
/usr/lib64 庫文件Glibc


==================================================================

***文件時間


ls -l 文件名 僅看的是文件的修改時間

Linux文件有四種時間:
# stat anaconda-ks.cfg //查看文件的詳細屬性(其中包括文件時間屬性)
訪問時間:atime,查看內容 //RHEL6會延後修改atime
修改時間:mtime,修改內容
改變時間:ctime,文件屬性,比如權限
刪除時間:dtime,文件被刪除的時間

[root@localhost ~]# ls -l install.log
-rw-r--r-- 1 root root 34793 10-23 13:49 install.log

[root@localhost ~]# stat install.log
File: “install.log”
Size: 34793 Blocks: 80 IO Block: 4096 一般文件
Device: 802h/2050d Inode: 65282 Links: 1
Access: (0644/-rw-r--r--) Uid: ( 0/ root) Gid: ( 0/ root)
Access: 2012-10-23 16:53:20.000000000 +0800
Modify: 2012-10-23 13:49:46.000000000 +0800
Change: 2012-10-23 13:49:52.000000000 +0800

註:RHEL6開始relatime,atime延遲修改,必須滿足其中一個條件:
1. 自上次atime修改後,已達到86400秒;
2. 發生寫操作時;



***文件類型:


通過顏色判斷文件的類型是不一定正確的!!!
Linux系統中文件是沒有擴展名!!!

方法一:
ls -l 文件名 //看第一個字符
- 普通文件(文本文件,二進制文件,壓縮文件,電影,圖片。。。)
d 目錄文件(藍色)
b 設備文件(塊設備)存儲設備硬盤,U盤 /dev/sda, /dev/sda1
c 設備文件(字符設備)打印機,終端 /dev/tty1
s 套接字文件
p 管道文件
l 鏈接文件(淡藍色)

[root@localhost ~]# ll -d /etc/hosts /bin/ls /home /dev/sda /dev/tty1 /etc/grub2.cfg /dev/log /run/dmeventd-client
-rwxr-xr-x. 1 root root 117616 Nov 20 2015 /bin/ls
srw-rw-rw- 1 root root 0 Mar 14 2017 /dev/log
brw-rw---- 1 root disk 8, 0 Mar 14 09:03 /dev/sda
crw--w---- 1 root tty 4, 1 Mar 14 09:03 /dev/tty1
lrwxrwxrwx. 1 root root 22 Dec 21 01:40 /etc/grub2.cfg -> ../boot/grub2/grub.cfg
-rw-r--r-- 1 root root 392 Feb 22 15:51 /etc/hosts
drwxr-xr-x. 10 root root 4096 Mar 14 11:00 /home


方法二:file
[yang@localhost ~]$ file /etc/hosts
/etc/hosts: ASCII text

[yang@localhost ~]$ file /bin/ls
/bin/ls: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 2.6.32, BuildID[sha1]=aa7ff68f13de25936a098016243ce57c3c982e06, stripped

[yang@localhost ~]$ file /dev/sda
/dev/sda: block special

[yang@localhost ~]$ file /dev/tty1
/dev/tty1: character special

[yang@localhost ~]$ file /etc/grub2.cfg
/etc/grub2.cfg: broken symbolic link to `../boot/grub2/grub.cfg‘

[yang@localhost ~]$ file /home
/home: directory

[yang@localhost ~]$ file /run/dmeventd-client
/run/dmeventd-client: fifo (named pipe)
=================================================================


二、路徑 (定位文件)
你要在哪兒創建文件?
你要將什麽文件復制到什麽地方?
你要刪除什麽地方的什麽文件?

技術分享圖片


/home/alice/file1 和 /home/bob/file1 不是同一文件!!!
/abc/file5 和 abc/file5 有可能是不一樣的!!!
命名規則:
1、長度不能超過255個字符;
2、不能使用/當文件名;
3、嚴格區分大小寫;

絕對路徑: 從/開始的路徑 /home/alice/file1
相對路徑: 相對於當前目錄開始 a.txt ./a.txt ../bob/b.txt [假如:此時在目錄/home/alice]

# useradd alice
# touch /home/alice/file1
# touch ~/file2
# touch ~alice/file3

# pwd
# mkdir abc
# touch ../file3
# touch file4
# touch abc/file5


三、文件管理
1. 文件管理之:cd 改變目錄
cd 絕對路徑 cd /home/alice cd ~alice
cd 相對路徑 cd Desktop/abc cd .. cd .
=======================================================
cd 專用:
cd - 返回上次目錄
cd 直接回家
=======================================================


2. 文件管理之:創建/復制/移動/刪除
==創建
文件 touch
# touch file1.txt //無則創建,有則修改時間
# touch file3 file4
# touch /home/file10.txt
# touch /home/file5 file6
# touch /home/{zhuzhu,gougou}
# touch file{1..20}
# touch file{a..c}
# touch yang{a,b,c} //{}集合,等價touch yanga yangb yangc

目錄 mkdir
# mkdir dir1
# mkdir /home/dir2 /home/dir3
# mkdir /home/{dir4,dir5}
# mkdir -v /home/{dir6,dir7}
# mkdir -v /hoem/dir8/111/22
# mkdir -pv /hoem/dir8/111/222 //包括其父母的創建,不會有任何消息輸出
# mkdir -pv /home/{yang/{dir1,111},localhost}


==復制 cp
Usage: cp [OPTION]... [-T] SOURCE DEST
# cd
# mkdir /home/dir{1,2}
# cp -v install.log /home/dir1
# cp -v install.log /home/dir1/yang.txt
# cp -rv /etc /home/dir1
# cp -v install.log /home/dir90 //沒有/home/dir90
# cp -v install.log /home/dir2
# cp -v anaconda-ks.cfg !$
# cp -rv /etc/sysconfig/network-scripts/ifcfg-eth0 /etc/passwd /etc/grub.conf /home/dir2 //將多個文件拷貝到同一個目錄
# cp -rv /etc/sysconfig/network-scripts/ifcfg-eth0 /etc/passwd /etc/grub.conf /etc/hosts .
# cp -r /etc /tmp
# cp -rf /etc /tmp
# \cp -r /etc /tmp

[root@localhost ~]# type -a cp
cp is aliased to `cp -i‘
cp is /bin/cp

[root@localhost ~]# cp -rv /etc/sysconfig/network-scripts/{ifcfg-eth0,ifcfg-eth0.bak}
[root@localhost ~]# cp -rv /etc/sysconfig/network-scripts/ifcfg-eth0{,-org}
[root@localhost ~]# cp -rv /etc/sysconfig/network-scripts/{ifcfg-eth0,yang-eth0}


==移動 mv
Usage: mv [OPTION]... [-T] SOURCE DEST
# mv file1 /home/dir3 將file2移動到/home/dir3
# mv file2 /home/dir3/file20 將file2移動到/home/dir3,並改名為file20
# mv file4 file5 將file4重命名為file5,當前位置的移動就是重命名

==刪除 rm
示例1:刪除/home/dir1
# cd /home
# rm -rf dir1
-r 遞歸
-f force強制
-v 詳細過程

示例2:
[root@localhost ~]# mkdir /home/dir10
[root@localhost ~]# touch /home/dir10/{file2,file3,.file4}
[root@localhost ~]# rm -rf /home/dir10/* //不包括隱藏文件
[root@localhost ~]# ls /home/dir10/ -a
. .. .file4

示例3:
[root@localhost ~]# rm -rf file*
[root@localhost ~]# rm -rf *.pdf


3. 文件管理之:查看文件內容
==文本文件 (cat tac less more head tail tailf grep ...)
/bin/date
/etc/hosts
/etc/sysconfig/network
/etc/sysconfig/network-scripts/ifcfg-eth0
/etc/passwd
/etc/shadow
/etc/group
/etc/grub2.cfg
/etc/resolv.conf
/etc/profile //設置系統環境變量
/etc/bashrc //影響bash shell環境
/var/log/messages //系統主日誌文件
/var/log/secure //跟安全相關的日誌如ssh登錄,本地登錄...

cat
-n 顯示行號
-A 包括控制字符(換行符/制表符)
linux $
Windows ^M$

less more head tail tailf
[root@localhost ~]# head /etc/passwd
[root@localhost ~]# head -2 /etc/passwd
[root@localhost ~]# tail /etc/passwd
[root@localhost ~]# tail -1 /etc/passwd
[root@localhost ~]# tail /var/log/messages
[root@localhost ~]# tail -20 /var/log/messages
[root@localhost ~]# tail -f /var/log/secure //-f 動態查看文件的尾部
[root@localhost ~]# tail -F /var/log/secure //-F 動態查看文件的尾部
註:vim, gedit編輯文件時,索引號會改變

grep 針對文件內容進行過濾
# grep ‘root‘ /etc/passwd
# grep ‘^root‘ /etc/passwd
# grep ‘bash$‘ /etc/passwd
# grep ‘failure‘ /var/log/secure


4. 文件管理之:修改文件內容
[root@localhost ~]# ll -a > list.txt
文件編輯器 gedit
文件編輯器 vi, vim, nano



本節作業:

1. 完成課堂中學習的所有內容

2. type file stat 3個命令的區別是什麽


3. 文件管理命令練習:
在student用戶主目錄下創建一個臨時目錄tmp;
在臨時目錄下創建一個文件,文件名為a.txt;
將a.txt復制成b.txt;將b.txt改名成c.txt;
為c.txt創建符號鏈接,鏈接文件名為linkc.txt;
使用gzip壓縮創建/etc的歸檔,將文件另存為/home/student/tmp/etc.tar.gz;
將壓縮的歸檔文件解壓到/backups目錄;
刪除tmp目錄




linux文件管理之bash shell