1、初始化你在 squid.conf 里配置的 cache 目錄
目前創(chuàng)新互聯(lián)已為千余家的企業(yè)提供了網(wǎng)站建設(shè)、域名、虛擬空間、網(wǎng)站托管、服務(wù)器租用、企業(yè)網(wǎng)站設(shè)計、膠州網(wǎng)站維護(hù)等服務(wù),公司將堅持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。
#squid/sbin/squid -z //第一次啟動squid服務(wù)時必須輸入此命令
如果有錯誤提示,請檢查你的 cache目錄的權(quán)限。
2、對你的squid.conf 排錯,即驗證 squid.conf 的 語法和配置。
#squid/sbin/squid -k parse
如果squid.conf 有語法或配置錯誤,這里會返回提示你,如果沒有返回,恭喜,可以嘗試啟動squid。
3、在前臺啟動squid,并輸出啟動過程。
#squid/sbin/squid -N -d1
如果有到 ready to server reques,恭喜,啟動成功。
然后 ctrl + c,停止squid,并以后臺運行的方式啟動它。
4、啟動squid在后臺運行。
#squid/sbin/squid -s
這時候可以 ps -A 來查看系統(tǒng)進(jìn)程,可以看到倆個 squid 進(jìn)程。
5、停止 squid
#squid/sbin/squid -k shutdown
這個不用解釋吧。
6、重引導(dǎo)修改過的 squid.conf
#squid/sbin/squid -k reconfigure
這個估計用的時候比較多,當(dāng)你發(fā)現(xiàn)你的配置有不盡你意的時候,可以隨時修改squid.conf,然后別忘記對你的 squid.conf排錯,然后再執(zhí)行此指令,即可讓運行中squid重新按照你的squid.conf 來運行。
7、把squid添加到系統(tǒng)啟動項
編輯 /etc/rc.d/rc.local
添加如下行: /usr/local/squid/sbin/squid -s
當(dāng)然,并不是每個人都喜歡這種啟動方式,你可以用你最習(xí)慣的方式;或者把它安裝為服務(wù)。
再來點其他的。
1、修改cache 緩存目錄的權(quán)限。
#chown -R squid:squid /home/cache
我的cache緩存目錄是 /home/cache,squid執(zhí)行用戶和用戶組是 squid,squid。
2、修改squid 日志目錄的權(quán)限
#chown -R squid:squid /usr/local/squid/var/logs
這一步并不是適合每一個使用squid的用戶.意為讓squid有權(quán)限在該目錄進(jìn)行寫操作 。
例如生成 access.log cache.log store.log
3、查看你的日志文檔。
#more /usr/local/squid/var/logs/access.log | grep TCP_MEM_HIT
該指令可以看到在squid運行過程中,有那些文件被squid緩存到內(nèi)存中,并返回給訪問用戶。
#more /usr/local/squid/var/logs/access.log | grep TCP_HIT
該指令可以看到在squid運行過程中,有那些文件被squid緩存到cache目錄中,并返回給訪問用戶。
#more /usr/local/squid/var/logs/access.log | grep TCP_MISS
該指令可以看到在squid運行過程中,有那些文件沒有被squid緩存,而是現(xiàn)重原始服務(wù)器獲取并返回給訪問用戶。
關(guān)于 TCP_XXXX 等參數(shù)及代表的信息,請參看彭勇華《squid中文權(quán)威指南》13.2.1 章節(jié)。
當(dāng)然,本例中的藍(lán)色文字是可以修改為其他的參數(shù),例如你的域名 ,同樣可以看到access.log里關(guān)于該域名的行。
4、squid -k rotate 輪換squid的日志文件/var/log/squid,Squid代理服務(wù)器日志文件
的增長速度是驚人的,很容易點球滿磁盤空間導(dǎo)致系統(tǒng)不能正常工作,甚至是死機(jī).為了解決日志文件增長太快的問題,squid采用了"輪換"的方法.在squid.conf中可以通過logfile_rotate來設(shè)置文件輪換的個數(shù),如:
logfile_rotate 10 ,輪換的工作一般用crontab定時器完在周期性的日志輪換,例如每周六凌晨2:00進(jìn)行日志輪換,則執(zhí)行如下命令: crontab -e
0 2 * * 6 squid -k rotate
| 線上查詢及幫助命令 |
man:全稱為manual,用于查看系統(tǒng)中自帶的各種參考手冊;
help:用于顯示shell內(nèi)部命令的幫助信息;
| 文件和目錄操作命令 |
ls:全拼list,列出目錄的內(nèi)容及其內(nèi)容屬性信息;
cd:全拼change directory,切換當(dāng)前工作目錄至dirName(目錄參數(shù));
cp:全稱copy,復(fù)制文件或目錄;
find:用于在指定目錄及目錄下查找文件;
mkdir:全拼make directories,創(chuàng)建目錄;
mv:全拼move,移動或重命名文件;
pwd:全拼print working directory,顯示當(dāng)前工作目錄的絕對路徑;
rename:可用字符串替換的方式批量改變文件名;
rm:全拼remove,刪除一個或多個文件或目錄。必須格外小心地使用該命令;
rmdir:全拼remove empty directories,刪除空目錄;
touch:修改文件或者目錄的時間屬性,包括存取時間和更改時間。若文件不存在,系統(tǒng)會建立一個新的文件;
| 查看文件及內(nèi)容處理命令 |
cat:全拼concatenate,用于連接多個文件并且打印到屏幕輸出或重定向到指定文件中,可查看文件內(nèi)容;
tac:cat的反向拼寫,因此命令的功能為反向顯示文件內(nèi)容。文件內(nèi)容的最后一行先顯示,第一行最后顯示;
less:可以隨意瀏覽文件,而more僅能向前移動,卻不能向后移動,而且less在查看之前不會加載整個文件;
head:顯示文件的開頭的內(nèi)容。在默認(rèn)情況下,head命令顯示文件的頭10行內(nèi)容;
tail:查看文件尾部內(nèi)容,有一個常用的參數(shù)-f常用于查閱正在改變的文件??梢钥吹阶钚碌奈募?nèi)容;
| 文件壓縮及解壓縮命令 |
tar:tar命令是用來建立,還原備份文件的工具程序,它可以加入,解開備份文件內(nèi)的文件;
unzip:用于解壓縮zip文件;
gzip:用于壓縮文件。gzip是個使用廣泛的壓縮程序,文件經(jīng)它壓縮過后,其名稱后面會多出".gz"的擴(kuò)展名;
zip:用來將文件壓縮成為常用的zip格式。
hexdump: 查看文件的內(nèi)容,比如二進(jìn)制文件中包含的某些字符串,通常用來調(diào)試驅(qū)動用
描述
我們以event1為例,當(dāng)我們insmod掛載了鍵盤驅(qū)動后,出現(xiàn)一個event1設(shè)備,
此時沒有按鍵按下,所以event1里面的數(shù)據(jù)是沒有的,那么數(shù)據(jù)又是從來哪里來?
通過鍵盤驅(qū)動的read函數(shù),若有按鍵按下,就會上傳按鍵數(shù)據(jù)給用戶層hexdump
因為鍵盤驅(qū)動的input_handler 是:evdev_handler
所以鍵盤驅(qū)動的read函數(shù)是: evdev_handler-evdev_fops-evdev_read
進(jìn)入evdev_read()函數(shù),如下圖所示:
evdev_event_to_user()這個函數(shù)從字面上來看,顯然就是用來上傳給用戶層的函數(shù),其中buffer是函數(shù)參數(shù),指向用戶層,所以數(shù)據(jù)就是event.
我們來看看event的結(jié)構(gòu)體:input_event
把 time里的成員展開如下:
所以我們hexdump調(diào)試任何輸入子系統(tǒng)event XX驅(qū)動時,有信息就會打印上面數(shù)據(jù)
1.調(diào)試鍵盤驅(qū)動
以按開發(fā)板的按鍵 KEY_L,為例(因為數(shù)據(jù)是從低到高打印的,所以數(shù)據(jù)是反的):
根據(jù)這些可以查看系統(tǒng)調(diào)用的完整性,比如說服務(wù)器連接數(shù)一直漲,說明fd沒有close,close調(diào)用在上邊有缺失
strace -t -T -v -f -p 16705 -Te write 只看write系統(tǒng)調(diào)用
sudo gcore xxpid 生成dump文件
sudo dlv core binfile core.xxxx 調(diào)試coredump文件,查看調(diào)用棧、goroutines
查看系統(tǒng)級別日志 /var/log/messages
messages 日志是核心系統(tǒng)日志文件。它包含了系統(tǒng)啟動時的引導(dǎo)消息,以及系統(tǒng)運行時的其他狀態(tài)消息。IO 錯誤、網(wǎng)絡(luò)錯誤和其他系統(tǒng)錯誤都會記錄到這個文件中。其他信息,比如某個人的身份切換為 root,也在這里列出。如果服務(wù)正在運行,比如 DHCP 服務(wù)器,您可以在 messages 文件中觀察它的活動。通常,/var/log/messages 是您在做故障診斷時首先要查看的文件。
tcpdump -i lo -nnA 'port 7076' and 'tcp[13] 4 != 0 ' 抓rst包,發(fā)送給7076端口或者是7076端口發(fā)出去的
mac osx系統(tǒng):sudo tcpdump -i lo0 -nnA 'port 3000'
下面的一切都是在 root 模式下進(jìn)行的,可以不再 root 模式下進(jìn)行
基礎(chǔ)環(huán)境就是編譯代碼的基礎(chǔ)庫,Ubuntu聯(lián)網(wǎng)安裝軟件很簡單,一個語句即可搞定,這里列出語句如下:
依賴庫分兩方面,參考以下網(wǎng)站列出的依賴庫信息,本文選擇的版本均參考于此網(wǎng)頁: FFmpeg依賴庫信息
首先創(chuàng)建 FFmpeg 代碼目錄,所有的源代碼放在這個目錄下
FFmpeg 編譯之后,即可使用。編譯生成的可執(zhí)行程序在 ~/bin 目錄下
注:上面的 ./configure 配置編譯后并不能進(jìn)行調(diào)試,需要如下配置.
剛才的工程可以運行,但不能debug。解決此問題,首先認(rèn)定一點,生成的可執(zhí)行程序中,ffmpeg 不包含調(diào)試信息,調(diào)試信息在 ffmpeg_g 中,debug 要選擇 ffmpeg_g。
另外,./config選項也是確定包含調(diào)試信息的核心,需要在config中添加:
采用以下命令重新config:
一些注意事項; 在使用 ffplay 播放生成 h264 格式的視頻時,播放速度會加快,解決方式:不要使用 FFmpeg 轉(zhuǎn)碼生成純 h264 格式的視頻,要使用一種容器包含 h264 視頻,即生成一種音視頻流格式,也就是不要生成純粹的 h264 碼流,而是生成諸如 mkv 等格式的文件。
linxu下的set命令是用來設(shè)置各種shell選項或者列出shell變量。下面由我為大家整理了linux的set命令的詳細(xì)解釋的相關(guān)知識,希望對大家有幫助!
一、Linux中的set命令的詳細(xì)解釋
功能說明:設(shè)置shell。
語法:set [+-abCdefhHklmnpPtuvx]
補(bǔ)充說明:用set 命令可以設(shè)置各種shell選項或者列 出shell變量.單個選項設(shè)置常用的特性.在某些選項之后-o參數(shù)將特殊特性打開.在某些選項之后使用+o參數(shù)將關(guān)閉某些特性,不帶任何參數(shù)的set命 令將顯示shell的全部變量.除非遇到非法的選項,否則set總是返回ture.
參數(shù):
allexport -a 從設(shè)置開始標(biāo)記所有新的和修改過的用于輸出的變量
braceexpand -B 允許符號擴(kuò)展,默認(rèn)選項
emacs 在進(jìn)行命令編輯的時候,使用內(nèi)建的emacs編輯器, 默認(rèn)選項
errexit -e 如果一個命令返回一個非0退出狀態(tài)值(失敗),就退出.
histexpand -H 在做臨時替換的時候允許使用!和!! 默認(rèn)選項
history 允許命令行歷史,默認(rèn)選項
ignoreeof 禁止coontrol-D的方式退出shell,必須輸入exit。
interactive-comments 在交互式模式下, #用來表示注解
keyword -k 為命令把關(guān)鍵字參數(shù)放在環(huán)境中
monitor -m 允許作業(yè)控制
noclobber -C 保護(hù)文件在使用重新動向的時候不被覆蓋
noexec -n 在腳本狀態(tài)下讀取命令但是不執(zhí)行,主要為了檢查語法結(jié)構(gòu)。
noglob -d 禁止路徑名擴(kuò)展,即關(guān)閉通配符
notify -b 在后臺作業(yè)以后通知客戶
nounset -u 在擴(kuò)展一個沒有的設(shè)置的變量的時候, 顯示錯誤的信息
onecmd -t 在讀取并執(zhí)行一個新的命令后退出
physical -P 如果被設(shè)置,則在使用pwd和cd命令時不使用符號連接的路徑 而是物理路徑
posix 改變shell行為以便符合POSIX要求
privileged 一旦被設(shè)置,shell不再讀取.profile文件和env文件 shell函數(shù)也不繼承任何環(huán)境
verbose -v 為調(diào)試打開verbose模式
vi 在命令行編輯的時候使用內(nèi)置的vi編輯器
xtrace -x 打開調(diào)試回響模式
二、Linux中的set命令詳解實例
顯示環(huán)境變量
# set
BASH=/bin/bash
BASH_ARGC=()
BASH_ARGV=()
BASH_LINENO=()
BASH_SOURCE=()
BASH_VERSINFO=([0]="3" [1]="00" [2]="15" [3]="1" [4]="release" [5]="i386-redhat-linux-gnu")
BASH_VERSION='3.00.15(1)-release'
COLORS=/etc/DIR_COLORS.xterm
COLUMNS=99
DIRSTACK=()
EUID=0
GROUPS=()
G_BROKEN_FILENAMES=1
HISTFILE=/root/.bash_history
HISTFILESIZE=1000
HISTSIZE=1000
HOME=/root
HOSTNAME=hnlinux
HOSTTYPE=i386
IFS=$' '
INPUTRC=/etc/inputrc
KDEDIR=/usr
LANG=zh_CN.GB2312
LESSOPEN='|/usr/bin/lesspipe.sh %s'
LINES=34
L
MAIL=/var/spool/mail/root
MAILCHECK=60
OLDPWD=/home/uptech
OPTERR=1
OPTIND=1
OSTYPE=linux-gnu
PATH=/usr/kerberos/sbin:/usr/kerberos/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/usr/X11R6/bin:/root/bin:/opt/crosstools/gcc-3.4.6-glibc-2.3.6/bin
PIPESTATUS=([0]="2")
PPID=26005
PROMPT_COMMAND='echo -ne "
三、Linux的set命令的相關(guān)擴(kuò)展
set、env、export——Linux中的環(huán)境變量命令
Linux是一個多用戶的操作系統(tǒng)。每個用戶登錄系統(tǒng)后,都會有一個專用的運行環(huán)境。通常每個用戶默認(rèn)的環(huán)境都是相同的,這個默認(rèn)環(huán)境實際上就是一組環(huán)境 變量的定義。用戶可以對自己的運行環(huán)境進(jìn)行定制,其方法就是修改相應(yīng)的系統(tǒng)環(huán)境變量。
什么是環(huán)境變量
環(huán)境變量是一個具有 特定名字的對象,它包含了一個或者多個應(yīng)用程序所將使用到的信息。許多用戶(特別是那些剛接觸Linux的新手)發(fā)現(xiàn)這些變量有些怪異或者難以控制。其 實,這是個誤會:通過使用環(huán)境變量,你可以很容易的修改一個牽涉到一個或多個應(yīng)用程序的配置信息。
常見的環(huán)境變量
對于 PATH和HOME等環(huán)境變量大家都不陌生。
PATH能夠指定命令的搜索路徑,那么動態(tài)鏈接庫的路徑用什么變量指定呢?或者就是在 PATH里面?
比如有一個程序需要/usr/local/lib下面的一個庫文件,應(yīng)該怎么指定其路徑呢?
經(jīng)??吹接行┳兞咳?LD_LIBRARY_PATH,LIBPATH,CLASSPATH等,他們之間有什么不同和關(guān)系?
除此之外,還有下面一些常見環(huán)境變 量。
◆ HISTSIZE是指保存歷史命令記錄的條數(shù)。
◆ LOGNAME是指當(dāng)前用戶的登錄名。
◆ HOSTNAME是指主機(jī)的名稱,許多應(yīng)用程序如果要用到主機(jī)名的話,通常是從這個環(huán)境變量中來取得的。
◆ SHELL是指當(dāng)前用戶用的是哪種Shell。
◆ LANG/LANGUGE是和語言相關(guān)的環(huán)境變量,使用多種語言的用戶可以修改此環(huán)境變量。
◆ MAIL是指當(dāng)前用戶的郵件存放目錄。
◆ PS1是基本提示符,對于root用戶是#,對于普通用戶是$。PS2是附屬提示符,默認(rèn)是“”??梢酝ㄟ^修改此環(huán)境變量來修改當(dāng)前的命令符,比 如下列命令會將提示符修改成字符串“Hello,My NewPrompt ”。
當(dāng)前標(biāo)題:linux下調(diào)試的命令 linux shell 調(diào)試
分享地址:http://jinyejixie.com/article48/doddoep.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信小程序、商城網(wǎng)站、外貿(mào)網(wǎng)站建設(shè)、網(wǎng)站策劃、網(wǎng)站制作、網(wǎng)站排名
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)