linux指令借鑑和整理,供參考

Linux命令
Linux命令經常使用的幾個命令html

1.cdjava

切換目錄 cd ..(返回上一級的目錄) cd ~(切換到當前用戶的家目錄)cd - (返回上一次的目錄)node

2.pwdpython

顯示當前目錄mysql

3.mkdirlinux

新建一個文件夾 mkdir xiaoqian(新建xiaoqian文件夾)mkdir -p(建立沒有的目錄)nginx

4.rmdirweb

刪除一個空文件夾sql

5.ls shell

顯示當前目錄下的文件夾 ls -l(查看詳細信息) ls -a(顯示隱藏文件)ls -all(顯示隱藏文件的詳細信息)

6.whoami

查看當前用戶是誰

7.who

顯示當前有那些用戶

8.date

查看當前日期 更改日期 用date + 月日時分年(date '032817062018')hwclock -s (同步系統的時間)

9.cal

查看日曆

10.clear

清除屏幕 Ctrl + L

11.sudo -s

切換管理員模式

12.useradd

建立用戶 useradd xiaoqian

13.passwd

修改密碼 passwd xaioqian

14.Ctrl + C

終止當前的命令

15.exit

退出當前的操做 也能夠退出當前普通用戶

16.su

切換用戶 su - xiaoqian 管理員切換到普通用戶不須要輸入密碼

17.man

幫助信息查詢 man useradd(查看useradd的使用方法 輸入q 能夠退出查詢)或者使用useradd --help查詢

18.init 0

關機 或 shutdown(須要root用戶才能關閉)

19.touch

新建一個文本 touch xiaoqian.py

20.rm

刪除目錄文件包括空文件rm xiaoqian(刪除有提示) rm -r xiaoqian.py (強制刪除) rm -rf xiaoqian.py(一次性強制刪除目錄下的全部文件)

21.cp

複製文件或目錄 cp xiaoqian.py /tmp(將xiaoqian.py複製到tmp目錄下) cp -i(提示是否覆蓋之前的文件) cp -r(遞歸拷貝目錄)

22.mv

剪切文件或重命名 mv xiaoqian.py /tmp(將xiaoqian.py剪切到tmp目錄下) mv xiaoqian.py 123.py(將xiaoqian.py改爲123.py)

23.cat

查看文件

24.head

顯示文件前10行 tail -1 xiaoqian.py (顯示文檔第一行)

25.tail

顯示後面幾行 tail -1 xiaoqian.py (顯示文檔最後一行)

26.echo

將信息輸出到屏幕或文件中 echo '你好'>>/tmp/xaioqian.py(將信息你好打印到xiaoqian.py文件最後一行)

27.more

查看文件只能回車翻看文件 more xiaoqiang.py

28.less

查看文件只能上下鍵翻文件 more xiaoqiang.py

29.df

顯示系統屬性 df -lh(使數值更加清晰)

30.ifconfig

獲取網絡接口配置信息

31.ping

網絡命令 用來測試是否與目的機相通聯 是否能拼通

32.od

非文檔文本文件的打開命令

33.which

查詢完整的文件名目錄which ifconfig

34.whereis

查找文檔 至關於find

35.find

搜索文件

36.tar

壓縮文件的命令 tar -cvf test.tar xiaoqian.py(把xiaoqian.py壓縮成test.tar) tar -xvf test.tar(解壓text.tar文件)

37.gzip

壓縮文件命令gzip xiaoqian.py(壓縮) gzip -d xiaoqiang.py.gz(解壓成xiaoqian.py文件)

38.top

顯示動態進程

39.ps

ps -aux(靜態進程)

40.kill

殺進程 kill -9(殺不死時用)

41.reboot

重啓計算機

42.gedit

編輯文本

43.ln

爲文件建立連接 ln -s xiaoqian.py /home (在home下面建立了一個軟連接 名字相同 若是原文件丟失則文件失效)

44.du

