青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

xiaoguozi's Blog
Pay it forword - 我并不覺(jué)的自豪,我所嘗試的事情都失敗了······習(xí)慣原本生活的人不容易改變,就算現(xiàn)狀很糟,他們也很難改變,在過(guò)程中,他們還是放棄了······他們一放棄,大家就都是輸家······讓愛(ài)傳出去,很困難,也無(wú)法預(yù)料,人們需要更細(xì)心的觀察別人,要隨時(shí)注意才能保護(hù)別人,因?yàn)樗麄兾幢刂雷约阂裁础ぁぁぁぁ?/span>

SSH是一個(gè)非常偉大的工具,如果你要在互聯(lián)網(wǎng)上遠(yuǎn)程連接到服務(wù)器,那么SSH無(wú)疑是最佳的候選。下面是通過(guò)網(wǎng)絡(luò)投票選出的25個(gè)最佳SSH命令,你必須牢記于心。

1、復(fù)制SSH密鑰到目標(biāo)主機(jī),開(kāi)啟無(wú)密碼SSH登錄

ssh-copy-id user@host

如果還沒(méi)有密鑰,請(qǐng)使用ssh-keygen命令生成。

2、從某主機(jī)的80端口開(kāi)啟到本地主機(jī)2001端口的 ssh 隧道

ssh -N -L2001:localhost:80 somemachine

現(xiàn)在你可以直接在瀏覽器中輸入http://localhost:2001訪問(wèn)這個(gè)網(wǎng)站。

3、將你的麥克風(fēng)輸出到遠(yuǎn)程計(jì)算機(jī)的揚(yáng)聲器

dd if=/dev/dsp | ssh -c arcfour -C username@host dd of=/dev/dsp

這樣來(lái)自你麥克風(fēng)端口的聲音將在SSH目標(biāo)計(jì)算機(jī)的揚(yáng)聲器端口輸出,但遺憾的是,聲音質(zhì)量很差,你會(huì)聽(tīng)到很多嘶嘶聲。

4、比較遠(yuǎn)程和本地文件

ssh user@host cat /path/to/remotefile | diff /path/to/localfile –

在比較本地文件和遠(yuǎn)程文件是否有差異時(shí)這個(gè)命令很管用。

5、通過(guò)SSH掛載目錄/文件系統(tǒng)

sshfs name@server:/path/to/folder /path/to/mount/point

從http://fuse.sourceforge.net/sshfs.html下載sshfs,它允許你跨網(wǎng)絡(luò)安全掛載一個(gè)目錄。

6、通過(guò)中間主機(jī)建立SSH連接

ssh -t reachable_host ssh unreachable_host

Unreachable_host表示從本地網(wǎng)絡(luò)無(wú)法直接訪問(wèn)的主機(jī),但可以從reachable_host所在網(wǎng)絡(luò)訪問(wèn),這個(gè)命令通過(guò)到reachable_host的“隱藏”連接,創(chuàng)建起到unreachable_host的連接。

7、通過(guò)你的電腦,復(fù)制遠(yuǎn)程 host1 主機(jī)上的文件到遠(yuǎn)程 host2 主機(jī)上的文件

ssh root@host1 “cd /somedir/tocopy/ && tar -cf – .” | ssh root@host2 “cd /samedir/tocopyto/ && tar -xf -”

如果只有你能同時(shí)訪問(wèn) host1 和 host 2 ,但它們不能訪問(wèn)你的主機(jī)(因此 ncat 是無(wú)法工作的),而且它們之間也無(wú)法直接訪問(wèn)。

8、運(yùn)行任何遠(yuǎn)程主機(jī)上的 GUI 程序

ssh -fX <user>@<host> <program>

SSH 服務(wù)器端必須要具備以下條件:

X11Forwarding yes #確保 X11 轉(zhuǎn)發(fā)是打開(kāi)的

同時(shí)也可以打開(kāi)

Compression delayed

當(dāng)然,你要能訪問(wèn)主機(jī)A才行。

9、創(chuàng)建到目標(biāo)主機(jī)的持久化連接

ssh -MNf <user>@<host>

在后臺(tái)創(chuàng)建到目標(biāo)主機(jī)的持久化連接,將這個(gè)命令和你~/.ssh/config中的配置結(jié)合使用:

Host host
ControlPath ~/.ssh/master-%r@%h:%p
ControlMaster no

