啟動(dòng)oracle數(shù)據(jù)庫(kù)步驟:\x0d\x0a首先使用oracle用戶登錄Linux,然后在shell命令行中執(zhí)行下面的命令:\x0d\x0a第一步:打開Oracle監(jiān)聽\x0d\x0a$ lsnrctl start\x0d\x0a第二步:進(jìn)入sqlplus\x0d\x0a$ sqlplus /nolog\x0d\x0aSQL\x0d\x0a第三步:使用sysdab角色登錄sqlplus\x0d\x0aSQL conn /as sysdba\x0d\x0a第四步:?jiǎn)?dòng)數(shù)據(jù)庫(kù)\x0d\x0aSQL startup\x0d\x0a經(jīng)過(guò)上面的四個(gè)步驟,oracle數(shù)據(jù)庫(kù)就可以啟動(dòng)了。\x0d\x0a關(guān)閉數(shù)據(jù)庫(kù)用 shutdown 是要等待事物結(jié)束才關(guān)閉,強(qiáng)制關(guān)閉用 shutdown abort。
創(chuàng)新互聯(lián)專注于于洪網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠(chéng)為您提供于洪營(yíng)銷型網(wǎng)站建設(shè),于洪網(wǎng)站制作、于洪網(wǎng)頁(yè)設(shè)計(jì)、于洪網(wǎng)站官網(wǎng)定制、微信小程序服務(wù),打造于洪網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供于洪網(wǎng)站排名全網(wǎng)營(yíng)銷落地服務(wù)。
1、在終端中輸入mysql -u用戶名 -p密碼命令可以進(jìn)行mysql命令行
2、如果密碼有特殊字符就先mysql -u用戶名 -p回車,然后提示輸入密碼后,再輸入密碼回車即可
3、mysql 其它參數(shù)說(shuō)明:
mysql命令行參數(shù)
Usage: mysql [OPTIONS] [database] //命令方式
-?, --help //顯示幫助信息并退出
-I, --help //顯示幫助信息并退出
--auto-rehash //自動(dòng)補(bǔ)全功能,就像linux里面,按Tab鍵出提示差不多,下面有例子
-A, --no-auto-rehash //默認(rèn)狀態(tài)是沒(méi)有自動(dòng)補(bǔ)全功能的。-A就是不要自動(dòng)補(bǔ)全功能
-B, --batch //ysql不使用歷史文件,禁用交互
(Enables --silent)
--character-sets-dir=name //字體集的安裝目錄
--default-character-set=name //設(shè)置數(shù)據(jù)庫(kù)的默認(rèn)字符集
-C, --compress //在客戶端和服務(wù)器端傳遞信息時(shí)使用壓縮
-#, --debug[=#] //bug調(diào)用功能
-D, --database=name //使用哪個(gè)數(shù)據(jù)庫(kù)
--delimiter=name //mysql默認(rèn)命令結(jié)束符是分號(hào),下面有例子
-e, --execute=name //執(zhí)行mysql的sql語(yǔ)句
-E, --vertical //垂直打印查詢輸出
-f, --force //如果有錯(cuò)誤跳過(guò)去,繼續(xù)執(zhí)行下面的
-G, --named-commands
/*Enable named commands. Named commands mean this program's
internal commands; see mysql help . When enabled, the
named commands can be used from any line of the query,
otherwise only from the first line, before an enter.
Disable with --disable-named-commands. This option is
disabled by default.*/
-g, --no-named-commands
/*Named commands are disabled. Use \* form only, or use
named commands only in the beginning of a line ending
with a semicolon (;) Since version 10.9 the client now
starts with this option ENABLED by default! Disable with
'-G'. Long format commands still work from the first
line. WARNING: option deprecated; use
--disable-named-commands instead.*/
-i, --ignore-spaces //忽視函數(shù)名后面的空格.
--local-infile //啟動(dòng)/禁用 LOAD DATA LOCAL INFILE.
-b, --no-beep //sql錯(cuò)誤時(shí),禁止嘟的一聲
-h, --host=name //設(shè)置連接的服務(wù)器名或者Ip
-H, --html //以html的方式輸出
-X, --xml //以xml的方式輸出
--line-numbers //顯示錯(cuò)誤的行號(hào)
-L, --skip-line-numbers //忽略錯(cuò)誤的行號(hào)
-n, --unbuffered //每執(zhí)行一次sql后,刷新緩存
--column-names //查尋時(shí)顯示列信息,默認(rèn)是加上的
-N, --skip-column-names //不顯示列信息
-O, --set-variable=name //設(shè)置變量用法是--set-variable=var_name=var_value
--sigint-ignore //忽視SIGINT符號(hào)(登錄退出時(shí)Control-C的結(jié)果)
-o, --one-database //忽視除了為命令行中命名的默認(rèn)數(shù)據(jù)庫(kù)的語(yǔ)句??梢詭吞^(guò)日志中的其它數(shù)據(jù)庫(kù)的更新。
--pager[=name] //使用分頁(yè)器來(lái)顯示查詢輸出,這個(gè)要在linux可以用more,less等。
--no-pager //不使用分頁(yè)器來(lái)顯示查詢輸出。
-p, --password[=name] //輸入密碼
-P, --port=# //設(shè)置端口
--prompt=name //設(shè)置mysql提示符
--protocol=name //使用什么協(xié)議
-q, --quick //不緩存查詢的結(jié)果,順序打印每一行。如果輸出被掛起,服務(wù)器會(huì)慢下來(lái),mysql不使用歷史文件。
-r, --raw //寫列的值而不轉(zhuǎn)義轉(zhuǎn)換。通常結(jié)合--batch選項(xiàng)使用。
--reconnect //如果與服務(wù)器之間的連接斷開,自動(dòng)嘗試重新連接。禁止重新連接,使用--disable-reconnect。
-s, --silent //一行一行輸出,中間有tab分隔
-S, --socket=name //連接服務(wù)器的sockey文件
--ssl //激活ssl連接,不激活--skip-ssl
--ssl-ca=name //CA證書
--ssl-capath=name //CA路徑
--ssl-cert=name //X509 證書
--ssl-cipher=name //SSL cipher to use (implies --ssl).
--ssl-key=name //X509 密鑰名
--ssl-verify-server-cert //連接時(shí)審核服務(wù)器的證書
-t, --table //以表格的形勢(shì)輸出
--tee=name //將輸出拷貝添加到給定的文件中,禁時(shí)用--disable-tee
--no-tee //根--disable-tee功能一樣
-u, --user=name //用戶名
-U, --safe-updates //Only allow UPDATE and DELETE that uses keys.
-U, --i-am-a-dummy //Synonym for option --safe-updates, -U.
-v, --verbose //輸出mysql執(zhí)行的語(yǔ)句
-V, --version //版本信息
-w, --wait //服務(wù)器down后,等待到重起的時(shí)間
--connect_timeout=# //連接前要等待的時(shí)間
--max_allowed_packet=# //服務(wù)器接收/發(fā)送包的最大長(zhǎng)度
--net_buffer_length=# //TCP / IP和套接字通信緩沖區(qū)大小。
--select_limit=# //使用--safe-updates時(shí)SELECT語(yǔ)句的自動(dòng)限制
--max_join_size=# //使用--safe-updates時(shí)聯(lián)接中的行的自動(dòng)限制
--secure-auth //拒絕用(pre-4.1.1)的方式連接到數(shù)據(jù)庫(kù)
--server-arg=name //Send embedded server this as a parameter.
--show-warnings //顯示警告
、配置文件介紹:
每個(gè) Linux 程序都是一個(gè)可執(zhí)行文件,它含有操作碼列表,CPU 將執(zhí)行這些操作碼來(lái)完成特定的操作。
例如,ls 命令是由 /bin/ls 文件提供的,該文件含有機(jī)器指令的列表,在屏幕上顯示當(dāng)前目錄中文件
的列表時(shí)需要使用這些機(jī)器指令。幾乎每個(gè)程序的行為都可以通過(guò)修改其配置文件來(lái)按照您的偏好或需
要去定制。
Linux 中有沒(méi)有一個(gè)標(biāo)準(zhǔn)的配置文件格式?
一句話,沒(méi)有。不熟悉 Linux 的用戶(一定)會(huì)感到沮喪,因?yàn)槊總€(gè)配置文件看起來(lái)都象是一個(gè)要迎
接的新挑戰(zhàn)。在 Linux 中,每個(gè)程序員都可以自由選擇他或她喜歡的配置文件格式。可以選擇的格式
很多,從 /etc/shells 文件(它包含被一個(gè)換行符分開的 shell 的列表),到 Apache 的復(fù)雜的
/etc/httpd.conf 文件。
什么是系統(tǒng)配置文件?
內(nèi)核本身也可以看成是一個(gè)“程序”。為什么內(nèi)核需要配置文件??jī)?nèi)核需要了解系統(tǒng)中用戶和組的列表,
進(jìn)而管理文件權(quán)限(即根據(jù)權(quán)限判定特定用戶(UNIX_USERS)是否可以打開某個(gè)文件)。注意,這些文
件不是明確地由程序讀取的,而是由系統(tǒng)庫(kù)所提供的一個(gè)函數(shù)讀取,并被內(nèi)核使用。例如,程序需要某
個(gè)用戶的(加密過(guò)的)密碼時(shí)不應(yīng)該打開 /etc/passwd 文件。相反,程序應(yīng)該調(diào)用系統(tǒng)庫(kù)的 getpw() 函
數(shù)。這種函數(shù)也被稱為系統(tǒng)調(diào)用。打開 /etc/passwd 文件和之后查找那個(gè)被請(qǐng)求的用戶的密碼都是由
內(nèi)核(通過(guò)系統(tǒng)庫(kù))決定的。
除非另行指定,Red Hat Linux 系統(tǒng)中大多數(shù)配置文件都在 /etc 目錄中。配置文件可以大致分為下面
幾類:
2、配置文件分類:
訪問(wèn)文件
/etc/host.conf
告訴網(wǎng)絡(luò)域名服務(wù)器如何查找主機(jī)名。(通常是 /etc/hosts,
然后就是名稱服務(wù)器;可通過(guò) netconf 對(duì)其進(jìn)行更改)
/etc/hosts
包含(本地網(wǎng)絡(luò)中)已知主機(jī)的一個(gè)列表。如果系統(tǒng)的 IP 不
是動(dòng)態(tài)生成,就可以使用它。對(duì)于簡(jiǎn)單的主機(jī)名解析(點(diǎn)分表
示法),在請(qǐng)求 DNS 或 NIS 網(wǎng)絡(luò)名稱服務(wù)器之前,
/etc/hosts.conf 通常會(huì)告訴解析程序先查看這里。
/etc/hosts.allow
請(qǐng)參閱 hosts_access 的聯(lián)機(jī)幫助頁(yè)。至少由 tcpd 讀取。
/etc/hosts.deny
請(qǐng)參閱 hosts_access 的聯(lián)機(jī)幫助頁(yè)。至少由 tcpd 讀取。
引導(dǎo)和登錄/注銷
/etc/issue
/etc/issue點(diǎn)虐
時(shí)也是管理員,那么在 group 文件中他的條目看起來(lái)就會(huì)是這樣的:user: * :
group-id : project1
/etc/nologin
這是一個(gè)普通的文本文件.你可以在里面寫上你喜歡的任何東西./etc/nologin
的作用在于,如果它存在,那么系統(tǒng)將拒絕任何非 root 用戶的登錄請(qǐng)求,并對(duì)其
它登錄用戶顯示此文件的內(nèi)容
此文件常由系統(tǒng)在停機(jī)前自動(dòng)生成.有時(shí)系統(tǒng)管理員也會(huì)手工生成它,用以禁止
其它用戶登錄,方便進(jìn)行一些管理工作.
etc/passwd
1.文件格式
/etc/passwd 存儲(chǔ)了系統(tǒng)中所有用戶的基本信息.可以說(shuō)這是系統(tǒng)中最重要的一
個(gè)配置文件.對(duì)它作任何修改一定要小心謹(jǐn)慎.同時(shí)要經(jīng)常檢察這個(gè)文件,包括
它的內(nèi)容和權(quán)限設(shè)置.
使用 vi 編輯程序打開此文件,可以看到這個(gè)文件由許多行記錄組成.每一行記
錄對(duì)應(yīng)著一個(gè)用戶.我們以第一行為例.第一行一般是 root 用戶的記錄,盡管這
不是必需的.實(shí)際上用戶記錄出現(xiàn)的順序并沒(méi)有任何的意義.
在我的系統(tǒng)中,/etc/passwd 的第一行看起來(lái)是這樣的:
root:x:0:0:root:/root:/bin/bash
每一條記錄都由 7 個(gè)字段組成,每個(gè)字段之間用冒號(hào)隔開.第一個(gè)字段是用戶
名,示例中是 root.第二個(gè)字段是用戶口令,示例中是一個(gè)字符 x,但這并不表示root 的口令是單個(gè)字符 x,而是說(shuō)用戶口令被加密了,并且加密口令也沒(méi)有放在
本文件中,而是放到了/etc/shadow(參考 /etc/shadow).假如刪除這個(gè) x,那么
root 的口令就清空了.第三個(gè)字段是用戶的用戶 ID,即 uid.第四個(gè)字段是用戶
的組 ID,即 gid. 這里要注意,系統(tǒng)分辨兩個(gè)用戶是看他們的 uid 是否相同而不
是看他們的用戶名是否相同.用戶名不同但 uid 相同的兩個(gè)用戶實(shí)際上是同一
個(gè)用戶.對(duì)組來(lái)說(shuō)也有類似的規(guī)則.所以這兩個(gè)字段大家一定要注意.第五個(gè)字
段是用戶全稱,沒(méi)有什么實(shí)際用途,相當(dāng)于注釋,這里是 root.第六個(gè)字段是用戶
的主目錄 (home),即登錄系統(tǒng)后默認(rèn)所處目錄,這里是/root.最后一個(gè)字段是
用戶的登錄 shell,可以是系統(tǒng)擁有的任何一個(gè) shell 的完整路徑,這里是
/bin/bash.注意,這個(gè)字段可以有一個(gè)特殊的值,即/sbin/nologin.如果把一個(gè)
用戶的登錄 shell 設(shè)置為 /sbin/nologin 的話,系統(tǒng)將禁止此用戶的本地登錄.
請(qǐng)參閱“man passwd”。它包含一些用戶帳號(hào)信息,包括密碼(如果未被 shadow
程序加密過(guò))。
2.安全性
/etc/passwd 的默認(rèn)權(quán)限為 644,所有者和所有組均為 root.切記,在任何情況下
都不要更改它.
3.相關(guān)命令
passwd
useradd
userdel
adduser
usermod
users
/etc/rpmrc
rpm 命令配置。所有的 rpm 命令行選項(xiàng)都可以在這個(gè)文件中一起設(shè)置,這樣,
當(dāng)任何 rpm 命令在該系統(tǒng)中運(yùn)行時(shí),所有的選項(xiàng)都會(huì)全局適用。
/etc/securetty
包含設(shè)備名稱,由 tty 行組成(每行一個(gè)名稱,不包括前面的 /dev/),root
用戶在這里被允許登錄。
1.文件格式
這是一個(gè)設(shè)備文件的列表.文件名取相對(duì)于/dev 的相對(duì)路徑.如,/dev/tty1 記
為 tty1
root 只有從這個(gè)列表中列出的設(shè)備上才可以登錄系統(tǒng).
例如:
代碼:
$cat /etc/securretty
tty1
tty2
tty3
這里 root 被限定只能從/dev/tty1, /dev/tty2, /dev/tty3 這三個(gè)設(shè)備上登錄
系統(tǒng)
如果/etc/securretty 不存在的話,那么 root 將可以從任何設(shè)備登錄系統(tǒng).
2.安全性
/etc/securetty 的默認(rèn)權(quán)限是 600,所有者和所有組都是 root
/etc/shadow
包含加密后的用戶帳號(hào)密碼信息,還可以包括密碼時(shí)效信息。包括的字段有:? 登錄名
? 加密后的密碼
? 從 1970 年 1 月 1 日到密碼最后一次被更改的天數(shù)
? 距密碼可以更改之前的天數(shù)
? 距密碼必須更改之前的天數(shù)
? 密碼到期前用戶被警告的天數(shù)
? 密碼到期后帳戶被禁用的天數(shù)
? 從 1970 年 1 月 1 日到帳號(hào)被禁用的天數(shù)
1.文件格式
/etc/shadow 文件保存的是用戶名,密碼,用戶賬號(hào)設(shè)置相關(guān)信息。
例:
root:$1$6UviCNvh$WTR0zPMek41KmzD0Z1DdV1:12264:3:4:5:6:12267:
第一段: root----- 用戶注冊(cè)名
第二段: $1$6UviCNvh$WTR0zPMek41KmzD0Z1DdV1 ----加密口令
第三段: 12264-----上次更動(dòng)密碼的日期,以 1970 年 1 月 1 日為 1,1 天加 1
第四段: 3---------密碼將被允許修改之前的天數(shù)(0 表示“可在任何時(shí)間修
改”)
第五段: 4---------系統(tǒng)將強(qiáng)制用戶修改為新密碼之前的天數(shù)(1 表示“永遠(yuǎn)
都不能修改”)
第六段: 5---------密碼過(guò)期之前,用戶將被警告過(guò)期的天數(shù)(-1 表示“沒(méi)有
警告”)
第七段: 6---------密碼過(guò)期之后,系統(tǒng)自動(dòng)禁用帳戶的天數(shù)(-1 表示“永遠(yuǎn)
不會(huì)禁用”)
第八段: 12267-----該帳戶被禁用的天數(shù)(-1 表示“該帳戶被啟用”).以 1970
年 1 月 1 日為 1,1 月 2 日為 2
第九段 ------ 保留供將來(lái)使用
注:第 2 段中為*表示帳號(hào)不可登錄,如密碼前為 !! 或只有 !! 表示帳號(hào)被鎖
2.安全性/etc/shadow 的默認(rèn)所有者和所有組均為 root.
建議運(yùn)行# chattr +i /etc/shadow 來(lái)保護(hù)文件使其不被意外地刪除或重寫
3.相關(guān)命令
passwd
useradd
userdel
usermod
/ect/gshadow
1.文件格式
/ect/gshadow 文件保存的是用戶和組群設(shè)置的信息
例:
root:!!::root,wa1
第一段:組名
第四段:該組包含用戶列表
2.安全性
/etc/gshadow 的默認(rèn)所有者和所有組均為 root.
建議運(yùn)行# chattr +i /etc/shadow 來(lái)保護(hù)文件使其不被意外地刪除或重寫
3.相關(guān)命令
groupadd
groupdel
groupmod
groups
/etc/sysctl.conf
1.文件格式
/etc/sysctl.conf 是 sysctl 程序的配置文件.sysctl 可以在系統(tǒng)運(yùn)行時(shí)更改內(nèi)
核參數(shù)./etc/sysctl.conf 中的配置將在系統(tǒng)起動(dòng)時(shí)執(zhí)行.
以 # 和 ; 開始的行是注釋,將和空白行一起被忽略.
配置項(xiàng)的格式為:
token = value
token 是一個(gè)鍵名,value 是對(duì)應(yīng)的鍵值.token 和 value 前后的空格將被忽略
token 不能是隨意的字符串.他和/proc/sys 下的文件有一一對(duì)應(yīng)的關(guān)系:
.h2 NEWS_PROXY
.h2 NNTP_PROXY
# Lynx version 2.2 and beyond supports the use of proxy servers that can act as
# firewall gateways and caching servers. They are preferable to the older
# gateway servers. Each protocol used by Lynx can be mapped separately using
# PROTOCOL_proxy environment variables (see Lynx Users Guide). If you have
# not set them externally, you can set them at run time via this configuration file.
# They will not override external settings. The no_proxy variable can be used
# to inhibit proxying to selected regions of the Web (see below). Note that on
# VMS these proxy variables are set as process logicals rather than symbols, to
# preserve lowercasing, and will outlive the Lynx image.
#
.ex 15
http_proxy:
ftp_proxy:
#http_proxy:
#ftp_proxy:
.h2 NO_PROXY
# The no_proxy variable can be a comma-separated list of strings defining
# no-proxy zones in the DNS domain name space. If a tail substring of the
# domain-path for a host matches one of these strings, transactions with that# node will not be proxied.
.ex
no_proxy:demiurge.in.ibm點(diǎn)抗 , demiurge
更改配置文件
在更改配置文件時(shí),如果程序不是由系統(tǒng)管理員或內(nèi)核控制的,就要確保重新啟動(dòng)過(guò)使用該配置的程
序。普通用戶通常沒(méi)有啟動(dòng)或停止系統(tǒng)程序和/或守護(hù)進(jìn)程的權(quán)限。
內(nèi)核
更改內(nèi)核中的配置文件會(huì)立即影響到系統(tǒng)。例如,更改 passwd 文件以增加用戶將立即使該用戶變?yōu)?/p>
可用。而且任何 Linux 系統(tǒng)的 /proc/sys 目錄中都有一些內(nèi)核可調(diào)參數(shù)。只有超級(jí)用戶可以得到對(duì)
所有這些文件的寫訪問(wèn)權(quán)力;其它用戶只有只讀訪問(wèn)權(quán)力。此目錄中文件的分類的方式和 Linux 內(nèi)
核源代碼的分類方式一樣。此目錄中的每個(gè)文件都代表一個(gè)內(nèi)核數(shù)據(jù)結(jié)構(gòu),這些數(shù)據(jù)結(jié)構(gòu)可以被動(dòng)態(tài)
地修改,從而改變系統(tǒng)性能。
注意:在更改其中任何文件的任何值之前,您應(yīng)該確保自己全面了解該文件,以避免對(duì)系統(tǒng)造成不可
修復(fù)的損害。
/proc/sys/kernel/ 目錄中的文件
文件名
描述
threads-max
內(nèi)核可運(yùn)行的最大任務(wù)數(shù)。
ctrl-alt-del
如果值為 1,那么順序按下這幾個(gè)鍵將“徹底地”重新引
導(dǎo)系統(tǒng)。
sysrq
如果值為 1,Alt-SysRq 則為激活狀態(tài)。
osrelease
顯示操作系統(tǒng)的發(fā)行版版本號(hào)
ostype
顯示操作系統(tǒng)的類型。
hostname
系統(tǒng)的主機(jī)名。
domainname
網(wǎng)絡(luò)域,系統(tǒng)是該網(wǎng)絡(luò)域的一部分。
modprobe
指定 modprobe 是否應(yīng)該在啟動(dòng)時(shí)自動(dòng)運(yùn)行并加載必需
的模塊。
守護(hù)進(jìn)程和系統(tǒng)程序
守護(hù)進(jìn)程是永遠(yuǎn)運(yùn)行在后臺(tái)的程序,它默默地執(zhí)行自己的任務(wù)。常見(jiàn)的守護(hù)進(jìn)程有 in.ftpd(ftp 服
務(wù)器守護(hù)進(jìn)程)、in.telnetd(telnet 服務(wù)器守護(hù)進(jìn)程)和 syslogd(系統(tǒng)日志記錄守護(hù)進(jìn)程)。
有些守護(hù)進(jìn)程在運(yùn)行時(shí)會(huì)嚴(yán)密監(jiān)視配置文件,在配置文件改變時(shí)就會(huì)自動(dòng)重新加載它。但是大多數(shù)守
護(hù)進(jìn)程并不會(huì)自動(dòng)重新加載配置文件。我們需要以某種方式“告訴”這些守護(hù)進(jìn)程配置文件已經(jīng)被發(fā)
生了改變并應(yīng)該重新加載??梢酝ㄟ^(guò)使用服務(wù)命令重新啟動(dòng)服務(wù)來(lái)達(dá)到這個(gè)目的(在 Red Hat Linux
系統(tǒng)上)。
例如,如果我們更改了網(wǎng)絡(luò)配置,就需要發(fā)出:
service network restart 。
注意:這些服務(wù)最常見(jiàn)的是 /etc/rc.d/init.d/* 目錄中存在的腳本,在系統(tǒng)被引導(dǎo)時(shí)由 init 啟動(dòng)。
所以,您也可以執(zhí)行如下操作來(lái)重新啟動(dòng)服務(wù):
/etc/rc.d/init.d/script-for-the-service start | stop | status
start、stop 和 status 是這些腳本接受的輸入值,用來(lái)執(zhí)行操作。
用戶程序用戶或系統(tǒng)程序在每次啟動(dòng)時(shí)都會(huì)讀取其配置文件。盡管如此,請(qǐng)記住,有些系統(tǒng)程序在計(jì)算機(jī)打開
時(shí)情況不一樣,它們的行為依賴于在 /etc/ 中的配置文件中讀到的內(nèi)容。所以,用戶程序第一次啟
動(dòng)時(shí)將從 /etc/ 目錄中存在的文件讀取缺省配置。然后,用戶可以通過(guò)使用 rc 和 .(點(diǎn))文件來(lái)
定制程序,正如下面一節(jié)所示。
用戶配置文件:.(點(diǎn))文件和 rc 文件
我們已經(jīng)看到怎樣容易地配置程序。但是如果有的人不喜歡在 /etc/ 中配置程序的方式該怎么辦呢?
“普通”用戶不能簡(jiǎn)單地進(jìn)入 /etc 然后更改配置文件;從文件系統(tǒng)的角度來(lái)看,配置文件的所有者
是 root 用戶!這就是大多數(shù)用戶程序都定義兩個(gè)配置文件的原因:第一個(gè)是“系統(tǒng)”級(jí)別的,位于
/etc/;另一個(gè)屬于用戶“專用”,可以在他或她的主目錄中找到。
例如,我在我的系統(tǒng)中安裝了非常有用的 wget 實(shí)用程序。/etc/ 中有一個(gè) /etc/wgetrc 文件。在
我的主目錄中,有一個(gè)名為 .wgetrc 的文件,它描述了我定制的配置(只有在我,也就是用戶運(yùn)行
wget 命令時(shí),才會(huì)加載這個(gè)配置文件)。其它用戶在他們自己的主目錄(/home/other)中也可以
有 .wgetrc 文件;當(dāng)然,只有這些用戶運(yùn)行 wget 命令時(shí),才會(huì)讀取這個(gè)文件。換句話說(shuō),/etc/wgetrc
文件為 wget 提供了“缺省”值,而 /home/xxx/.wgetrc 文件列舉了某個(gè)用戶的“定制項(xiàng)”。重要
的是這只是“一般規(guī)則”,并非所有情況都如此。例如,一個(gè)象 pine 一樣的程序,在 /etc/ 中并
沒(méi)有任何文件,它只在用戶主目錄中有一個(gè)定制配置文件,名為 .pinerc。其它程序可能只有 /etc/
中的缺省配置文件,而且可能不允許用戶“定制”這些配置文件(/etc 目錄中只有少數(shù) config. 文
件是這種情況)。
通常使用的 rc 和 .(點(diǎn))文件
文件名
描述
~/.bash_login
請(qǐng)參考“man bash”。如果
~/.bash_profile 不存在,bash 則將
~/.bash_login 作為
~/.bash_profile 處理。
~/.bash_logout
請(qǐng)參考“man bash”。在退出時(shí)由
bash 登錄 shell 引用。
~/.bash_profile
由 bash 登錄 shell 引用
/etc/profile 之后引用。
~/.bash_history
先前執(zhí)行的命令的列表。
~/.bashrc
請(qǐng)參考“man bash”。由 bash 非登
錄交互式 shell 引用(沒(méi)有其它文
件)。除非設(shè)置了 BASH_ENV 或 ENV,
非交互式 shell 不引用任何文件。
~/.emacs
啟動(dòng)時(shí)由 emac 讀取。
~/.forward
如果這里包含一個(gè)電子郵件地址,那
么所有發(fā)往 ~ 的所有者的郵件都會(huì)
被轉(zhuǎn)發(fā)到這個(gè)電子郵件地址。
~/.fvwmrc ~/.fvwm2rc
fvwm 和 fvwm2(基本的 X Window 管
理器)的配置文件。
~/.hushlogin
請(qǐng)參考“man login”。引起“無(wú)提
示”登錄(沒(méi)有郵件通知、上次登錄
信息或者 MOD 信息)。~/.mail.rc
郵件程序的用戶初始化文件。
~/.ncftp/
ncftp 程序的目錄;包含書簽、日志、
宏、首選項(xiàng)和跟蹤信息。請(qǐng)參閱 man
ncftp。ncftp 的目的是為因特網(wǎng)標(biāo)準(zhǔn)
文件傳輸協(xié)議(Internet standard
File Transfer Protocol)提供一個(gè)
強(qiáng)大而靈活的接口。它旨在替換系統(tǒng)
所使用的標(biāo)準(zhǔn)的 ftp 程序。
~/.profile
請(qǐng)參考“man bash”。如果
~/.bash_profile 和 ~/.bash_login
文件不存在,bash 則將 ~/.profile
作為 ~/.bash_profile 處理,并被其
它繼承 Bourn 的 shell 使用。
~/.pinerc
Pine 配置
~/.muttrc
Mutt 配置
~/.exrc
這個(gè)文件可以控制 vi 的配置。
示例:set ai sm ruler
在此文件中寫入上面一行會(huì)讓 vi 設(shè)
置自動(dòng)縮進(jìn)、匹配括號(hào)、顯示行號(hào)和
行-列這幾個(gè)選項(xiàng)。
~/.vimrc
缺省的“Vim”配置文件。和 .exrc
一樣。
~/.gtkrc
GNOME 工具包(GNOME Toolkit)。
~/.kderc
KDE 配置。
~/點(diǎn)虐 rc
ftp 缺省登錄名和密碼。
~/.rhosts
由 r- 工具(如 rsh、rlogin 等等)
使用。因?yàn)槊俺渲鳈C(jī)很容易,所以安
全性非常低。
1. 必須由用戶(~/ 的所有者)或超
級(jí)用戶擁有。
2. 列出一些主機(jī),用戶可以從這些主
機(jī)訪問(wèn)該帳號(hào)。
3. 如果是符號(hào)鏈接則被忽略。
~/.rpmrc
請(qǐng)參閱“man rpm”。如果 /etc/rpmrc
不存在則由 rpm 讀取。
~/.signature
消息文本,將自動(dòng)附加在從此帳號(hào)發(fā)
出的郵件末尾。
~/.twmrc
twm( The Window Manager)的配置
文件。~/.xinitrc
啟動(dòng)時(shí)由 X 讀?。ǘ皇怯?xinit
腳本讀取)。通常會(huì)啟動(dòng)一些程序。
示例:exec /usr/sbin/startkde
如果該文件中存在上面這行內(nèi)容,那
么在從這個(gè)帳號(hào)發(fā)出 startx 命令
時(shí),這一行就會(huì)啟動(dòng)“KDE 視窗管理
器”(KDE Window Manager)。
~/.xmodmaprc
此文件被傳送到 xmodmap 程序,而且
可以被命名為任何文件(例如
~/.Xmodmap 和 ~/.keymap.km)。
~/.xserverrc
如果 xinit 可以找到要執(zhí)行的 X,
xinit 就會(huì)將該文件作為 X 服務(wù)器
運(yùn)行。
~/News/Sent-Message-IDs
gnus 的缺省郵件歷史文件。
~/.Xauthority
由 xdm 程序讀和寫,以處理權(quán)限。請(qǐng)
參閱 X、xdm 和 xauth 聯(lián)機(jī)幫助頁(yè)。
~/.Xdefaults,
~/.Xdefaults-hostname
在主機(jī) hostname 的啟動(dòng)過(guò)程中由 X
應(yīng)用程序讀取。如果找不到
-hostname 文件,則查找 .Xdefaults
文件。
~/.Xmodmap
指向 .xmodmaprc;Red Hat 有使用這
個(gè)名稱的 .xinitrc 文件。
~/.Xresources
通常是傳送到 xrdb 以加載 X 資源
數(shù)據(jù)庫(kù)的文件的名稱,旨在避免應(yīng)用
程序需要讀取一個(gè)很長(zhǎng)
的 .Xdefaults 文件這樣的情況。(有
些情況曾經(jīng)使用了 ~/.Xres。)
~/mbox
用戶的舊郵件。
3、重要的配置文件列表:
啟動(dòng)引導(dǎo)程序配置文件
LILO /etc/lilo.conf
GRUB /boot/grub/menu.lst
系統(tǒng)啟動(dòng)文件核腳本
主啟動(dòng)控制文件 /etc/inittab
SysV 啟動(dòng)腳本的位置 /etc/init.d、/etc/rc.d/init.d 或/etc/rc.d
SysV 啟動(dòng)腳本鏈接的位置 /etc/init.d/rc?.d、/etc/rc.d/rc?.d 或/etc/rc?.d
本地啟動(dòng)腳本 /etc/rc.d/rc.local、/etc/init.d/boot.local 或/etc/rc.boot 里的文件
網(wǎng)絡(luò)配置文件
建立網(wǎng)絡(luò)接口的腳本 /sbin/ifup
保存網(wǎng)絡(luò)配置數(shù)據(jù)文件的目錄 /etc/network、/etc/sysconfig/network 和
/etc/sysconfig/network-scripts保存解析 DNS 服務(wù)的文件 /etc/resolv.conf
DHCP 客戶端的配置文件 /etc/dhclient.conf
超級(jí)服務(wù)程序配置文件和目錄
inetd 配置文件 /etc/inetd.conf
TCP Wrappers 配置文件 /etc/hosts.allow 和/etc/hosts.deny
xinetd 配置文件 /etc/xinetd.conf 和/etc/xinetd.d 目錄里的文件
硬件配置
內(nèi)核模塊配置文件 /etc/modules.conf
硬件訪問(wèn)文件
Linux 設(shè)備文件 /dev 目錄里
保存硬件和驅(qū)動(dòng)程序數(shù)據(jù)的文件 /proc 目錄里
掃描儀配置文件
SANE 主配置 /etc/sane.d/dll.conf
特定掃描儀的配置文件 /etc/sane.d 目錄里以掃描儀型號(hào)命名的文件
打印機(jī)配置文件
BSD LPD 核 LPRng 的本地打印機(jī)主配置文件 /etc/printcap
CUPS 本地打印機(jī)主配置和遠(yuǎn)程訪問(wèn)受權(quán)文件 /etc/cups/cupsd.conf
BSD LPD 遠(yuǎn)程訪問(wèn)受權(quán)文件 /etc/hosts.lpd
LPRng 遠(yuǎn)程訪問(wèn)受權(quán)文件 /etc/lpd.perms
文件系統(tǒng)
文件系統(tǒng)表 /etc/fstab
軟驅(qū)裝配點(diǎn) /floppy、/mnt/floppy 或/media/floppy
光驅(qū)裝配點(diǎn) /cdrom、/mnt/cdrom 或/media/cdrom
shell 配置文件
bash 系統(tǒng)非登錄配置文件 /etc/bashrc、/etc/bash.bashrc 或/etc/bash.bashrc.local
bash 系統(tǒng)登錄文件 /etc/profile 和/etc/profile.d 里的文件
bash 用戶非登錄配置文件 ~/.bashrc
bash 用戶登錄配置文件 ~/.profile
XFree86 配置文件核目錄
XFree86 主配置文件 /etc/XF86config、/etc/X11/XF86Config 或/etc/X11/XF86Config-4
字體服務(wù)程序配置文件 /etc/X11/fs/config
Xft 1.x 配置文件 /etcX11/XftConfig
Xft 2.0 配置文件 /etc/fonts/fonts.conf
字體目錄 /usr/X11R6/lib/X11/fonts 和/usr/share/fonts
Web 服務(wù)程序配置文件
Apache 主配置文件 /etc/apache、/etc/httpd 或/httpd/conf 里的 httpd.conf 或 httpd2.conf 文
件
MIME 類型文件 與 Apache 主配置文件在同一目錄里的 mime.types 或 apache-mime.types
文件服務(wù)程序配置文件
ProFTPd 配置文件 /etc/proftpd.conf
vsftpd 配置文件 /etc/vsftpd.conf
NFS 服務(wù)程序的輸出定義文件 /etc/exports
NFS 客戶端裝配的 NFS 輸出 /etc/fstab
Samba 配置文件 /etc/samba/smb.confSamba 用戶配置文件 /etc/samba/smbpasswd
郵件服務(wù)程序配置文件
sendmail 主配置文件 /etc/mail/sendmail.cf
sendmail 源配置文件 /etc/mail/sendmail.mc 或/usr/share/sendmail/cf/cf/linux.smtp.mc 或
其他文件
Postfix 主配置文件 /etc/postfix/main.cf
Exim 主配置文件 /etc/exim/exim.cf
Procmail 配置文件 /etc/procmailrc 或~/.procmailrc
Fetchmail 配置文件 ~/.fetchmailrc
遠(yuǎn)程登錄配置文件
SSH 服務(wù)程序配置文件 /etc/ssh/sshd_config
SSH 客戶端配置文件 /etc/ssh/ssh_config
XDM 配置文件 /etc/X11/xdm 目錄下
GDM 配置文件 /etc/X11/gdm 目錄下
VNC 服務(wù)程序配置文件 /usr/X11R6/bin/vncserver 啟動(dòng)腳本和~/.vnc 目錄里的文件
其他服務(wù)程序配置文件
DHCP 服務(wù)程序配置文件 /etc/dhcpd.conf
BIND 服務(wù)程序配置文件 /etc/named.conf 和/var/named/
NTP 服務(wù)程序配置文件 /etc/ntp.conf
ldd
可執(zhí)行文件名
查看可執(zhí)行文件鏈接了哪些
系統(tǒng)動(dòng)態(tài)鏈接庫(kù)
nm
可執(zhí)行文件名
查看可執(zhí)行文件里面有哪些符號(hào)
strip
可執(zhí)行文件名
去除符號(hào)表可以給可執(zhí)行文件瘦身
如果我們想從可執(zhí)行程序里面提取出來(lái)一點(diǎn)什么文本信息的話,還可以用strings命令
strings
可執(zhí)行文件名
Linux操作系統(tǒng)上面的動(dòng)態(tài)共享庫(kù)大致分為三類:
1、操作系統(tǒng)級(jí)別的共享庫(kù)和基礎(chǔ)的系統(tǒng)工具庫(kù)
比方說(shuō)libc.so,
libz.so,
libpthread.so等等,這些系統(tǒng)庫(kù)會(huì)被放在/lib和/usr/lib目錄下面,如果是64位操作系統(tǒng),還會(huì)有/lib64和/usr
/lib64目錄。如果操作系統(tǒng)帶有圖形界面,那么還會(huì)有/usr/X11R6/lib目錄,如果是64位操作系統(tǒng),還有/usr/X11R6
/lib64目錄。此外還可能有其他特定Linux版本的系統(tǒng)庫(kù)目錄。
這些系統(tǒng)庫(kù)文件的完整和版本的正確,確保了Linux上面各種程序能夠正常的運(yùn)行。
2、應(yīng)用程序級(jí)別的系統(tǒng)共享庫(kù)
并非操作系統(tǒng)自帶,但是可能被很多應(yīng)用程序所共享的庫(kù),一般會(huì)被放在/usr/local/lib和/usr/local/lib64這兩個(gè)目錄下面。很多你自行編譯安裝的程序都會(huì)在編譯的時(shí)候自動(dòng)把/usr/local/lib加入gcc的-L參數(shù),而在運(yùn)行的時(shí)候自動(dòng)到/usr/local
/lib下面去尋找共享庫(kù)。
以上兩類的動(dòng)態(tài)共享庫(kù),應(yīng)用程序會(huì)自動(dòng)尋找到他們,并不需要你額外的設(shè)置和擔(dān)心。這是為什么呢?因?yàn)橐陨线@些目錄默認(rèn)就被加入到動(dòng)態(tài)鏈接程序的搜索路徑里面了。Linux的系統(tǒng)共享庫(kù)搜索路徑定義在/etc/ld.so.conf這個(gè)配置文件里面。這個(gè)文件的內(nèi)容格式大致如下:
/usr/X11R6/lib64
/usr/X11R6/lib
/usr/local/lib
/lib64
/lib
/usr/lib64
/usr/lib
/usr/local/lib64
/usr/local/ImageMagick/lib
假設(shè)我們自己編譯安裝的ImageMagick圖形庫(kù)在/usr/local/ImageMagick目錄下面,并且希望其他應(yīng)用程序都可以使用
ImageMagick的動(dòng)態(tài)共享庫(kù),那么我們只需要把/usr/local/ImageMagick/lib目錄加入/etc/ld.so.conf文件里面,然后執(zhí)行:ldconfig
命令即可。
ldcofig將搜索以上所有的目錄,為共享庫(kù)建立一個(gè)緩存文件/etc/ld.so.cache。為了確認(rèn)ldconfig已經(jīng)搜索到ImageMagick的庫(kù),我們可以用上面介紹的strings命令從ld.so.cache里面抽取文本信息來(lái)檢查一下:
strings
/etc/ld.so.cache
|
grep
ImageMagick
輸出結(jié)果為:
/usr/local/ImageMagick/lib/libWand.so.10
/usr/local/ImageMagick/lib/libWand.so
/usr/local/ImageMagick/lib/libMagick.so.10
/usr/local/ImageMagick/lib/libMagick.so
/usr/local/ImageMagick/lib/libMagick++.so.10
/usr/local/ImageMagick/lib/libMagick++.so
已經(jīng)成功了!
3、應(yīng)用程序獨(dú)享的動(dòng)態(tài)共享庫(kù)
有很多共享庫(kù)只被特定的應(yīng)用程序使用,那么就沒(méi)有必要加入系統(tǒng)庫(kù)路徑,以免應(yīng)用程序的共享庫(kù)之間發(fā)生版本沖突。因此Linux還可以通過(guò)設(shè)置環(huán)境變量LD_LIBRARY_PATH來(lái)臨時(shí)指定應(yīng)用程序的共享庫(kù)搜索路徑,就像我們上面舉的那個(gè)例子一樣,我們可以在應(yīng)用程序的啟動(dòng)腳本里面預(yù)先設(shè)置
LD_LIBRARY_PATH,指定本應(yīng)用程序附加的共享庫(kù)搜索路徑,從而讓應(yīng)用程序找到它。