顯示文件或目錄所佔的空間大小

45.vi

編輯文件 i(命令模式切換到編輯模式)esc(退出編輯模式) :(進入最後一行):x(保存當前文件) :xq(保存並退出文件)

簡單命令

ifconfig 查看服務器ip地址

ls 查看當前文件夾下的內容

pwd 查看當前全部文件夾

cd 切換文件夾

touch 若是文件不存在建立新的文件

mkdir 建立目錄

rm 刪除指定的文件名

clear 清屏

. 當前目錄
.. 上層目錄
- 前一個工做目錄
~ 當前所在的家目錄
Linux當前路徑PATH

echo $PATH

輸出

複製代碼
/usr/local/sbin:

/usr/local/bin:

/usr/sbin:

/usr/bin:

/root/bin:
複製代碼
vim的工做流程

打開文件 vim alex.txt 進入一個命令模式

輸入字母 i 進入編輯模式

輸入 esc鍵盤 退出編輯模式 而後輸入 :wq 保持並退出

遞歸添加文件夾

mkdir -p /tmp/{alex,wusir}
建立普通用戶

useradd alex
更改密碼

passwd alex
刪庫跑路

rm -rf /*
cat 查看文件內容

ls -la 以樹狀顯示文件夾,顯示隱藏文件

更改主機名字

hostnamectl set-hostname wangdachui
1.查看linux的path變量

echo $PATH
2.簡述linux的文檔目錄結構
是一個樹狀圖
定點是根目錄 /
查看根目錄 ls /
超級用戶root家目錄 /root
普通家目錄 /home

3.遞歸建立文件夾/tmp/oldboy/python/{alex,wusir,nvshen,xiaofeng}

mkdir -p /tmp/oldboy/python/{alex,wusir,nvshen,xiaofeng}
4.顯示/tmp/下全部內容詳細信息

ls /tmp/* -lh

5.簡述 / ~ - 的含義
/ 根目錄
~ 用戶家目錄
- 上一次工做目錄

6.請簡述你如何使用vi命令
1.打開文件 vim filename。此時進入了一個命令模式
2.輸入 字母i ,進入編輯模式
3. 輸入 esc 鍵盤 ,退出編輯模式,此時輸入 :wq 寫入代碼,而且保存退出

7.查看/etc/passwd的內容而且打印行號

cat -n /etc/passwd

8.查看文本有哪些命令?

vi
vim
cat

9.linux xshell經常使用快捷鍵?

tab 自動補全
ctrl + l 清屏
ctrl + c 終止
shift + ctrl + r 快速連接對話
ctrl + d 是快速推出會話

10.如何用echo清空一個文件?

echo > xx.txt

11.複製/tmp/下全部內容到/home,在修改文件前,先拷貝一份,防止內容被破壞

cp -r /tmp/* /home

12.重命名test.py爲my.py

mv test.py my.py

13.強制刪除/tmp下內容

rm -rf /tmp/*

14.找到服務器上的settings.py

find / -type f -name settings.py

15.找到/etc下的網卡配置文件,提示網卡配置文件名是ifc開頭
find /etc -name ifc*

這裏題目,請先cp /etc/passwd /tmp/ 拷貝文件
16.過濾出/tmp/passwd下有關root的信息
cat /etc/passwd |grep '^root'

17.過濾出/tmp/passwd下除了/sbin/nologin的信息,且打印行號
cat /etc/passwd |grep -v /sbin/nologin -n

18.查看/tmp/passwd前25行
head -25 /tmp/passwd

19.查看/tm/passwd後3行
tail -3 /tmp/passwd

20.不間斷打印/var/log/py.log的信息
tail -f /var/log/py.log


23.配置rm別名爲「禁止你用rm,謝謝」,而後取消別名
alias = 「 echo 禁止你用rm,謝謝"
unalias rm

24.將服務器1的/tmp/my.py遠程傳輸到服務器2的/opt/目錄下
scp /tmp/my.py root@服務器2地址ip:/opt/

25.將服務器2的/opt/test.py拷貝到服務器1的/home目錄下
scp -r root@服務器2地址IP:opt/test.py /home

26.統計/var/log/文件夾大小
du -sh /var/log/

27.簡述top的常見參數
-b 批處理
-c 顯示完整的治命令
-I 忽略失效過程
-s 保密模式
-S 累積模式

28.給settings.py加鎖,禁止刪除
lsattr settings.py #查看是否加鎖

chattr +a settings.py #加鎖

chattr -a settings.py #解除

29.同步服務器時間到ntp.aliyun.com
ntpdate -u ntp.aliyun.com

30.下載http://pythonav.cn/xiaobo.jpg圖片
wget http://pythonav.cn/xiaobo.jpg

 

在編輯文件顯示顯示行號

:set nu

echo追加寫入文件
> 重定向覆蓋輸出符
>> 重定向追加輸入符

head -10 filename #查看前10行
tail -10 filename #查看後10行

實時監控 tail -f filename

複製的命令
cp 文件 新文件夾
cp -r 文件夾 新文件夾
歷史記錄命令
history 歷史記錄命令,記錄系統的命令敲過的歷史 以!加數字執行

查找命令,查找機器上的文件,或者文件夾

find / -name views.py #找到機器上全部的 views.py
find /etc -name *.py #找到/etc目錄下 全部名字叫作 .py的文件
find / -name python* #找到 機器上 全部的python開頭的文件和文件夾
find / -type f -name python* #找到機器上 全部以python開頭的文件
find / -type d -name python* #找到機器上全部python開頭的文件夾

查看命令幫助信息,如何查看有什麼參數?
http://linux.51yip.com/

linux的系統管道符
grep -v "^$" settings.py | grep -i "allow"

-v 取反 -i 忽略大小寫

alias添加別名

alias rm="echo 請不要刪庫"

unalias rm 取消別名

.更改主機名字
hostnamectl set-hostname xxx

.xshell的快捷鍵
ctrl + l 清屏
ctrl + d 是快速推出會話 logout
shift + ctrl + r 是快速鏈接會話

遠程傳輸文件的命令

scp 你想傳輸的內容 你想傳輸到的地方

#實例
#把本地的test.sh 傳輸到遠程服務器上
scp test.sh root@服務器ip:/opt/

#把遠端服務器的內容,傳輸到本身的機器上

scp -r root@123.206.16.61:/opt/pythonav /tmp/

 

給文件加鎖

chattr +a fildname

給文件解鎖

chattr -a fildname

查看隱藏鎖

lschattr fildname

wget 資源的url
wget http://www.xiaohuar.com/d/file/20190227/257e9f91df2bbd45c537f9416ae3afbb.jpg

統計文件 文件夾大小的命令
ls -lh 方式1
du -h 文件 #統計文件大小
du -sh . #統計當前文件夾大小合計
du -sh /var/log #統計/var/log大小

linux的任務管理器

top

linux的時間命令

date 能夠查看當前時間日期

進行linux時間同步的命令
ntpdate -u ntp.aliyun.com

下載python3,進行編譯安裝,運行django程序
1.解決python編譯安裝所需的軟件依賴
yum install gcc patch libffi-devel python-devel zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gdbm-devel db4-devel libpcap-devel xz-devel -y

2.下載python3源碼包
wget https://www.python.org/ftp/python/3.6.7/Python-3.6.7.tar.xz

xz -d Python-3.6.7.tar.xz
tar -xf Python-3.6.7.tar #解壓縮,生成一個python源碼文件夾

3.進入python源碼文件夾
cd Python-3.6.7
4.進行編譯安裝,編譯三部曲
1.第一曲
./configure --prefix=/opt/python36/
--prefix 參數解釋:指定python36安裝的位置
2.第二曲
make
3.第三曲 ,此時就開始安裝python3軟件
make install


5.進入python36安裝目錄 ,檢查bin目錄


6.配置python3的環境變量 PATH
1.取出當前的path變量
echo $PATH
2.填寫python3的bin目錄到PATH中
PATH="/opt/python36/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin"
3.講環境變量,寫入到全局配置文件/etc/profile
vim /etc/profile

4.寫入以下代碼,在最底行寫入以下配置
PATH="/opt/python36/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin"
5.讀取配置文件,加載變量生效
source /etc/profile

7.安裝django,運行django
1.安裝django模塊
pip3 install -i https://pypi.douban.com/simple django

2.升級pip
pip3 install --upgrade pip

3.經過命令建立django項目

django-admin startproject crm
django-admin startapp app01

4.關閉防火牆
iptables -F

 

查看系統發行版本

cat /etc/redhat-release

cat /etc/os-release

看系統用戶的id信息
id root

存放用戶信息的文件 /etc/passwd
存放用戶組的文件 /etc/group

用戶切換

su - 用戶名

 

userdel刪除用戶

userdel -rf 用戶名

vim /etc/sudoers #編輯文本給普通用戶加權限

sudo命令,預設以root身份去執行命令
1.配置 /etc/sudoers,添加banzhuren用戶到配置中
找到以下行
## Allow root to run any commands anywhere
root ALL=(ALL) ALL
banzhuren ALL=(ALL) ALL

2.保存退出後,banzhuren用戶便可使用sudo命令了

3.visodu命令,提供對/etc/sudoers文件,進行配置檢測的功能

權限查看

- 橫線表明是普通文本
d 表明文件夾
l 表明軟鏈接

r read 可讀
w write 可寫
x 可執行
- 沒有權限

linux有三個用戶身份
可讀可寫可執行 是有順序的 依次是可讀可寫可執行
user 屬主
group 屬組
others 其餘人

 

加權限

chmod o+w fildname #給其餘用戶加寫權限

chmod 777 fildname #給因此用戶加讀寫執行

 

更改文件屬主

chown 用戶名 文件

更改文件屬組

chgrp 用戶組名 文件

linux的軟鏈接配置

ln -s 目標文件絕對路徑 軟鏈接絕對路徑

ln -s /tmp/file1.txt /opt/file2.txt

#打包,解包命令
#將/tmp下全部內容打包成一個文件 xx.tar


#打包文件 ,不節省磁盤
tar -cvf 打包文件的名字.tar 要打包的內容

#壓縮且打包文件
tar -zcvf 壓縮文件名.tar.gz 要壓縮的內容

#解壓縮
tar -xf 解包文件名.tar

tar -zxvf 壓縮文件名.tar.gz

 

#查看進程
ps -ef |grep python #檢查python進程是否存活


#查看端口
netstat -tunlp | grep 8000


netstat -tunlp |grep

#殺死計算機的進程
1.經過ps -ef | grep 找到進程的pid號

2.經過kill pid 殺死進程

#批量殺死進程

pkill 你想殺死的任務名字

pkill python

#linux防火牆功能

1.linux有倆防火牆,可能會影響我們的 web服務部署
一個是selinux
二個是iptables
三個,雲服務器對外提供防火牆服務的 硬件防火牆

2.關閉防火牆的步驟
iptables -F #清空防火牆規則
systemctl stop firewalld #關閉防火牆服務
systemctl disable firewalld #禁止防火牆開機自啓

3.關閉selinux 步驟以下
1.打開文件vim /etc/selinux/config

2.臨時修改selinux,臨時關閉
getenforce #獲取selinux狀態
setenforce 0 #臨時關閉

想要永久關閉seliunux,執行3,4步驟
3.修改代碼以下
SELINUX=disabled
4.重啓機器後,生效

linux的定時任務
crontab服務

vim /etc/crontab #打開文件,查看語法規則

編輯定時任務的文件
crontab -e

#每分鐘寫入一個信息到文件中
* * * * * /usr/bin/echo "老弟啊,學習很累啊" >> /tmp/xd.txt

#每分鐘執行一次命令
分 時 日 月 周
* * * * * 命令絕對路徑
* * * * * 執行命令

#每小時的3,15分組執行命令
分 時 日 月 周
* * * * * 命令絕對路徑
3,15 * * * * 執行

提早下載好wget工具
yum install wget -y

 

2.下載lrzsz工具,方便linux和windows互相傳文件
yum install lrzsz -y

3.如何手動啓動網卡?
ifup eth33

4.linux的超級用戶是什麼?如何查看用戶身份信息?
root管理員
id root

5.簡單描述linux的用戶管理
用戶
用戶組
其餘用戶

6.如何建立普通用戶,而且修改用戶密碼,而後使用普通用戶登陸
useradd alex
passwd alex

ssh alex@服務器

7.在linux下如何切換用戶
su - alex

8.如何使用root身份執行普通用戶的命令?請詳細說明配置步驟
visudo
配置 /etc/sudoers 添加alex用戶到配置中
## Allow root to run any commands anywhere
root ALL=(ALL) ALL
alex ALL=(ALL) ALL

保存退出後,alex用戶便可使用sudo命令了


9.簡述linux文件的權限有哪些?
r:讀
w:寫
x:執行

10.linux文件權限的755,700是什麼意思?
755 700
user 屬主 rwx rwx
group 屬組 r-x ---
other 其餘人 r-x ---

11.如何修改test.py文件權限爲700
chmod 700 test.py

12.如何修改test.py屬組是oldboy?
chgrp oldboy test.py

13.已知test.py文件權限是rwxr--r--,如何修改權限爲rw-rw-rw
chmod 666 test.py

14.linux如何創建軟鏈接?
ln -s 目標文件地址 快捷地址

15.linux的PS1變量是什麼?如何修改
linux的命令提示符
查找echo PS1 修改PS1="[\u@\h \w \t]\$" 1.vim vi 是什麼? 文本編輯器 2.vim有哪幾種模式? 命令模式 插入模式 底行模式 3.命令模式有哪些? :wq vim 4.輸入模式有哪些? i a o ESC 5.底線命令模式有哪些? : ENTER 6.centos7用什麼命令管理服務 systemctl restart nginx service nginx stop #centos7如下 7.linux解析dns的命令是什麼? nslookup 1.將/tmp/下全部內容壓縮成All_log.tar.gz而且放到/home/下 tar -zcvf /tmp/All_log.tar.gz /tmp/* 2.解壓縮Python源碼包Python-3.7.0b3.tgz tar -zxvf Python-3.7.0b3.tgz 3.查看mysql端口狀態 netstat -tunlp |grep mysql 4.如何查看nginx的進程 ps -ef |grep nginx 5.如何殺死nginx進程 pkill nginx 6.如何修改linux中文 vim /etc/locale.conf 7.如何統計/var/log大小 du -sh /var/log 8.tree是什麼做用? 以樹形結構展現給用戶 9.如何給linux添加一個dns服務器記錄 /etc/hosts 強制寫入本地 須要測試的域名 和ip的解析 vim /etc/resolv.conf nameserver 114.114.114.114 crontab -e 10.每個月的,5,15,25天的晚上5點50重啓nginx 50 17 5,15,25 * * /opt/nginx/sbin/nginx -s reload 11.每週3到周5的深夜11點,備份/var/log /vmtp/ * 23 * * 3-5 /var/log/cp /var/log/ /mtp/ 12.天天早上6.30清空/tmp/內容 30 6 * * * /usr/bin/rm -rf /tmp/* 13.每一個星期三的下午6點到8點的第5,15分鐘執行命令 command 5,15 18-20 * * 3 command 14.編譯安裝軟件有哪些步驟? 1.下載源代碼 2.解壓源代碼 3進入源代碼目錄,開始編譯安裝 4.配置環境變量 15.如何修改python3的環境變量,以及軟鏈接 echoPATH
PATH="/opt/python36/bin/:$PATH"
vim /etc/profile
ln -s /opt/python36/bin/python3.6 /usr/bin/python3

16.請在linux上啓動django,windows上進行訪問

18.如何查看linux端口?
netstat -tunlp

19.如何殺死進程號爲5888?
kill 5888

20。如何關閉iptables?
iptables -F

14.請說出 755, 740分別是什麼權限?
rwxr-xr-x
rwxr-----

15.修改文件權限爲只有屬主可讀可寫可執行?
chmod 070 xx.txt


系統信息
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 註銷

 

文件和目錄
cd /home 進入 '/ home' 目錄'
cd .. 返回上一級目錄
cd ../.. 返回上兩級目錄
cd 進入我的的主目錄
cd ~user1 進入我的的主目錄
cd - 返回上次所在的目錄
pwd 顯示工做路徑
ls 查看目錄中的文件
ls -F 查看目錄中的文件
ls -l 顯示文件和目錄的詳細資料
ls -a 顯示隱藏文件
ls *[0-9]* 顯示包含數字的文件名和目錄名
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 -jxvf archive.tar.bz2 解壓一個bzip2格式的壓縮包
tar -cvfz archive.tar.gz dir1 建立一個gzip格式的壓縮包
tar -zxvf 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 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 比較兩個文件的內容只刪除兩個文件共有的部分

 


字符設置和文件格式轉換
dos2unix filedos.txt fileunix.txt 將一個文本文件的格式從MSDOS轉換成UNIX
unix2dos fileunix.txt filedos.txt 將一個文本文件的格式從UNIX轉換成MSDOS
recode ..HTML < page.txt > page.html 將一個文本文件轉換成html
recode -l | more 顯示全部容許的轉換格式

 

文件系統分析
badblocks -v /dev/hda1 檢查磁盤hda1上的壞磁塊
fsck /dev/hda1 修復/檢查hda1磁盤上linux文件系統的完整性
fsck.ext2 /dev/hda1 修復/檢查hda1磁盤上ext2文件系統的完整性
e2fsck /dev/hda1 修復/檢查hda1磁盤上ext2文件系統的完整性
e2fsck -j /dev/hda1 修復/檢查hda1磁盤上ext3文件系統的完整性
fsck.ext3 /dev/hda1 修復/檢查hda1磁盤上ext3文件系統的完整性
fsck.vfat /dev/hda1 修復/檢查hda1磁盤上fat文件系統的完整性
fsck.msdos /dev/hda1 修復/檢查hda1磁盤上dos文件系統的完整性
dosfsck /dev/hda1 修復/檢查hda1磁盤上dos文件系統的完整性

 

初始化一個文件系統
mkfs /dev/hda1 在hda1分區建立一個文件系統
mke2fs /dev/hda1 在hda1分區建立一個linux ext2的文件系統
mke2fs -j /dev/hda1 在hda1分區建立一個linux ext3(日誌型)的文件系統
mkfs -t vfat 32 -F /dev/hda1 建立一個 FAT32 文件系統
fdformat -n /dev/fd0 格式化一個軟盤
mkswap /dev/hda3 建立一個swap文件系統

 

SWAP文件系統
mkswap /dev/hda3 建立一個swap文件系統
swapon /dev/hda3 啓用一個新的swap文件系統
swapon /dev/hda2 /dev/hdb3 啓用兩個swap分區

 

備份
dump -0aj -f /tmp/home0.bak /home 製做一個 '/home' 目錄的完整備份
dump -1aj -f /tmp/home0.bak /home 製做一個 '/home' 目錄的交互式備份
restore -if /tmp/home0.bak 還原一個交互式備份
rsync -rogpav --delete /home /tmp 同步兩邊的目錄
rsync -rogpav -e ssh --delete /home ip_address:/tmp 經過SSH通道rsync
rsync -az -e ssh --delete ip_addr:/home/public /home/local 經過ssh和壓縮將一個遠程目錄同步到本地目錄
rsync -az -e ssh --delete /home/local ip_addr:/home/public 經過ssh和壓縮將本地目錄同步到遠程目錄
dd bs=1M if=/dev/hda | gzip | ssh user@ip_addr 'dd of=hda.gz' 經過ssh在遠程主機上執行一次備份本地磁盤的操做
dd if=/dev/sda of=/tmp/file1 備份磁盤內容到一個文件
tar -Puf backup.tar /home/user 執行一次對 '/home/user' 目錄的交互式備份操做
( cd /tmp/local/ && tar c . ) | ssh -C user@ip_addr 'cd /home/share/ && tar x -p' 經過ssh在遠程目錄中複製一個目錄內容
( tar c /home ) | ssh -C user@ip_addr 'cd /home/backup-home && tar x -p' 經過ssh在遠程目錄中複製一個本地目錄
tar cf - . | (cd /tmp/backup ; tar xf - ) 本地將一個目錄複製到另外一個地方,保留原有權限及連接
find /home/user1 -name '*.txt' | xargs cp -av --target-directory=/home/backup/ --parents 從一個目錄查找並複製全部以 '.txt' 結尾的文件到另外一個目錄
find /var/log -name '*.log' | tar cv --files-from=- | bzip2 > log.tar.bz2 查找全部以 '.log' 結尾的文件並作成一個bzip包
dd if=/dev/hda of=/dev/fd0 bs=512 count=1 作一個將 MBR (Master Boot Record)內容複製到軟盤的動做
dd if=/dev/fd0 of=/dev/hda bs=512 count=1 從已經保存到軟盤的備份中恢復MBR內容

 

光盤
cdrecord -v gracetime=2 dev=/dev/cdrom -eject blank=fast -force 清空一個可複寫的光盤內容
mkisofs /dev/cdrom > cd.iso 在磁盤上建立一個光盤的iso鏡像文件
mkisofs /dev/cdrom | gzip > cd_iso.gz 在磁盤上建立一個壓縮了的光盤iso鏡像文件
mkisofs -J -allow-leading-dots -R -V "Label CD" -iso-level 4 -o ./cd.iso data_cd 建立一個目錄的iso鏡像文件
cdrecord -v dev=/dev/cdrom cd.iso 刻錄一個ISO鏡像文件
gzip -dc cd_iso.gz | cdrecord dev=/dev/cdrom - 刻錄一個壓縮了的ISO鏡像文件
mount -o loop cd.iso /mnt/iso 掛載一個ISO鏡像文件
cd-paranoia -B 從一個CD光盤轉錄音軌到 wav 文件中
cd-paranoia -- "-3" 從一個CD光盤轉錄音軌到 wav 文件中(參數-3)
cdrecord --scanbus 掃描總線以識別scsi通道
dd if=/dev/hdc | md5sum 校驗一個設備的md5sum編碼,例如一張 CD

 

網絡 - (以太網和WIFI無線)
ifconfig eth0 顯示一個以太網卡的配置
ifup eth0 啓用一個 'eth0' 網絡設備
ifdown eth0 禁用一個 'eth0' 網絡設備
ifconfig eth0 192.168.1.1 netmask 255.255.255.0 控制IP地址
ifconfig eth0 promisc 設置 'eth0' 成混雜模式以嗅探數據包 (sniffing)
dhclient eth0 以dhcp模式啓用 'eth0'
route -n show routing table
route add -net 0/0 gw IP_Gateway configura default gateway
route add -net 192.168.0.0 netmask 255.255.0.0 gw 192.168.1.1 configure static route to reach network '192.168.0.0/16'
route del 0/0 gw IP_gateway remove static route
echo "1" > /proc/sys/net/ipv4/ip_forward activate ip routing
hostname show hostname of system
host www.example.com lookup hostname to resolve name to ip address and viceversa(1)
nslookup www.example.com lookup hostname to resolve name to ip address and viceversa(2)
ip link show show link status of all interfaces
mii-tool eth0 show link status of 'eth0'
ethtool eth0 show statistics of network card 'eth0'
netstat -tup show all active network connections and their PID
netstat -tupl show all network services listening on the system and their PID
tcpdump tcp port 80 show all HTTP traffic
iwlist scan show wireless networks
iwconfig eth1 show configuration of a wireless network card
hostname show hostname
host www.example.com lookup hostname to resolve name to ip address and viceversa
nslookup www.example.com lookup hostname to resolve name to ip address and viceversa
whois www.example.com lookup on Whois database

 

JPS工具

jps(Java Virtual Machine Process Status Tool)是JDK 1.5提供的一個顯示當前全部java進程pid的命令,簡單實用,很是適合在linux/unix平臺上簡單察看當前java進程的一些簡單狀況。

我想不少人都是用過unix系統裏的ps命令,這個命令主要是用來顯示當前系統的進程狀況,有哪些進程,及其 id。 jps 也是同樣,它的做用是顯示當前系統的java進程狀況,及其id號。咱們能夠經過它來查看咱們到底啓動了幾個java進程(由於每個java程序都會獨佔一個java虛擬機實例),和他們的進程號(爲下面幾個程序作準備),並可經過opt來查看這些進程的詳細啓動參數。

使用方法:在當前命令行下打 jps(須要JAVA_HOME,沒有的話,到改程序的目錄下打) 。

jps存放在JAVA_HOME/bin/jps,使用時爲了方便請將JAVA_HOME/bin/加入到Path.

$> jps
23991 Jps
23789 BossMain
23651 Resin

 


比較經常使用的參數:

-q 只顯示pid,不顯示class名稱,jar文件名和傳遞給main 方法的參數
$> jps -q
28680
23789
23651

-m 輸出傳遞給main 方法的參數,在嵌入式jvm上多是null

$> jps -m
28715 Jps -m
23789 BossMain
23651 Resin -socketwait 32768 -stdout /data/aoxj/resin/log/stdout.log -stderr /data/aoxj/resin/log/stderr.log

-l 輸出應用程序main class的完整package名 或者 應用程序的jar文件完整路徑名

$> jps -l
28729 sun.tools.jps.Jps
23789 com.asiainfo.aimc.bossbi.BossMain
23651 com.caucho.server.resin.Resin

-v 輸出傳遞給JVM的參數

$> jps -v
23789 BossMain
28802 Jps -Denv.class.path=/data/aoxj/bossbi/twsecurity/java/trustwork140.jar:/data/aoxj/bossbi/twsecurity/java/:/data/aoxj/bossbi/twsecurity/java/twcmcc.jar:/data/aoxj/jdk15/lib/rt.jar:/data/aoxj/jd

k15/lib/tools.jar -Dapplication.home=/data/aoxj/jdk15 -Xms8m
23651 Resin -Xss1m -Dresin.home=/data/aoxj/resin -Dserver.root=/data/aoxj/resin -Djava.util.logging.manager=com.caucho.log.LogManagerImpl -

Djavax.management.builder.initial=com.caucho.jmx.MBeanServerBuilderImpl

sudo jps看到的進程數量最全

jps 192.168.0.77

列出遠程服務器192.168.0.77機器全部的jvm實例,採用rmi協議,默認鏈接端口爲1099

(前提是遠程服務器提供jstatd服務)

注:jps命令有個地方很很差,彷佛只能顯示當前用戶的java進程,要顯示其餘用戶的仍是隻能用unix/linux的ps命令。


Vi命令:如何刪除所有內容?


在命令模式下,輸入:.,$d 一回車就全沒了。

表示從當前行到末行所有刪除掉。

用gg表示移動到首行。

超哥方法:

g 進入文檔開頭 G文檔結尾 按下dG 刪除當前光標到行尾的數據

相關文章
相關標籤/搜索