所有到目標(biāo)主機(jī)的SSH連接都將使用持久化SSH套接字,如果你使用SSH定期同步文件(使用rsync/sftp/cvs/svn),這個(gè)命令將非常有用,因?yàn)槊看未蜷_(kāi)一個(gè)SSH連接時(shí)不會(huì)創(chuàng)建新的套接字。

10、通過(guò)SSH 直接開(kāi)啟并還原 screen 命令

ssh -t remote_host screen –r

直接連接到遠(yuǎn)程 screen 會(huì)話(節(jié)省了無(wú)用的父bash進(jìn)程)。

11、端口檢測(cè)(敲門)

knock <host> 3000 4000 5000 && ssh -p <port> user@host && knock <host> 5000 4000 3000

在一個(gè)端口上敲一下打開(kāi)某個(gè)服務(wù)的端口(如SSH),再敲一下關(guān)閉該端口,需要先安裝knockd,下面是一個(gè)配置文件示例。

[options]
logfile = /var/log/knockd.log
[openSSH]
sequence = 3000,4000,5000
seq_timeout = 5
command = /sbin/iptables -A INPUT -i eth0 -s %IP% -p tcp –dport 22 -j ACCEPT
tcpflags = syn
[closeSSH]
sequence = 5000,4000,3000
seq_timeout = 5
command = /sbin/iptables -D INPUT -i eth0 -s %IP% -p tcp –dport 22 -j ACCEPT
tcpflags = syn

12、刪除文本文件中的一行內(nèi)容,有用的修復(fù)

ssh-keygen -R <the_offending_host>

在這種情況下,最好使用專業(yè)的工具。

13、通過(guò)SSH運(yùn)行復(fù)雜的遠(yuǎn)程shell命令

ssh host -l user $(<cmd.txt)

更具移植性的版本:

ssh host -l user “`cat cmd.txt`”

14、通過(guò)SSH將MySQL數(shù)據(jù)庫(kù)復(fù)制到新服務(wù)器

mysqldump –add-drop-table –extended-insert –force –log-error=error.log -uUSER -pPASS OLD_DB_NAME | ssh -C user@newhost “mysql -uUSER -pPASS NEW_DB_NAME”

通過(guò)壓縮的SSH隧道Dump一個(gè)MySQL數(shù)據(jù)庫(kù),將其作為輸入傳遞給mysql命令,我認(rèn)為這是遷移數(shù)據(jù)庫(kù)到新服務(wù)器最快最好的方法。

15、刪除文本文件中的一行,修復(fù)“SSH主機(jī)密鑰更改”的警告

sed -i 8d ~/.ssh/known_hosts

16、從一臺(tái)沒(méi)有SSH-COPY-ID命令的主機(jī)將你的SSH公鑰復(fù)制到服務(wù)器

cat ~/.ssh/id_rsa.pub | ssh user@machine “mkdir ~/.ssh; cat >> ~/.ssh/authorized_keys”

如果你使用Mac OS X或其它沒(méi)有ssh-copy-id命令的*nix變種,這個(gè)命令可以將你的公鑰復(fù)制到遠(yuǎn)程主機(jī),因此你照樣可以實(shí)現(xiàn)無(wú)密碼SSH登錄。

17、實(shí)時(shí)SSH網(wǎng)絡(luò)吞吐量測(cè)試

yes | pv | ssh $host “cat > /dev/null”

通過(guò)SSH連接到主機(jī),顯示實(shí)時(shí)的傳輸速度,將所有傳輸數(shù)據(jù)指向/dev/null,需要先安裝pv。

如果是Debian:

apt-get install pv

如果是Fedora:

yum install pv

(可能需要啟用額外的軟件倉(cāng)庫(kù))。

18、如果建立一個(gè)可以重新連接的遠(yuǎn)程GNU screen

ssh -t user@some.domain.com /usr/bin/screen –xRR

人 們總是喜歡在一個(gè)文本終端中打開(kāi)許多shell,如果會(huì)話突然中斷,或你按下了“Ctrl-a d”,遠(yuǎn)程主機(jī)上的shell不會(huì)受到絲毫影響,你可以重新連接,其它有用的screen命令有“Ctrl-a c”(打開(kāi)新的shell)和“Ctrl-a a”(在shell之間來(lái)回切換),請(qǐng)?jiān)L問(wèn)http://aperiodic.net/screen/quick_reference閱讀更多關(guān)于 screen命令的快速參考。

