淺談Linux網絡故障的解決辦法
創新互聯主要從事成都網站制作、成都做網站、外貿營銷網站建設、網頁設計、企業做網站、公司建網站等業務。立足成都服務潯陽,10年網站建設經驗,價格優惠、服務專業,歡迎來電咨詢建站服務:18982081108
Linux繼承了Unix以網絡為核心的設計思想,是一個性能穩定的多用戶網絡操作系統。我告訴大家,Linux網絡故障排除應當遵循先硬件后軟件的方法。因為硬件如果出現物理損壞那么如何設定網絡都不能解決故障。解決問題的方法可以從自身Linux計算機的網卡查起,然后到服務器、集線器、路由器等硬件。如果確定硬件沒有問題了,再來考慮軟件的設定。
1、檢查網卡工作狀況
(1)使用cat /proc/modules查看網卡的模塊是否已被加載,驅動硬件是操作系統最基本的功能,操作系統通過各種驅動程序來駕馭硬件設備,和Windows系統不同Linux內核目前采用可加載的模塊化設計(LKMs Loadable Kernel Modules),就是將最基本的核心代碼編譯在內核中,而我們常見的驅動程序就是作為內核模塊動態加載的,比如網卡驅動。Windows系統中我們一般“控制面板”的“設備管理器”查看硬件列表,在Linux中可以在命令行下輸入:cat /proc/modules 即可顯示Linux系統檢測到的所有硬件設備。運行cat /proc/modules需要超級用戶的權限,你可以使用su命令實現。
我Linux計算機中兩塊網卡模塊:NE2000和8139已經加載。如果沒有檢測到硬件,用硬件檢測程序Kuduz檢測網卡,它和Windows中添加新硬件差不多。kudzu程序是通過查看/usr/share/hwdata/目錄下的文件識別各種硬件設備的。如果核心支持該硬件,并且有該驅動程序就可自動裝載。首先說明的是Linux下對網卡的支持往往是只對芯片的,所以對某些不是很著名的網卡,往往需要知道它的芯片型號以配置Linux.比如我的Top link網卡,就不存在Linux的驅動,但是因為它是NE2000兼容,所以把它當NE2000就可以在Linux下用了.所以當你有一塊網卡不能用,在找Linux的驅動程序之前一定搞清楚這個網卡用的什么芯片,跟誰兼容,比如3c509,ne2000,etherexpress等等.這樣的型號一般都在網卡上最大的一快芯片上印著,抄下來就是了。對于ISA接口的NE2000卡,先要作的一件事情,是將網卡設定為Jumpless模式.很多現在的網卡缺省都是PnP模式,這在Windows下的確能減少很多麻煩,但是Linux不支持,所以Linux下必須是Jumpless模式.一般所有網卡都有帶的驅動盤和DOS下可執行的一個設定程序,用該程序將網卡設為 Jumpless。對于PCI網卡,可以使用如下命令來查看:less/proc/pci。在顯示的列表中找到“Ethernet Controller”,記下廠商和型號。然后使用modprobe嘗試加載正確的模塊,比如modprobe 3c509。如果出現錯誤,說明該模塊不存在。這時候你應該找到正確的模塊并且重新編譯。如果顯示說該設備不存在,那也是因為沒有正確的模塊。找到正確的模塊,并且編譯,問題一般即可解決。
(2)使用Ifconfig-a命令檢查網卡接口
如果已經檢測到網卡,網卡硬件就沒有問題,接下來檢查網卡的軟件設定。使用ifconfig -a命令:
第二塊網卡沒有分配IP地址,我們現在可以添加IP地址。以Redhat Linux 9.0為例。以root權限運行命令:neat出現圖形化配置界面,然后添加IP地址后保存設置,從新啟動網絡和網絡服務或計算機.
(4)編譯網卡
如果Linux內核沒有檢測到網卡通常要重新安裝網卡的驅動程序,網卡驅動程序安裝方法步驟如下:
a、 編譯并安裝模塊;
b、 修改/etc/conf.module 文件;
c、 修改/etc/sysconfig/network文件;
d、 修改/etc/sysconfig/network-scripts/ifcfg-eth0 文件;
e、 給網卡添加IP地址:打開網卡IP地址配置文件/etc/sysconfig/network-script/ifcfg-eh0.
e、然后用命令啟動網絡服務。
說明網卡問題:使用ifconfig來進行配置。如果運行ifconfig,將會給出所有已經安裝了的網卡。如果沒有顯示可用的網卡,那么很有可能是以下原因之一:1. 網卡沒有被Linux檢測到;2. 沒有與之相應的內核模塊;3. 該模塊沒有被加載;4. Linux系統不支持你的網卡。就現在來說,出現問題4的可能性很小,一般來說都是問題2和3,也可能是1。
Linux下無線網卡的安裝:
目前經過認證的PCMCIA網卡有兩大類。使用基于朗訊(Lucent)芯片組的PCIMCIA無線網卡和使用基于intersil PRISM2-based cards 芯片組的PCMCIA的無線網卡見表-1。不過由于基于intersil PRISM2-based cards 芯片組的PCMCIA的無線網卡價格比較便宜(相當于朗訊(Lucent)芯片組的PCIMCIA無線網卡的三分之一),所以國內的PCMCIA的無線網卡以后者居多。
在很多人學習Linux命令行,會經常遇到command not found 錯誤,出現上述錯誤主要有以下幾種情況:
命令書寫錯誤,如有些人將Windows命令與Linux命令搞錯,如查看ip相關信息,Linux命令行應該為ifconfig
環境變量沒有配置好,這里一般有兩種解決方法,第一,可以切換到root用戶執行命令,第二種,就是配置用戶的環境變量,其指令如下:
export PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin
----------------------------分割線----------------------------
Linux命令找不到?(找不到命令)
這個問題其實很簡單,如果你在終端輸入一個命令,而系統提示你說命令沒有找到(Command not found)的話,要么是因為你沒有裝相應的軟件包,要么就是因為路徑設置的問題。如果是因為軟件包的問題,那沒有別的好說的,安裝相應的軟件包就好了。而另外一種情況,則需要對用戶的路徑進行設置。這里針對普通用戶和超級用戶分開介紹,以 RedHat 些列為例。
一、普通用乎如果一些程序沒有安裝在系統默認的路徑(ie /bin/, /usr/bin, /usr/local/bin/ )里面,這個時候普通用戶想要調用這些命令,必須設定路徑。方法很簡單:以普通用戶登錄,然后在終端輸入:
vi ~/.bash_profile
會出現如下的內容:# .bash_profile
export PATH此時,只要在export PATH前面加入自己的路徑即可,例如我的修改后如下:[ @localhost bin]$ cat ~/.bash_profile# .bash_profile# Get the aliases and functionsif [ -f ~/.bashrc ]; then . ~/.bashrcfi# User specific environment and startup programsPATH=$PATH:/usr/local/programs/crosstool/gcc-4.0.2-glibc-2.3.6/arm-linux-gnu/bin/export PATH
二、超級用戶這里主要是一些用在系統管理上的命令,例如ifconfig, route等等, 他們位于/sbin, 或/usr/sbin/下。其實這些命令本身就沒有任何問題,軟件包早已安裝完畢,路徑設置也沒有絲毫問題。而出現Command not found的原因在于:在終端使用su變成超級用戶的時候沒有將root的路徑(環境)一起切換過來,從而導致身份雖然已經是root,但是工作的環境和路徑依舊是普通用戶的。這種問題的解決方法有兩個,其一是按照(一)里面提到的,對普通用戶的工作路徑進行修改,但是這樣比較麻煩。其二則簡單的多,只要在使用su的時候在其后家上一個空格和”-“ ,即將su改為 su - 。這樣就可以在成為root的同時將root的工作路徑也一起切換過來了。如果你已經使用su變成了root,那也沒有關系,只要在輸入一下su - 就好了。
原文地址:
首先,如果正在使用vsftpd,可以先把其停掉,命令:service vsftpd stop,接下來需要編輯/etc/xinetd.d/下的`gssftp配置文件,文件內容如下:
# default: off
# description: The kerberized FTP server accepts FTP connections
# that can be authenticated with Kerberos 5.
service ftp
{
disable = yes
flags = REUSE
socket_type = stream
wait = no
user = root
server = /usr/kerberos/sbin/ftpd
server_args = -l -a
log_on_failure += USERID
}
在文件中,我們要修改的內容有:
1、disable = yes 改為 disable =no ,系統默認ftp功能是無效的,修改使ftp功能生效。
2、server_args = -l -a 改為 server_args = -l。
without -a means : *enable weak authentication*
其中表示使用Kerberos 5驗證機制,而一般的ftp是不支持該驗證機制的。
修改完畢后,將其保存。
3、重啟啟動xinetd服務。請執行一下的命令(/etc/xinetd.d/):
service xinetd restart
service vsftpd restart
可能由于自己在WIN10里,在360進行一些殺毒清理,一個不小心根據它的提示,修改了啟動項 把其中你認為加上它提示沒用用的不知神碼東西給刪除了,然后要求我們重啟。
重啟后你會發現進不去選擇系統的頁面了
出現error:file 'boot/grub/i386-pc/normal.mod' not found? ?grub rescue:
然后就很無奈? 只能先去百度試試 解決方案如下,勇敢嘗試,不要怕處理不了,方法還是很有效的,不然我也不會寫這個文章的:
先輸入命令 ls??
會出現一串字符串? 我的是 hd0? (hd0,msdos9) (hd0,msdos8)??(hd0,msdos7)?(hd0,msdos6)?(hd0,msdos5)?(hd0,msdos2)?(hd0,msdos1)
接下來需要試一下到底那個msdos*(*為上面字符串里的數字)才是具體的linux系統的主分區;需要輸入的命令為:ls(hd0,msdos*)/boot/grub? ? 一個個試過去,一般都是第一個的? ? ?當輸入正確的時候會出現下列命令:
../../....../.......(由于沒用拍照,所以忘記了,不好意思,基本格式是這樣的,輸入錯誤的都會提示 not found)
好,你終于找到了先恭喜一下,你快解決了,接下只要配置下環境就好了,再輸入一些命令就好,命令為:
1.set root=(hd0,msdos9)/boot/grub? //這里msdos后面的數字為你找到的msdos后面的那個數字? ?我的為9;
2.set prefix=(hd0,msdos9)/boot/grub
3.insmod normal
4.normal
輸入完后你就可以進入選擇系統頁面的;為了安全起見,我們先進入linux系統內,重新安裝一下grub,就可以盡可能避免再次發生這樣的事;
很簡單。ctrl+alt+t進入終端,輸入命令 sudo update-grub
會出現:
Installing for i386-pc platform.
Installation finished. No error reported.
sudo grub-install /dev/sda
會出現
Installing for i386-pc platform.? ?
Installation finished. No error reported.
好的 這個問題已經解決的
謝謝觀看本文章
[root@localhost ~]# ls -l
總用量 44
-rw------. 1 ---- root ---- root --------1207 1 月14 18:18 anaconda-ks.cfg
權限--引用計數 所有者 -- 所屬組--- 大小-- 文件修改時間 文件名
ls [選項] [文件名或目錄名]
選項:
-a :顯示所有文件
--color=when:支持顏色輸出
-d :顯示目錄信息,而不是目錄下的文件
-h :人性化顯示﹐按照我們習慣的顯示文件大小
-i :顯示文件的i節點號
-l:長格式顯示
pwd 命令是查詢當前所在的目錄的絕對路徑
選項:
-L (默認值)打印環境變量"$PWD"的值,可能為符號鏈接。
-P 打印當前工作目錄的物理位置。
mkdir 是創建目錄的命令
選項:
-Z:設置安全上下文,當使用SELinux時有效;
-m或--mode:建立目錄的同時設置目錄的權限;
-p或--parents:若所要建立目錄的上層目錄目前尚未建立,則會一并建立上層目錄;
rmdir 是刪除空目錄的命令
-p: 遞歸刪除目錄
touch 是 創建空文件或修改文件的時間戳
[root@localhost ~]# touch [選項] 文件名
-a:或--time=atime或--time=access或--time=use 只更改存取時間;
-c:或--no-create 不建立任何文件;
-d:時間日期 使用指定的日期時間,而非現在的時間;
-f:此參數將忽略不予處理,僅負責解決BSD版本touch指令的兼容性問題;
-m:或--time=mtime或--time=modify 只更該變動時間;
-r:參考文件或目錄 把指定文件或目錄的日期時間,統統設成和參考文件或目錄的日期時間相同;
-t:日期時間 使用指定的日期時間,而非現在的時間;
--help:在線幫助;
--version:顯示版本信息。
stat 是查看文件詳細信息的命令,而且可以看到文件的這三個時間戳
選項:
-L:支持符號連接;
-f:顯示文件系統狀態而非文件狀態;
-t:以簡潔方式輸出信息;
cat 命令用來查看文件內容
選項:
-A: 相當于-vET 選項的整合,用于列出所有隱藏符號
-E: 列出每行結尾的回車符$
-n: 顯示行號
-T: 把 Tab 鍵用^I顯示出來
-v: 列出特殊字符
more 是分屏顯示文件的命令
less 是分行顯示文件的命令
用less命令顯示文件時,用PageUp鍵向上翻頁,用PageDown鍵向下翻頁。要退出less程序,應按Q鍵。
選項:
-e:文件內容顯示完畢后,自動退出;
-f:強制顯示文件;
-g:不加亮顯示搜索到的所有關鍵詞,僅顯示當前顯示的關鍵字,以提高顯示速度;
-l:搜索時忽略大小寫的差異;
-N:每一行行首顯示行號;
-s:將連續多個空行壓縮成一行顯示;
-S:在單行顯示較長的內容,而不換行顯示;
-x數字:將TAB字符顯示為指定個數的空格字符。
head 是用來顯示文件開頭的命令
選項:
-c --bytes=[-]NUM 顯示前NUM字節;如果NUM前有"-",那么會打印除了文件末尾的NUM字節以外的其他內容。
-n, --lines=[-]NUM 顯示前NUM行而不是默認的10行;如果NUM前有"-",那么會打印除了文件末尾的NUM行以外的其他行。
-q, --quiet, --silent 不打印文件名行。
-v, --verbose 總是打印文件名行。
-z, --zero-terminated 行終止符為NUL而不是換行符。
tail 是用來顯示文件末尾的命令
選項:
-c, --bytes=NUM 輸出文件尾部的NUM(NUM為整數)個字節內容。
-f, --follow[={name|descript}] 顯示文件最新追加的內容?!皀ame”表示以文件名的方式監視文件的變化。
-F 與 “--follow=name --retry” 功能相同。
-n, --line=NUM 輸出文件的尾部NUM(NUM位數字)行內容。
--pid=進程號 與“-f”選項連用,當指定的進程號的進程終止后,自動退出tail命令。
-q, --quiet, --silent 當有多個文件參數時,不輸出各個文件名。
--retry 即是在tail命令啟動時,文件不可訪問或者文件稍后變得不可訪問,都始終嘗試打開文件。使用此選項時需要與選項“--follow=name”連用。
-s, --sleep-interal=秒數 與“-f”選項連用,指定監視文件變化時間隔的秒數。
-v, --verbose 當有多個文件參數時,總是輸出各個文件名。
ln 是用來為文件創建鏈接的命令
[root@localhost ~]# ln [選項] 源文件 目標文件
選項:
-s: 建立軟鏈接文件。如果不加“-s”選項,則建立硬鏈接文件
-f: 強制。如果目標文件已經存在,則刪除目標文件后再建立鏈接文件
-d, -F, --directory 創建指向目錄的硬鏈接(只適用于超級用戶)
-f, --force 強行刪除任何已存在的目標文件
-i, --interactive 覆蓋既有文件之前先詢問用戶
-L, --logical 取消引用作為軟鏈接的目標
-n, --no-dereference 把軟鏈接的目的目錄視為一般文件
-P, --physical 直接將硬鏈接到軟鏈接
-r, --relative 創建相對于鏈接位置的軟鏈接
-s, --symbolic 對源文件建立軟鏈接
硬鏈接特征:
源文件和硬鏈接文件擁有相同的 Inode 和 Block
? 修改任意一個文件,另一個都改變
? 刪除任意一個文件,另一個都能使用
? 硬鏈接標記不清,很難確認硬鏈接文件位置,不建議使用
? 硬鏈接不能鏈接目錄
? 硬鏈接不能跨分區
軟鏈接特征:
? 軟鏈接和源文件擁有不同的 Inode 和 Block
? 兩個文件修改任意一個,另一個都改變
? 刪除軟鏈接,源文件不受影響;刪除源文件,軟鏈接不能使用
? 軟鏈接沒有實際數據,只保存源文件的 Inode,不論源文件多大,軟鏈接大小不變
? 軟鏈接的權限是最大權限 lrwxrwxrwx.,但是由于沒有實際數據,最終訪問時需要參考源文
件權限
? 軟鏈接可以鏈接目錄
? 軟鏈接可以跨分區
? 軟鏈接特征明顯,建議使用軟連接
rm 是強大的刪除命令,不僅可以刪除文件,也可以刪除目錄
[root@localhost ~]# rm [選項] 文件或目錄
選項:
d:直接把欲刪除的目錄的硬連接數據刪除成0,刪除該目錄;
-f:強制刪除文件或目錄;
-i:刪除已有文件或目錄之前先詢問用戶;
-r:遞歸處理,將指定目錄下的所有文件與子目錄一并處理;
--preserve-root:不對根目錄進行遞歸操作;
-v:顯示指令的詳細執行過程。
cp 是文件或目錄用于復制的命令
[root@localhost ~]# cp [選項] 源文件 目標文件
選項:
-a:此參數的效果和同時指定"-dpR"參數相同;
-d:當復制軟鏈接時,把目標文件或目錄也建立為軟鏈接,并指向與源文件或目錄連接的原始文件或目錄;
-f:強行復制文件或目錄,不論目標文件或目錄是否已存在;
-i:覆蓋既有文件之前先詢問用戶;
-l:對源文件建立硬連接,而非復制文件;
-p:保留源文件或目錄的屬性;
-r:遞歸處理,將指定目錄下的所有文件與子目錄一并處理;
-s:對源文件建立軟鏈接,而非復制文件;
-u:使用這項參數后只會在源文件的更改時間較目標文件更新時或是名稱相互對應的目標文件并不存在時,才復制文件;
-S:在備份文件時,用指定的后綴“SUFFIX”代替文件的默認后綴;
-b:覆蓋已存在的文件目標前將目標文件備份;
-v:詳細顯示命令執行的操作。
mv 是用來對文件或目錄重新命名,或者將文件移動至其他目錄
[root@localhost ~]# mv [選項] 源文件 目標文件
選項:
-b:當文件存在時,覆蓋前,為其創建一個備份;
-f:若目標文件或目錄與現有的文件或目錄重復,則直接覆蓋現有的文件或目錄;
-i:交互式操作,覆蓋前先行詢問用戶,如果源文件與目標文件或目標目錄中的文件同名,則詢問用戶是否覆蓋目標文件。用戶輸入”y”,表示將覆蓋目標文件;輸入”n”,表示取消對源文件的移動。這樣可以避免誤將文件覆蓋。
--strip-trailing-slashes:刪除源文件中的斜杠“ / ”;
-S后綴:為備份文件指定后綴,而不使用默認的后綴;
--target-directory=目錄:指定源文件要移動到目標目錄;
-u:當源文件比目標文件新或者目標文件不存在時,才執行移動操作。
[root@localhost ~]# ls -l install.log
-rw-r--r--. 1 root root 24772 1 月 14 18:17 install.log
第一列的權限位如果不計算最后的“.”,則共有 10 位。
第 2~4 位代表文件所有者的權限。
chmod 用來變更文件或目錄的權限
[root@localhost ~]# chmod [選項] 權限模式 文件名
選項:
-c, --changes:當文件的權限更改時輸出操作信息。
--no-preserve-root:不將'/'特殊化處理,默認選項。
--preserve-root:不能在根目錄下遞歸操作。
-f, --silent, --quiet:抑制多數錯誤消息的輸出。
-v, --verbose:無論文件是否更改了權限,一律輸出操作信息。
--reference=RFILE:使用參考文件或參考目錄RFILE的權限來設置目標文件或目錄的權限。
-R, --recursive:對目錄以及目錄下的文件遞歸執行更改權限操作。
用戶身份
首先,讀、寫、執行權限對文件和目錄的作用是不同的。
目錄的可用權限其實只有以下幾個。
chown 是修改文件和目錄的所有者和所屬組的命令
[root@localhost ~]# chown [選項] 所有者:所屬組 文件或目錄
選項:
-c或——changes:效果類似“-v”參數,但僅回報更改的部分;
-f或--quite或——silent:不顯示錯誤信息;
-h或--no-dereference:只對軟鏈接的文件作修改,而不更改其他任何相關文件;
-R或——recursive:遞歸處理,將指定目錄下的所有文件及子目錄一并處理;
-v或——version:顯示指令執行過程;
--reference=參考文件或目錄:把指定文件或目錄的擁有者與所屬群組全部設成和參考文件或目錄的擁有者與所屬群組相同;
普通用戶不能修改文件的所有者,哪怕自己是這個文件的所有者也不行
普通用戶可以修改所有者是自己的文件的權限
chgrp 是修改文件和目錄的所屬組的命令
[root@phato ~]# chgrp [選項] 所屬組 文件或目錄
-R 遞歸式地改變指定目錄及其下的所有子目錄和文件的所屬的組
-c或——changes:效果類似“-v”參數,但僅回報更改的部分;
-f或--quiet或——silent:不顯示錯誤信息;
-h或--no-dereference:只對符號連接的文件作修改,而不是該其他任何相關文件;
-H如果命令行參數是一個通到目錄的軟鏈接,則遍歷軟鏈接
-R或——recursive:遞歸處理,將指令目錄下的所有文件及子目錄一并處理;
-L:遍歷每一個遇到的通到目錄的軟鏈接
-P:不遍歷任何符號鏈接(默認)
-v或——verbose:顯示指令執行過程;
--reference=參考文件或目錄:把指定文件或目錄的所屬群組全部設成和參考文件或目錄的所屬群組相同;
umask 是顯示或設置創建文件的權限掩碼。我們需要先了解一下新建文件和目錄的默認最大權限。
我們在這里按照權限字母來講解 umask 權限的計算方法。我們就按照默認的 umask 值是 022來分別計算一下新建文件和目錄的默認權限吧。
分享名稱:linux錯誤處理命令,linux輸錯命令
URL地址:http://m.kartarina.com/article26/heijjg.html
成都網站建設公司_創新互聯,為您提供網站改版、虛擬主機、搜索引擎優化、網站設計公司、面包屑導航、定制開發
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