19、繼續(xù)SCP大文件

rsync –partial –progress –rsh=ssh $file_source $user@$host:$destination_file

它可以恢復(fù)失敗的rsync命令,當(dāng)你通過(guò)VPN傳輸大文件,如備份的數(shù)據(jù)庫(kù)時(shí)這個(gè)命令非常有用,需要在兩邊的主機(jī)上安裝rsync。

rsync –partial –progress –rsh=ssh $file_source $user@$host:$destination_file local -> remote

rsync –partial –progress –rsh=ssh $user@$host:$remote_file $destination_file remote -> local

20、通過(guò)SSH W/ WIRESHARK分析流量

ssh root@server.com ‘tshark -f “port !22″ -w -' | wireshark -k -i –

使 用tshark捕捉遠(yuǎn)程主機(jī)上的網(wǎng)絡(luò)通信,通過(guò)SSH連接發(fā)送原始pcap數(shù)據(jù),并在wireshark中顯示,按下Ctrl+C將停止捕捉,但也會(huì)關(guān)閉 wireshark窗口,可以傳遞一個(gè)“-c #”參數(shù)給tshark,讓它只捕捉“#”指定的數(shù)據(jù)包類型,或通過(guò)命名管道重定向數(shù)據(jù),而不是直接通過(guò)SSH傳輸給wireshark,我建議你過(guò)濾數(shù) 據(jù)包,以節(jié)約帶寬,tshark可以使用tcpdump替代:

ssh root@example.com tcpdump -w – ‘port !22′ | wireshark -k -i –

21、保持SSH會(huì)話永久打開(kāi)

autossh -M50000 -t server.example.com ‘screen -raAd mysession’

打開(kāi)一個(gè)SSH會(huì)話后,讓其保持永久打開(kāi),對(duì)于使用筆記本電腦的用戶,如果需要在Wi-Fi熱點(diǎn)之間切換,可以保證切換后不會(huì)丟失連接。

22、更穩(wěn)定,更快,更強(qiáng)的SSH客戶端

ssh -4 -C -c blowfish-cbc

強(qiáng)制使用IPv4,壓縮數(shù)據(jù)流,使用Blowfish加密。

23、使用cstream控制帶寬

tar -cj /backup | cstream -t 777k | ssh host ‘tar -xj -C /backup’

使用bzip壓縮文件夾,然后以777k bit/s速率向遠(yuǎn)程主機(jī)傳輸。Cstream還有更多的功能,請(qǐng)?jiān)L問(wèn)http://www.cons.org/cracauer/cstream.html#usage了解詳情,例如:

echo w00t, i’m 733+ | cstream -b1 -t2

24、一步將SSH公鑰傳輸?shù)搅硪慌_(tái)機(jī)器

ssh-keygen; ssh-copy-id user@host; ssh user@host

這 個(gè)命令組合允許你無(wú)密碼SSH登錄,注意,如果在本地機(jī)器的~/.ssh目錄下已經(jīng)有一個(gè)SSH密鑰對(duì),ssh-keygen命令生成的新密鑰可能會(huì)覆蓋 它們,ssh-copy-id將密鑰復(fù)制到遠(yuǎn)程主機(jī),并追加到遠(yuǎn)程賬號(hào)的~/.ssh/authorized_keys文件中,使用SSH連接時(shí),如果你 沒(méi)有使用密鑰口令,調(diào)用ssh user@host后不久就會(huì)顯示遠(yuǎn)程shell。

25、將標(biāo)準(zhǔn)輸入(stdin)復(fù)制到你的X11緩沖區(qū)

ssh user@host cat /path/to/some/file | xclip

posted @ 2012-12-17 18:17 小果子 閱讀(317) | 評(píng)論 (0)編輯 收藏
今天弄了下mysql的幾個(gè)安全設(shè)置: 只允許本地登錄,允許ssh通過(guò)遠(yuǎn)程登錄

1.my.cnf
#skip-networking
bind-address = 127.0.0.1

此項(xiàng)設(shè)置允許 tcp/ip 訪問(wèn),但是只有127.0.0.1 有可以訪問(wèn),如果把skip-networking 開(kāi)啟。則只能通過(guò)sock連接。
順便提下,

mysql -h localhost -u eric -p saker

mysql -h 127.0.0.1 -u eric -p saker

 

這兩個(gè)命令在skip-networking 開(kāi)啟的時(shí)候localhost能正常登錄mysql,但是127.0.0.1不能。具體原因如下:


大多數(shù)程序?qū)⒅鳈C(jī)名localhost和IP地址127.0.0.1 視作“本地服務(wù)器”的同義詞。

 

但在UNIX系統(tǒng)中,MySQL 有所不同:
出現(xiàn)localhost時(shí),MySQL會(huì)嘗試使用一個(gè)Unix domain socket 文件來(lái)連接本地服務(wù)器。

要強(qiáng)制使用TCP/IP連接到本地服務(wù)器,那就使用IP地址 127.0.0.1 而不是主機(jī)名localhost。
可以通過(guò)指定 --protocol=tcp 選項(xiàng)來(lái)強(qiáng)制使用TCP/IP進(jìn)行連接

TCP/IP 連接的默認(rèn)端口號(hào)是 3306.

2.mysql 設(shè)置好了,只允許本地登錄。但是允許通過(guò)ssh遠(yuǎn)程登錄
原理:無(wú)論是windows還是 linux,第一步就是本地與mysql服務(wù)器建立一個(gè)ssl tunnel,
利用ssh命令在本機(jī)開(kāi)個(gè)33xx的端口,這個(gè)端口為隧道的入口端口,出口就是數(shù)據(jù)庫(kù)的3306(如果默認(rèn)端口沒(méi)被修改的話),
linux如下:
ssh -NCPf root@localaddress -L 3388:mysqlserver:3306

參數(shù)解釋

-C    使用壓縮功能,是可選的,加快速度。 
-P    用一個(gè)非特權(quán)端口進(jìn)行出去的連接。 
-f    一旦SSH完成認(rèn)證并建立port forwarding,則轉(zhuǎn)入后臺(tái)運(yùn)行。 
-N    不執(zhí)行遠(yuǎn)程命令。該參數(shù)在只打開(kāi)轉(zhuǎn)發(fā)端口時(shí)很有用(V2版本SSH支持)


1)如果是windows 下用navicat for mysql 之類的數(shù)據(jù)庫(kù)管理軟件,比較簡(jiǎn)單,
在"常規(guī)"選項(xiàng)卡填寫主機(jī)名為localhost或127.0.0.1,遠(yuǎn)程數(shù)據(jù)庫(kù)的賬號(hào)和密碼
"SSH"選項(xiàng)卡填寫遠(yuǎn)程服務(wù)器的主機(jī)名和ssh端口號(hào),及登錄的用戶和密碼,測(cè)試連接是否成功
2)windows 暫時(shí)沒(méi)找出類似
ssh -NCPf root@localaddress -L 3388:mysqlserver:3306
命令安靜模式下建立ssh tunnel。 我用了putty試了下。連接可以成功。呆后續(xù)研究

3.mysql 主從備份使用ssh tunnel,下面摘自別人文章,待驗(yàn)證
1). 備份初始數(shù)據(jù)。
關(guān)閉所有相關(guān)的數(shù)據(jù)更新操作程序,或者對(duì)要備份的數(shù)據(jù)庫(kù)加鎖,避免更新,然后用 tar 備份到從服務(wù)器上。或者可以用mysqlhotcopy。
2). 需要在主服務(wù)器上,配置日志功能
這需要重啟服務(wù),使其啟用日志功能。配置文件 my.cnf 可以放在 mysql 的安裝目錄中。
[mysqld] 
server-id=1
log-bin=mydb-bin
binlog-do-db=mydb
重啟服務(wù)后,可以在數(shù)據(jù)目錄下,看見(jiàn)該數(shù)據(jù)庫(kù)的日志文件,并且可以通過(guò) "show master status",查看到主服務(wù)器的狀態(tài)。
3). 設(shè)置備用用戶
mysql>GRANT REPLICATION SLAVE ON *.* TO backup@'localhost' IDENTIFIED BY 'backup';
這里之所以用本地連接,是因?yàn)楹竺娌捎?ssh 隧道連接 mysql
4). 設(shè)置從服務(wù)器
[mysqld]
server-id=2
master-host=127.0.0.1
master-port=3307
master-user=backup
master-password=backup
master-connect-retry=10
report-host=127.0.0.1
5). 遠(yuǎn)程連接隧道
ssh -f -N -4 -L 3307:127.0.0.1:3306 mysqlm@remotemysql  
6). 啟動(dòng)從服務(wù)器
可以通過(guò) "show processlist",查看備份情況。并且可以查看mysql的錯(cuò)誤日志,了解是否連接正常,同步備份功能是否工作正常。
4.因?yàn)槭褂脃ii框架在寫一個(gè)項(xiàng)目,所以遠(yuǎn)程mysql禁止直接登錄后,yii的配置文件也要相應(yīng)修改,linux下比較簡(jiǎn)單,可參看以下
http://www.yiiframework.com/forum/index.php/topic/30678-mysql-through-ssh-tunnel/
windows待續(xù)......
posted @ 2012-12-17 18:14 小果子 閱讀(11556) | 評(píng)論 (0)編輯 收藏

Amoeba for MySQL 位于Client、Database Server(s)之間,具有負(fù)載均衡、高可用性、sql過(guò)濾、可承受高并發(fā)、讀寫分離、Query Route(解析sql query語(yǔ)句,并且根據(jù)條件與預(yù)先設(shè)定的規(guī)則,請(qǐng)求到指定的目標(biāo)數(shù)據(jù)庫(kù)。可并發(fā)請(qǐng)求多臺(tái)數(shù)據(jù)庫(kù)合并結(jié)果)、對(duì)客戶端透明,能降低數(shù)據(jù)切分帶來(lái)的復(fù)雜多數(shù)據(jù)庫(kù)結(jié)構(gòu)、數(shù)據(jù)切分規(guī)則給應(yīng)用帶來(lái)的影響。適用mysql 4.1或者以上版本(mysql 協(xié)議版本:10)暫時(shí)不支持事務(wù)、DDL語(yǔ)句目前只會(huì)分配給默認(rèn)的數(shù)據(jù)庫(kù)執(zhí)行,運(yùn)行環(huán)境至少需要運(yùn)行 mysql 4.1以上服務(wù), Java 1.5或以上版本。
Amoeba與mysql proxy存在一些區(qū)別。在mysql proxy上面如果想要讀寫分離并且讀集群、寫集群機(jī)器比較多情況下,用mysql proxy 需要自己寫一個(gè)LUA腳本,目前mysql proxy沒(méi)有現(xiàn)成的比較好的lua腳本。amoeba只需要進(jìn)行相關(guān)的配置就可以滿足需求。


一、Mysql Master/Slave 結(jié)構(gòu)之下的讀寫分離:
Master: serverM (主庫(kù),接收寫操作)
slaves:serverA、serverB、serverC(3個(gè)輔庫(kù),只讀操作)

amoeba提供讀寫分離pool相關(guān)配置,可配置serverA、serverB、serverC形成一個(gè)虛擬的virtualSlave,該配置提供LB,failover/failbackup功能.
 
<dbServer name="virtualSlave" virtual="true"> 
    <poolConfig> 
        <className>com.meidusa.amoeba.server.MultipleServerPool</className> 
        <!-- 負(fù)載均衡參數(shù) 1=ROUNDROBIN , 2=WEIGHTBASED --> 
        <property name="loadbalance">1</property> 
                  
        <!-- 參與該pool負(fù)載均衡的poolName列表以逗號(hào)分割 --> 
        <property name="poolNames">serverA,serverB,serverC</property> 
    </poolConfig> 
</dbServer> 


<dbServer name="virtualSlave" virtual="true">
 <poolConfig>
  <className>com.meidusa.amoeba.server.MultipleServerPool</className>
  <!-- 負(fù)載均衡參數(shù) 1=ROUNDROBIN , 2=WEIGHTBASED -->
  <property name="loadbalance">1</property>
    
  <!-- 參與該pool負(fù)載均衡的poolName列表以逗號(hào)分割 -->
  <property name="poolNames">serverA,serverB,serverC</property>
 </poolConfig>
</dbServer>

 

如果不啟用數(shù)據(jù)切分功能,那么只需要配置QueryRouter屬性
wirtePool=serverM
readPool=virtualSlave

<queryRouter> 
    <className>com.meidusa.amoeba.mysql.parser.MysqlQueryRouter</className> 
    <property name="LRUMapSize">1500</property> 
    <property name="defaultPool">serverM</property> 
 
    <property name="writePool">serverM</property> 
    <property name="readPool">virtualSlave</property> 
 
    <property name="needParse">true</property> 
</queryRouter> 

 <queryRouter>
  <className>com.meidusa.amoeba.mysql.parser.MysqlQueryRouter</className>
  <property name="LRUMapSize">1500</property>
  <property name="defaultPool">serverM</property>

  <property name="writePool">serverM</property>
  <property name="readPool">virtualSlave</property>

  <property name="needParse">true</property>
 </queryRouter>


client發(fā)送過(guò)來(lái)的update/insert/delete語(yǔ)句被發(fā)送到wirtePool,將select語(yǔ)句發(fā)送到readPool機(jī)器執(zhí)行。

 

二、數(shù)據(jù)切分方面:
這方面amoeba顯然也很容易,舉個(gè)數(shù)據(jù)切分例子:

select * from user_event where user_id='test' and  gmt_create between Sysdate() -1 and Sysdate()

如果根據(jù)gmt_create 時(shí)間進(jìn)行數(shù)據(jù)切分,比如6個(gè)月進(jìn)行切分一次,amoeba提供利用類似sql表達(dá)式進(jìn)行數(shù)據(jù)切分:

規(guī)則1:GMT_CREATE > to_date('2008-01-01','yyyy-mm-dd') and GMT_CREATE < to_date('2008-05-31','yyyy-mm-dd')

規(guī)則1對(duì)應(yīng)服務(wù)器1

規(guī)則2:GMT_CREATE > to_date('2008-06-01','yyyy-mm-dd') and GMT_CREATE < to_date('2008-12-31','yyyy-mm-dd')

規(guī)則2對(duì)應(yīng)服務(wù)器2
上面的sql的條件 gmt_create 與規(guī)則里面的的gmt_create 進(jìn)行交集判斷,如果存在交集則表示符合規(guī)則,則會(huì)將sql轉(zhuǎn)移到 規(guī)則1 的相應(yīng)的服務(wù)器上面執(zhí)行。

利用amoeba寫出這種類似規(guī)則很容易,但是要想做到數(shù)據(jù)切分以后可線性擴(kuò)容,那么這樣的規(guī)則需要自己根據(jù)業(yè)務(wù)實(shí)際情況進(jìn)行設(shè)置。amoeba可同時(shí)將 sql并發(fā)分發(fā)到多臺(tái)服務(wù)器、然后將結(jié)果合并再反饋給客戶端,而且amoeba內(nèi)部采用無(wú)阻塞模式,工作線程是不會(huì)等待的,并發(fā)請(qǐng)求多臺(tái) database server情況下,客戶端等待的時(shí)間基本上面是性能最差的那臺(tái)database server+amoeba內(nèi)部解析協(xié)議時(shí)間。


中文文檔地址: http://amoeba.sourceforge.net/amoeba.pdf
amoeba 未來(lái)發(fā)展方向: http://amoeba.sourceforge.net/amoeba-big-picture.pdf

文件下載: http://www.sourceforge.net/projects/amoeba
amoeba 開(kāi)發(fā)者博客: http://amoeba.meidusa.com

轉(zhuǎn)自:
http://blog.sina.com.cn/s/blog_499740cb0100g45w.html
posted @ 2012-12-13 17:14 小果子 閱讀(532) | 評(píng)論 (0)編輯 收藏
http://wenku.baidu.com/view/195a16eae009581b6bd9eb1b.html
http://blog.chinaunix.net/uid-20344928-id-3195698.html
http://www.issacy.com/archives/770.html
http://www.cnblogs.com/linuxer/archive/2012/03/07/2441224.html
http://zhidao.baidu.com/question/266486719.html
http://blog.163.com/fxd_3/blog/static/59261582201211032530668/
http://storage.chinaunix.net/stor/raid/2008/05/28/1117871.shtml
http://www.ibmsos.cn/a/IBMfuwuqijishuzhuanti/IBMfuwuqiyingjian_ruanjian/2011/0720/127.html
http://qijianghao.blog.51cto.com/3258446/787961
http://www.jb51.net/article/30494.htm
posted @ 2012-12-13 17:13 小果子 閱讀(192) | 評(píng)論 (0)編輯 收藏
more:
http://www.yiiframework.com/doc/guide/1.1/zh_cn/topics.console

PHP提供的cli模式可以進(jìn)行一些簡(jiǎn)單的shell程序開(kāi)發(fā),Yii框架也提供了cli程序開(kāi)發(fā)的解決方案。

在Yii項(xiàng)目的protected目錄下,存在yiic和yii.bat兩個(gè)文件,它們分別是類unix系統(tǒng)和windows系統(tǒng)下執(zhí)行Yii項(xiàng)目的命令行程序的入口,例如:

1
$ yiic command action --param=value

或者

1
 $ php yiic sitemap test --type=value

具體使用哪種寫法,取決于入口程序是否有執(zhí)行權(quán)限,例如,在linux系統(tǒng)下,如果執(zhí)行命令:

1
chmod +x yiic

給予了yiic執(zhí)行權(quán)限,就可以用第一種方式來(lái)執(zhí)行php命令行程序,否則需要使用第二種方式。

執(zhí)行Yii的命令行程序的命令有四部分組成:
命令行入口程序yiic
要執(zhí)行的命令名稱,類似Yii框架web程序的controller
要執(zhí)行的動(dòng)作名稱,類似Yii框架web程序controller的action
提供給程序的外部參數(shù),以兩個(gè)短橫線“–”開(kāi)頭,參數(shù)沒(méi)有順序

要建立一個(gè)命令行程序,需要繼承一個(gè)CConsoleCommand的子類:


class SitemapCommand extends CConsoleCommand
{
    public function actionTest($type, $limit=5) { ... }
}

保存到protected/commands/SitemapCommand.php文件。

在命令行下執(zhí)行:

1
$ php yiic sitemap test --type=value

SitemapCommand類的 actionTest 方法就會(huì)被執(zhí)行,并獲得值為value的$type參數(shù)。

可以在protected/config/console.php文件中進(jìn)行命令行模式下相關(guān)參數(shù)的配置,例如數(shù)據(jù)庫(kù)連接信息等,配置方法和Yii的web模式一樣。

posted @ 2012-12-12 14:41 小果子 閱讀(5551) | 評(píng)論 (0)編輯 收藏
僅列出標(biāo)題
共58頁(yè): First 7 8 9 10 11 12 13 14 15 Last 
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产在线国偷精品产拍免费yy| 欧美风情在线观看| 亚洲人成高清| 久久视频一区| 亚洲性色视频| 99xxxx成人网| 亚洲激情网站| 在线成人激情黄色| 国产永久精品大片wwwapp| 国产精品久久久久久久7电影 | 亚洲一区日韩在线| 亚洲日本一区二区| 在线观看亚洲视频啊啊啊啊| 国产伦精品一区二区三区高清| 欧美日本国产一区| 欧美freesex8一10精品| 久久婷婷国产综合尤物精品| 欧美亚洲视频在线看网址| 亚洲伊人观看| 亚洲香蕉伊综合在人在线视看| 日韩视频三区| 亚洲精品日韩在线| 亚洲精品午夜| 亚洲国产精品t66y| 亚洲国产精品综合| 亚洲国产成人精品女人久久久| 欧美xxx成人| 欧美黄色日本| 亚洲高清久久网| 亚洲国产高清在线观看视频| 欧美激情一二三区| 欧美激情在线有限公司| 欧美刺激午夜性久久久久久久| 欧美ed2k| 欧美激情一区二区三区全黄| 亚洲二区视频| 亚洲精品视频在线观看免费| 亚洲精品专区| 亚洲视频第一页| 亚洲一区二区在线| 欧美在线免费| 久热精品在线视频| 欧美黄色网络| 欧美视频一区在线| 国产久一道中文一区| 国产一区二区三区不卡在线观看| 黄色欧美日韩| 亚洲激情网站免费观看| 日韩一区二区久久| 亚洲男女毛片无遮挡| 欧美专区一区二区三区| 美女黄色成人网| 亚洲国产精品久久人人爱蜜臀| 亚洲激情校园春色| 亚洲永久在线| 久久精品主播| 欧美精品 国产精品| 欧美性猛交xxxx乱大交蜜桃| 国产婷婷成人久久av免费高清| 狠狠色综合播放一区二区| 亚洲人成网站999久久久综合| 宅男精品视频| 久久精品免视看| 亚洲国产欧美另类丝袜| 亚洲一区三区视频在线观看| 久久se精品一区二区| 欧美v国产在线一区二区三区| 欧美视频一区二区三区…| 国产婷婷色一区二区三区| 亚洲人成毛片在线播放女女| 亚洲免费在线播放| 欧美第十八页| 亚洲一区免费观看| 麻豆精品视频| 国产乱理伦片在线观看夜一区 | 亚洲日本va午夜在线电影| 一区二区三区日韩在线观看| 久久精品国产精品亚洲精品| 欧美精品久久久久久| 国产日韩一区在线| 99v久久综合狠狠综合久久| 欧美怡红院视频| 亚洲区免费影片| 欧美一区二区视频网站| 欧美日韩国产在线看| 国产在线精品二区| 亚洲图片欧美午夜| 欧美成人亚洲成人日韩成人| 亚洲夜间福利| 欧美精品一区二区在线观看| 国产私拍一区| 亚洲一区二区网站| 亚洲国产精品久久久久秋霞影院 | 影音先锋日韩有码| 亚洲欧美国产毛片在线| 欧美激情欧美激情在线五月| 欧美一区二区日韩一区二区| 欧美日韩精品久久| 亚洲欧洲综合| 免费亚洲婷婷| 欧美影院成人| 国产精品蜜臀在线观看| 夜夜嗨av色综合久久久综合网| 久久综合狠狠综合久久综合88| 亚洲调教视频在线观看| 欧美日韩国产不卡| 91久久精品国产91久久性色tv| 久久久久网址| 亚洲欧美日韩国产成人| 国产精品v欧美精品v日本精品动漫| 亚洲国产欧美另类丝袜| 蜜桃久久精品乱码一区二区| 欧美有码视频| 国产亚洲一本大道中文在线| 午夜欧美精品久久久久久久| 日韩午夜剧场| 欧美日韩在线视频一区| 99综合在线| 亚洲精品免费网站| 欧美精品一区二区三区蜜桃| 亚洲精品一二三| 亚洲观看高清完整版在线观看| 久久婷婷国产麻豆91天堂| 尤物yw午夜国产精品视频| 另类欧美日韩国产在线| 久久精品日产第一区二区三区 | 亚洲一区二区成人| av成人免费观看| 欧美特黄a级高清免费大片a级| 亚洲天堂男人| 亚洲深夜av| 国产日韩欧美黄色| 久久久久成人精品免费播放动漫| 欧美一区在线视频| 极品少妇一区二区三区| 麻豆成人av| 欧美电影在线观看| 99在线热播精品免费| av不卡在线| 国产欧美一区二区三区在线老狼 | 国产女主播视频一区二区| 欧美在线视频一区二区| 欧美制服丝袜| 亚洲黄一区二区| 亚洲剧情一区二区| 国产精品萝li| 久久视频在线看| 欧美成人黑人xx视频免费观看| avtt综合网| 亚洲欧美日韩在线播放| 精品动漫3d一区二区三区免费| 欧美成人亚洲| 欧美新色视频| 久久久亚洲国产美女国产盗摄| 久久青草久久| 在线综合+亚洲+欧美中文字幕| 亚洲欧美久久久| 在线观看视频一区二区欧美日韩| 亚洲国产综合91精品麻豆| 欧美日韩中文在线观看| 久久成人综合视频| 欧美xx视频| 先锋影院在线亚洲| 久久亚洲精品中文字幕冲田杏梨| 亚洲开发第一视频在线播放| 亚洲一品av免费观看| 尤物网精品视频| 一本久久知道综合久久| 狠狠久久五月精品中文字幕| 亚洲经典三级| 国产欧美视频一区二区| 亚洲国产天堂网精品网站| 国产精品中文字幕欧美| 欧美二区在线| 国产精品系列在线| 亚洲大片av| 国产一区二区精品久久99| 最新高清无码专区| 国内视频精品| 一区二区三区欧美在线| 亚洲国产cao| 亚洲欧美亚洲| 一区二区三区成人| 久久艳片www.17c.com| 午夜久久黄色| 欧美乱妇高清无乱码| 玖玖在线精品| 国产精品香蕉在线观看| 亚洲日本成人| 亚洲高清资源综合久久精品| 亚洲女同同性videoxma| 正在播放欧美视频| 男女激情视频一区| 久久久久久久网站| 国产精品久久久久永久免费观看| 亚洲成色www8888| 很黄很黄激情成人| 亚洲欧美美女| 亚洲欧美成人一区二区三区| 欧美激情精品久久久久久免费印度 |