<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆-153  評(píng)論-235  文章-19  trackbacks-0
      2008年6月22日
    如鼠標(biāo)移到 class 為 box 的 div 標(biāo)簽中背景變色

    .vbox div:hover{background: #ddd;}

    據(jù)說 IE6.0、Firefox2.0、Opera 9.23都不支持

    posted @ 2010-02-24 22:10 流浪汗 閱讀(1987) | 評(píng)論 (0)編輯 收藏
    想改 a  的默認(rèn)方式,比如:鏈接不要下劃線,鼠標(biāo)移到上面時(shí)有劃線。

    css 如
    a:hover {text-decoration: underline;}
    a:link 
    {text-decoration: none;}
    a:visited 
    {text-decoration: none;}

    是沒有達(dá)到鼠標(biāo)稱到上面有劃線。

    必須改為:
    a:link {text-decoration: none;}
    a:visited 
    {text-decoration: none;}
    a:hover 
    {text-decoration: underline;}

    a:hover 放到最后。
    posted @ 2010-02-24 22:04 流浪汗 閱讀(1010) | 評(píng)論 (3)編輯 收藏
    一、介紹Nginx是俄羅斯人編寫的十分輕量級(jí)的HTTP服務(wù)器,Nginx,它的發(fā)音為“engine X”, 是一個(gè)高性能的HTTP和反向代理服務(wù)器,同時(shí)也是一個(gè)IMAP/POP3/SMTP 代理服務(wù)器.
    二、Location語法語法:location [=|~|~*|^~] /uri/ { … }
    注:
    1、~   為區(qū)分大小寫匹配
    2、~* 為不區(qū)分大小寫匹配
    3、!~和!~*分別為區(qū)分大小寫不匹配及不區(qū)分大小寫
    不匹配
    示例一:
    location  / {
    }
    匹配任何查詢,因?yàn)樗姓?qǐng)求都以 / 開頭。但是正則表達(dá)式規(guī)則將被優(yōu)先和查詢匹配。
    示例二:
    location =/ {}
    僅僅匹配/

    示例三:
    location ~* \.(gif|jpg|jpeg)$ {
    rewrite \.(gif|jpg)$ /logo.png;

    注:不區(qū)分大小寫匹配任何以gif,jpg,jpeg結(jié)尾的文件

    三、ReWrite語法
    last - 基本上都用這個(gè)Flag。
    break - 中止Rewirte,不在繼續(xù)匹配
    redirect - 返回臨時(shí)重定向的HTTP狀態(tài)302
    permanent - 返回永久重定向的HTTP狀態(tài)301

    1、下面是可以用來判斷的表達(dá)式:
    -f和!-f用來判斷是否存在文件
    -d和!-d用來判斷是否存在目錄
    -e和!-e用來判斷是否存在文件或目錄
    -x和!-x用來判斷文件是否可執(zhí)行
    2、下面是可以用作判斷的全局變量
    例:http://localhost:88/test1/test2/test.php
    $host:localhost
    $server_port:88
    $request_uri:
    http://localhost:88/test1/test2/test.php
    $document_uri:/test1/test2/test.php
    $document_root:D:\nginx/html
    $request_filename:D:\nginx/html/test1/test2/test.php

    四、Redirect語法
        server {
        listen 80;
        server_name start.igrow.cn;
        index index.html index.php;
        root html;
        if ($http_host !~ "^star\.igrow\.cn$&quot {
             rewrite ^(.*)
    http://star.igrow.cn$1 redirect;
        }
        }

    五、防盜鏈location ~* \.(gif|jpg|swf)$ {
      valid_referers none blocked start.igrow.cn sta.igrow.cn;
      if ($invalid_referer) {
      rewrite ^/
    http://$host/logo.png;
      }
    }

    六、根據(jù)文件類型設(shè)置過期時(shí)間
    location ~* \.(js|css|jpg|jpeg|gif|png|swf)$ {
    if (-f $request_filename) {
       expires    1h;
       break;
    }
    }

    七、禁止訪問某個(gè)目錄
    location ~* \.(txt|doc)${
       
      root /data/www/wwwroot/linuxtone/test;
       
    deny all;
    }

    轉(zhuǎn):http://www.phpchina.com/html/70/t-162870.html,http://idev.yo2.cn/go/19761.html
    posted @ 2010-02-03 10:25 流浪汗 閱讀(12028) | 評(píng)論 (0)編輯 收藏
    top命令是Linux下常用的性能分析工具,能夠?qū)崟r(shí)顯示系統(tǒng)中各個(gè)進(jìn)程的資源占用狀況,類似于Windows的任務(wù)管理器。下面詳細(xì)介紹它的使用方法。

       
     top - 01:06:48 up  1:22,  1 user,  load average: 0.06, 0.60, 0.48
    Tasks:  29 total,   1 running,  28 sleeping,   0 stopped,   0 zombie
    Cpu(s):  0.3% us,  1.0% sy,  0.0% ni, 98.7% id,  0.0% wa,  0.0% hi,  0.0% si
    Mem:    191272k total,   173656k used,    17616k free,    22052k buffers
    Swap:   192772k total,        0k used,   192772k free,   123988k cached

       PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND
      1379 root      16   0  7976 2456 1980 S  0.7  1.3   0:11.03 sshd
    14704 root      16   0  2128  980  796 R  0.7  0.5   0:02.72 top
         1 root      16   0  1992  632  544 S  0.0  0.3   0:00.90 init
         2 root      34  19     0    0    0 S  0.0  0.0   0:00.00 ksoftirqd/0
         3 root      RT   0     0    0    0 S  0.0  0.0   0:00.00 watchdog/0

        統(tǒng)計(jì)信息區(qū)
        前五行是系統(tǒng)整體的統(tǒng)計(jì)信息。第一行是任務(wù)隊(duì)列信息,同 uptime 命令的執(zhí)行結(jié)果。其內(nèi)容如下:

        01:06:48 當(dāng)前時(shí)間
        up 1:22 系統(tǒng)運(yùn)行時(shí)間,格式為時(shí):分
        1 user 當(dāng)前登錄用戶數(shù)
        load average: 0.06, 0.60, 0.48 系統(tǒng)負(fù)載,即任務(wù)隊(duì)列的平均長(zhǎng)度。
        三個(gè)數(shù)值分別為 1分鐘、5分鐘、15分鐘前到現(xiàn)在的平均值。

        第二、三行為進(jìn)程和CPU的信息。當(dāng)有多個(gè)CPU時(shí),這些內(nèi)容可能會(huì)超過兩行。內(nèi)容如下:

        Tasks: 29 total 進(jìn)程總數(shù)
        1 running 正在運(yùn)行的進(jìn)程數(shù)
        28 sleeping 睡眠的進(jìn)程數(shù)
        0 stopped 停止的進(jìn)程數(shù)
        0 zombie 僵尸進(jìn)程數(shù)
        Cpu(s): 0.3% us 用戶空間占用CPU百分比
        1.0% sy 內(nèi)核空間占用CPU百分比
        0.0% ni 用戶進(jìn)程空間內(nèi)改變過優(yōu)先級(jí)的進(jìn)程占用CPU百分比
        98.7% id 空閑CPU百分比
        0.0% wa 等待輸入輸出的CPU時(shí)間百分比
        0.0% hi
        0.0% si

        最后兩行為內(nèi)存信息。內(nèi)容如下:

        Mem: 191272k total 物理內(nèi)存總量
        173656k used 使用的物理內(nèi)存總量
        17616k free 空閑內(nèi)存總量
        22052k buffers 用作內(nèi)核緩存的內(nèi)存量
        Swap: 192772k total 交換區(qū)總量
        0k used 使用的交換區(qū)總量
        192772k free 空閑交換區(qū)總量
        123988k cached 緩沖的交換區(qū)總量。
        內(nèi)存中的內(nèi)容被換出到交換區(qū),而后又被換入到內(nèi)存,但使用過的交換區(qū)尚未被覆蓋,
        該數(shù)值即為這些內(nèi)容已存在于內(nèi)存中的交換區(qū)的大小。
        相應(yīng)的內(nèi)存再次被換出時(shí)可不必再對(duì)交換區(qū)寫入。

    進(jìn)程信息區(qū)
        統(tǒng)計(jì)信息區(qū)域的下方顯示了各個(gè)進(jìn)程的詳細(xì)信息。首先來認(rèn)識(shí)一下各列的含義。

        序號(hào) 列名 含義
        a PID 進(jìn)程id
        b PPID 父進(jìn)程id
        c RUSER Real user name
        d UID 進(jìn)程所有者的用戶id
        e USER 進(jìn)程所有者的用戶名
        f GROUP 進(jìn)程所有者的組名
        g TTY 啟動(dòng)進(jìn)程的終端名。不是從終端啟動(dòng)的進(jìn)程則顯示為 ?
        h PR 優(yōu)先級(jí)
        i NI nice值。負(fù)值表示高優(yōu)先級(jí),正值表示低優(yōu)先級(jí)
        j P 最后使用的CPU,僅在多CPU環(huán)境下有意義
        k %CPU 上次更新到現(xiàn)在的CPU時(shí)間占用百分比
        l TIME 進(jìn)程使用的CPU時(shí)間總計(jì),單位秒
        m TIME+ 進(jìn)程使用的CPU時(shí)間總計(jì),單位1/100秒
        n %MEM 進(jìn)程使用的物理內(nèi)存百分比
        o VIRT 進(jìn)程使用的虛擬內(nèi)存總量,單位kb。VIRT=SWAP+RES
        p SWAP 進(jìn)程使用的虛擬內(nèi)存中,被換出的大小,單位kb。
        q RES 進(jìn)程使用的、未被換出的物理內(nèi)存大小,單位kb。RES=CODE+DATA
        r CODE 可執(zhí)行代碼占用的物理內(nèi)存大小,單位kb
        s DATA 可執(zhí)行代碼以外的部分(數(shù)據(jù)段+棧)占用的物理內(nèi)存大小,單位kb
        t SHR 共享內(nèi)存大小,單位kb
        u nFLT 頁面錯(cuò)誤次數(shù)
        v nDRT 最后一次寫入到現(xiàn)在,被修改過的頁面數(shù)。
        w S 進(jìn)程狀態(tài)。
        D=不可中斷的睡眠狀態(tài)
        R=運(yùn)行
        S=睡眠
        T=跟蹤/停止
        Z=僵尸進(jìn)程
        x COMMAND 命令名/命令行
        y WCHAN 若該進(jìn)程在睡眠,則顯示睡眠中的系統(tǒng)函數(shù)名
        z Flags 任務(wù)標(biāo)志,參考 sched.h

        默認(rèn)情況下僅顯示比較重要的 PID、USER、PR、NI、VIRT、RES、SHR、S、%CPU、%MEM、TIME+、COMMAND 列。可以通過下面的快捷鍵來更改顯示內(nèi)容。

        更改顯示內(nèi)容
        通過 f 鍵可以選擇顯示的內(nèi)容。按 f 鍵之后會(huì)顯示列的列表,按 a-z 即可顯示或隱藏對(duì)應(yīng)的列,最后按回車鍵確定。

        按 o 鍵可以改變列的顯示順序。按小寫的 a-z 可以將相應(yīng)的列向右移動(dòng),而大寫的 A-Z 可以將相應(yīng)的列向左移動(dòng)。最后按回車鍵確定。

        按大寫的 F 或 O 鍵,然后按 a-z 可以將進(jìn)程按照相應(yīng)的列進(jìn)行排序。而大寫的 R 鍵可以將當(dāng)前的排序倒轉(zhuǎn)。

     命令使用

        1. 工具(命令)名稱
        top
        2.工具(命令)作用
        顯示系統(tǒng)當(dāng)前的進(jìn)程和其他狀況; top是一個(gè)動(dòng)態(tài)顯示過程,即可以通過用戶按鍵來不斷刷新當(dāng)前狀態(tài).如果在前臺(tái)執(zhí)行該命令,它將獨(dú)占前臺(tái),直到用戶終止該程序?yàn)橹? 比較準(zhǔn)確的說,top命令提供了實(shí)時(shí)的對(duì)系統(tǒng)處理器的狀態(tài)監(jiān)視.它將顯示系統(tǒng)中CPU最“敏感”的任務(wù)列表.該命令可以按CPU使用.內(nèi)存使用和執(zhí)行時(shí)間對(duì)任務(wù)進(jìn)行排序;而且該命令的很多特性都可以通過交互式命令或者在個(gè)人定制文件中進(jìn)行設(shè)定.
        3.環(huán)境設(shè)置
        在Linux下使用。
        4.使用方法
        4.1使用格式
        top [-] [d] [p] [q] [c] [C] [S] [s]  [n]
        4.2參數(shù)說明
         d 指定每?jī)纱纹聊恍畔⑺⑿轮g的時(shí)間間隔。當(dāng)然用戶可以使用s交互命令來改變之。
         p 通過指定監(jiān)控進(jìn)程ID來僅僅監(jiān)控某個(gè)進(jìn)程的狀態(tài)。
         q該選項(xiàng)將使top沒有任何延遲的進(jìn)行刷新。如果調(diào)用程序有超級(jí)用戶權(quán)限,那么top將以盡可能高的優(yōu)先級(jí)運(yùn)行。
         S 指定累計(jì)模式
         s 使top命令在安全模式中運(yùn)行。這將去除交互命令所帶來的潛在危險(xiǎn)。
         i  使top不顯示任何閑置或者僵死進(jìn)程。
         c  顯示整個(gè)命令行而不只是顯示命令名
        4.3其他
           下面介紹在top命令執(zhí)行過程中可以使用的一些交互命令。從使用角度來看,熟練的掌握這些命令比掌握選項(xiàng)還重要一些。這些命令都是單字母的,如果在命令行選項(xiàng)中使用了s選項(xiàng),則可能其中一些命令會(huì)被屏蔽掉。
          Ctrl+L 擦除并且重寫屏幕。
          h或者? 顯示幫助畫面,給出一些簡(jiǎn)短的命令總結(jié)說明。
          k 終止一個(gè)進(jìn)程。系統(tǒng)將提示用戶輸入需要終止的進(jìn)程PID,以及需要發(fā)送給該進(jìn)程什么樣的信號(hào)。一般的終止進(jìn)程可以使用15信號(hào);如果不能正常結(jié)束那就使用信號(hào)9強(qiáng)制結(jié)束該進(jìn)程。默認(rèn)值是信號(hào)15。在安全模式中此命令被屏蔽。
          i 忽略閑置和僵死進(jìn)程。這是一個(gè)開關(guān)式命令。
          q 退出程序。
          r 重新安排一個(gè)進(jìn)程的優(yōu)先級(jí)別。系統(tǒng)提示用戶輸入需要改變的進(jìn)程PID以及需要設(shè)置的進(jìn)程優(yōu)先級(jí)值。輸入一個(gè)正值將使優(yōu)先級(jí)降低,反之則可以使該進(jìn)程擁有更高的優(yōu)先權(quán)。默認(rèn)值是10。
          S 切換到累計(jì)模式。
          s 改變兩次刷新之間的延遲時(shí)間。系統(tǒng)將提示用戶輸入新的時(shí)間,單位為s。如果有小數(shù),就換算成m s。輸入0值則系統(tǒng)將不斷刷新,默認(rèn)值是5 s。需要注意的是如果設(shè)置太小的時(shí)間,很可能會(huì)引起不斷刷新,從而根本來不及看清顯示的情況,而且系統(tǒng)負(fù)載也會(huì)大大增加。
          f或者F 從當(dāng)前顯示中添加或者刪除項(xiàng)目。
          o或者O 改變顯示項(xiàng)目的順序。
          l 切換顯示平均負(fù)載和啟動(dòng)時(shí)間信息。
          m 切換顯示內(nèi)存信息。
          t 切換顯示進(jìn)程和CPU狀態(tài)信息。
          c 切換顯示命令名稱和完整命令行。
          M 根據(jù)駐留內(nèi)存大小進(jìn)行排序。
          P 根據(jù)CPU使用百分比大小進(jìn)行排序。
          T 根據(jù)時(shí)間/累計(jì)時(shí)間進(jìn)行排序。
            W 將當(dāng)前設(shè)置寫入~/.toprc文件中。這是寫top配置文件的推薦方法。

    posted @ 2010-01-08 11:08 流浪汗 閱讀(764) | 評(píng)論 (0)編輯 收藏

    想發(fā)布新版的 mmseg4j 到現(xiàn)在已經(jīng)有二個(gè)多月了。主要是因?yàn)檫@段時(shí)間忙其它事情了。現(xiàn) Lucene 2.9 發(fā)布了,solr 1.4 也應(yīng)該會(huì)比較快就要發(fā)布了。對(duì) mmseg4j 兼容新版的 lucene/solr 也是個(gè)任務(wù)。

    現(xiàn) mmseg4j 發(fā)布新版 1.8,可以下載:mmseg4j-1.8.zip 包括了源碼與詞庫(kù),還有創(chuàng)建文件。下面說下此版的主要變更:

    new:

    1、有檢測(cè)詞典變更的接口,外部程序可以使用 wordsFileIsChange() 和 reload() 來完成檢測(cè)與加載的工作. (內(nèi)部不實(shí)現(xiàn)自動(dòng)檢測(cè)與加載,留給外部程序去做。)

    2、添加 MMseg4jHandler 類,可以在solr中用url的方式來控制加載檢測(cè)詞庫(kù)。

    3、增加 CutLetterDigitFilter過慮器,切分“字母和數(shù)”混在一起的過慮器。比如:mb991ch 切為 "mb 991 ch"。

    changes:

    1、默認(rèn)在 classpath 中加載 data 目錄(詞庫(kù)目錄),找不到再找 user.dir/data 目錄。但是優(yōu)先 mmseg.dic.path 系統(tǒng)屬性指定的。

    2、新詞庫(kù),去除 sogou 高頻無詞性的詞,合并 rmmseg 提供的詞(是 mmseg4j 1.0 使用的詞庫(kù)),共計(jì)(14W 多詞)。

    3、數(shù)字或英文開頭的數(shù)字或英文不獨(dú)立分出。如 MB991CH/A 分為 mb991ch a,cq40-519tx 分為 CQ40 519TX

    4、內(nèi)置支持小寫,不需要 LowerCaseFilter 了。MMSegAnalyzer 去除了小寫過慮。

    5、支持 solr 1.3/1.4、lucene 2.3/2.4/2.9

    6、嘗試加載 jar 里的 words.dic,并構(gòu)建含有 words.dic 的 jar(mmseg4j-*-with-dic.jar)。

    bugs:

    1、Dictionary 添加 finalize 方法。修正 tomcat reload 時(shí) OOM 的 bug: http://code.google.com/p/mmseg4j/issues/detail?id=4

    2、MMSegTokenizer 在 lucene 2.4 編譯的 在 lucene 2.9 中會(huì)報(bào) java.lang.NoSuchFieldError: input。bug: http://code.google.com/p/mmseg4j/issues/detail?id=5

    詳情:http://blog.chenlb.com/2009/10/chinese-segment-mmseg4j-1_8-release.html

    posted @ 2009-10-19 09:28 流浪汗 閱讀(3454) | 評(píng)論 (1)編輯 收藏
    中文分詞 mmseg4j 1.7.2 版發(fā)布,其實(shí)兩天前就發(fā)布了,只是沒有寫博客而已。與引版本發(fā)布的還有 1.6.2,兩者基本一樣,只是詞庫(kù)的數(shù)據(jù)結(jié)構(gòu)不同,1.7的是鍵樹,1.6的是數(shù)組與二分查找。 mmseg4j 1.7.2 版的主要更新:
    • 修復(fù)由 1.7-beta 升級(jí)到 1.7 版的 bug:添加 lowerCaseFilter 后的一個(gè) bug: NullPointerException。
    • 核發(fā)程序與 lucene 和 solr 擴(kuò)展分開打包, 同時(shí)給出低版本的 lucene 擴(kuò)展(lucene 1.9 到 2.2; lucene 2.3)
    如何從源碼編譯:下載源碼:mmseg4j-1.7.2-srcmmseg4j-1.6.2-src。解壓到如:e:/mmseg4j-1.7.2-src。然后到這個(gè)目錄,運(yùn)行:

     




    上面編譯是在 solr 1.3 和 lucene 2.4 環(huán)境下的。如果您要在 低版本的 lucene 中使用,到 e:/mmseg4j-1.7.2-src/contrib/lucene_1_9 或 e:/mmseg4j-1.7.2-src/contrib/lucene_2_3 運(yùn)行:

     

    說明:到 contrib 下的子項(xiàng)目中編譯的話,先要編譯 mmseg4j,contrib/lucene_1_9 可以支持到 2.2。

    如果有任何疑問、建議,歡迎到論壇 http://groups.google.com/group/mmseg4j/topics?hl=zh_CN 討論。或與我聯(lián)系 chenlb2008#gmail.com。

    還要感謝網(wǎng)友“苦澀可樂”提示 NullPointerException 的bug。

    官方博客:mmseg4j,項(xiàng)目:google code mmseg4j
    posted @ 2009-04-27 20:00 流浪汗 閱讀(2927) | 評(píng)論 (0)編輯 收藏
    很久沒有在此博客寫東西了。但一個(gè)多月了,原因是我已經(jīng)有自己的博客空間了,此博客很少更新,不過如果寫得好文就轉(zhuǎn)載到此博客。

    posted @ 2008-10-25 11:54 流浪汗 閱讀(689) | 評(píng)論 (0)編輯 收藏
    一直找代碼高亮顯示,在wp上可以有coolcode但,覺得美中不足的是服務(wù)器解析,每請(qǐng)求一次做一次。今天偶然看到 Unmi的博客,他的代碼好漂亮,看源碼,知道shCore,把他的拿過來試用下。 java 代碼

    java 代碼

    groovy 代碼

     

    posted @ 2008-09-05 00:26 流浪汗 閱讀(1353) | 評(píng)論 (2)編輯 收藏
    .tgz 解壓:
    tar zxvf myfile.tgz
    posted @ 2008-09-03 13:33 流浪汗 閱讀(46254) | 評(píng)論 (3)編輯 收藏
    solr分發(fā)問題。
    用rsync同步目錄里出現(xiàn):rsync:link_stat "snapshot.20080820124136/." (in solr) failed: No such file or directory (2)

    上一編配置得沒什么問題:http://m.tkk7.com/chenlb/archive/2008/07/04/212398.html 。現(xiàn)竟然出錯(cuò),郁悶。

    網(wǎng)上找了下, 說明路徑有空格。http://bbs.chinaunix.net/viewthread.php?tid=1003058

    二樓的回復(fù):

    帶空格的文件/目錄名不知道害死了多少人。

    `rsync -av --progress $dir1 $dir2`;

    `rsync -av --progress "$dir1" "$dir2"`;
    代替。

    其實(shí) `` 雖然用著方便,
    但不適合內(nèi)插變量。
    有變量作為參數(shù)的情況下,建議用 system。

    此是解決那樓主的問題,可以本來就沒有空格的問題,沒解決到我的問題。仔細(xì)思索。

    機(jī)子里有幾個(gè)rsync服務(wù),我部署的時(shí)候是復(fù)制相關(guān)的配置,rsync服務(wù)端口沒改,子機(jī)同步這個(gè)服務(wù)的時(shí)候(子機(jī)同步端口與rsync一致,是錯(cuò)的,重復(fù)的),然后做同步的時(shí)候出現(xiàn)上面的問題。改了其它端口后就可以。

    總的來講,還是自己對(duì)linux了解不多。
    posted @ 2008-09-02 16:14 流浪汗 閱讀(6530) | 評(píng)論 (0)編輯 收藏
    用unzip

    unzip myfile.zip
    posted @ 2008-09-02 16:03 流浪汗 閱讀(829) | 評(píng)論 (0)編輯 收藏
    上一篇記錄了本機(jī)模式我虛擬分布模式。http://m.tkk7.com/chenlb/archive/2008/08/11/221311.html

    現(xiàn)我在虛擬機(jī)里開三臺(tái)機(jī)子,分別命名為:master(172.16.249.210),slave-1(172.16.249.211),slave-2(172.16.249.212)。

    master可以無密碼登錄到slave機(jī)。
    每臺(tái)機(jī)子都匹配ip對(duì)應(yīng)名。
    127.0.0.1       localhost       localhost

    172.16.249.210  master
    172.16.249.211  slave-1
    172.16.249.212  slave-2

    修改conf/masters文件和conf/slaves文件。
    conf/masters文件:
    master

    conf/slaves文件:
    slave-1
    slave-
    2

    格式化后可以啟動(dòng)了:
    [chenlb@master hadoop-0.17.1]$ bin/start-all.sh 


    參考資料:
    http://hadoop.apache.org/core/docs/r0.17.1/quickstart.html
    http://hadoop.apache.org/core/docs/r0.17.1/cluster_setup.html
    posted @ 2008-08-11 15:45 流浪汗 閱讀(804) | 評(píng)論 (0)編輯 收藏

     

    Required Software

    1. JavaTM 1.5.x
    2. ssh與sshd

    如果沒有安裝請(qǐng)自行安裝。我以CentOS 4.6為例。

    下載hadoop,http://apache.mirror.phpchina.com/hadoop/core/ 我下載的是0.17.1版本。

    解壓hadoop-0.17.1.tar.gz,然后conf/hadoop-env.sh 設(shè)置JAVA_HOME ,我是可JAVA_HOME 去注釋,值自己的路徑。如:

    export JAVA_HOME=/usr/java/jdk1.6.0_06

    如果不設(shè)置啟動(dòng)后用不了。

    先從簡(jiǎn)單開始。

    1、Local (Standalone) Mode ,叫單機(jī)模式。

    [chenlb@master hadoop-0.17.1]$ bin/hadoop jar hadoop-0.17.1-examples.jar grep conf output 'dfs[a-z.]+'

     

    [chenlb@master hadoop-0.17.1]$ cat output/*


    如果,正常可以看到內(nèi)容。像這樣。

    3       dfs.
    3       dfs.class
    2       dfs.period
    2       dfs.replication
    ...    ...

    2、Pseudo-Distributed Mode,虛擬分布模式。
    vi conf/hadoop-site.xml
    <configuration>
    <property>
            
    <name>fs.default.name</name>
            
    <value>hdfs://master:9000/</value>
    </property>
    <property>
            
    <name>mapred.job.tracker</name>
            
    <value>hdfs://master:9001/</value>
    </property>
    <property>
            
    <name>dfs.replication</name>
            
    <value>1</value>
    </property>
    <property>
            
    <name>hadoop.tmp.dir</name>
            
    <value>/home/chenlb/hadoop-0.17.1/tmp/</value>
    </property>
    </configuration>

    在/etc/hosts里添加本機(jī)ip對(duì)應(yīng)master,例如我的:172.16.249.210    master
    保證可以無密碼登錄。請(qǐng)看那一篇文章:http://m.tkk7.com/chenlb/archive/2008/07/03/212293.html

    用ssh localhost試一下是否免密碼登錄。

    格式化分布式文件系統(tǒng):
    [chenlb@master hadoop-0.17.1]$ bin/hadoop namenode -format

    啟動(dòng)Hadoop:
    [chenlb@master hadoop-0.17.1]$ bin/start-all.sh 

    默認(rèn)可以在${HADOOP_HOME}/logs里看到日志。

    可以用web看瀏覽NameNode和JobTracker
  • NameNode - http://localhost:50070/
  • JobTracker - http://localhost:50030/


    把文件放到分布式文件系統(tǒng)里:

    [chenlb@master hadoop-0.17.1]$ bin/hadoop dfs -put conf input

    此時(shí)已經(jīng)在分布文件系統(tǒng)里建立了input文件夾。而conf是本地的文件夾。

    執(zhí)行示例:
    [chenlb@master hadoop-0.17.1]$ bin/hadoop jar hadoop-*-examples.jar grep input output 'dfs[a-z.]+'

    這里input和output都是分布式文件系統(tǒng)的的文件夾,而且output在分布式文件系統(tǒng)里不存在,否則報(bào)錯(cuò)(也可以先刪除它bin/badoop dfs -rmr output)。

    耐心等待。結(jié)束后可以查看。
    [chenlb@master hadoop-0.17.1]$ bin/hadoop dfs -get output output 
    [chenlb
    @master hadoop-0.17.1]$ cat output/* 

    也可以直接在分布式文件系統(tǒng)里查:
    [chenlb@master hadoop-0.17.1]$ bin/hadoop dfs -cat output/*

    成功運(yùn)行后可以關(guān)閉它了:
    [chenlb@master hadoop-0.17.1]$ bin/stop-all.sh

    我在第2階段,出了些問題:output已經(jīng)存在,要先刪除它(第二次運(yùn)行前,可以不用output)。

    下一篇講:Fully-Distributed Mode http://m.tkk7.com/chenlb/archive/2008/08/11/221314.html
  • posted @ 2008-08-11 15:28 流浪汗 閱讀(4962) | 評(píng)論 (2)編輯 收藏
    在linux下改了ip地址后,不能立即生效。以前是重啟機(jī)器,我覺得這樣很傻,后來知道網(wǎng)卡可以重啟。

    /etc/init.d/network restart
    posted @ 2008-08-11 09:34 流浪汗 閱讀(6078) | 評(píng)論 (1)編輯 收藏
    一直想了解分布搜索與索引。Lucene有MultiSearcher,solr1.2的只能有單個(gè)索引,現(xiàn)在1.3可以有Distributed Searching這玩意。可以從多個(gè)索引里搜索出并合并結(jié)果返回給你。這些索引不是replication的,是分割的。可以先%num方式索引在num臺(tái)機(jī)器上,然后用solr的shards參數(shù)。

    如:
    shards=localhost:8080/use-solr1.3,localhost:9080/use-solr1.3&q=chenlb

    測(cè)試后可以返回結(jié)果,但合并的時(shí)候發(fā)了點(diǎn)時(shí)間,我的機(jī)子上40-60ms,單個(gè)搜索基本是0ms

    測(cè)試數(shù)據(jù)是14W結(jié)果,分開索引到兩個(gè)tomcat里。看了后臺(tái),一個(gè)搜索有兩次請(qǐng)求,其中合并的那機(jī)子是三次請(qǐng)求。時(shí)間可能花在請(qǐng)求里,還有就是合并可能緩存不到。

    官方建議:如果單個(gè)solr足夠快的話沒有必要搞Distributed Searching,如果再高點(diǎn)要求可以index repliction。

    當(dāng)索引很大的時(shí)候可能Distributed Searching用的上場(chǎng), 個(gè)人之見。

    參考:http://wiki.apache.org/solr/DistributedSearch
    posted @ 2008-08-07 18:31 流浪汗 閱讀(1017) | 評(píng)論 (0)編輯 收藏
    html 與 xml的轉(zhuǎn)義符不同, xml就只有5個(gè):

    < &lt;
    > &gt;
    & &amp;
    " &quot;
    ' &apos;


    xml沒有&nbsp;
    posted @ 2008-08-06 12:40 流浪汗 閱讀(15431) | 評(píng)論 (2)編輯 收藏
    我比較喜歡免安裝版(非安裝版)的mysql,

    下載如: mysql-noinstall-5.0.45-win32.zip

    把它解壓到如: E:/mysql-5.0.45, 當(dāng)然可以任意位置。

    然后改my-medium.ini文件為my.ini,當(dāng)然也可以不改名,但要改內(nèi)容

    basedir="E:/mysql-5.0.45/"

    datadir
    ="E:/mysql-5.0.45/Data/"

    如果上面,最好加個(gè)字符集,在[mysqld]和[mysql]下面加
    default-character-set=utf8

    當(dāng)然可能是其它字符集, 如:gbk

    寫個(gè)mysql-startup.bat
    "E:\mysql-5.0.45\bin\mysqld" --defaults-file="E:\mysql-5.0.45\my.ini"

    雙擊mysql-startup.bat即可啟動(dòng)。

    用mysqladmin關(guān)閉mysql服務(wù):
    E:/mysql-5.0.45/bin/mysqladmin -u root shutdown


    ^_^
    posted @ 2008-08-03 16:22 流浪汗 閱讀(3094) | 評(píng)論 (1)編輯 收藏
        想讓Tomcat支持ssi,一般是shtml文件。配置比較簡(jiǎn)單。

    默認(rèn)tomcat不支持ssi。

    現(xiàn)以tomcat5.5.x為例。

    改conf/web.xml配置。

    有兩種方式:一是servlet,二是filter。

    servlet方式的:
    <!--
        <servlet>
            <servlet-name>ssi</servlet-name>
            <servlet-class>
              org.apache.catalina.ssi.SSIServlet
            </servlet-class>
            <init-param>
              <param-name>buffered</param-name>
              <param-value>1</param-value>
            </init-param>
            <init-param>
              <param-name>debug</param-name>
              <param-value>0</param-value>
            </init-param>
            <init-param>
              <param-name>expires</param-name>
              <param-value>666</param-value>
            </init-param>
            <init-param>
              <param-name>isVirtualWebappRelative</param-name>
              <param-value>0</param-value>
            </init-param>
            <load-on-startup>4</load-on-startup>
        </servlet>
    -->

    <!--
        <servlet-mapping>
            <servlet-name>ssi</servlet-name>
            <url-pattern>*.shtml</url-pattern>
        </servlet-mapping>
    -->

    找到上面的內(nèi)容,去掉注釋。

    filter方式:
    <!--
        <filter>
            <filter-name>ssi</filter-name>
            <filter-class>
              org.apache.catalina.ssi.SSIFilter
            </filter-class>
            <init-param>
              <param-name>contentType</param-name>
              <param-value>text/x-server-parsed-html(;.*)?</param-value>
            </init-param>
            <init-param>
              <param-name>debug</param-name>
              <param-value>0</param-value>
            </init-param>
            <init-param>
              <param-name>expires</param-name>
              <param-value>666</param-value>
            </init-param>
            <init-param>
              <param-name>isVirtualWebappRelative</param-name>
              <param-value>0</param-value>
            </init-param>
        </filter>
    -->

    <!--
        <filter-mapping>
            <filter-name>ssi</filter-name>
            <url-pattern>*.shtml</url-pattern>
        </filter-mapping>
    -->

    同樣是去掉上面的注釋。但是filter方式的還要加mime-mapping=text/x-server-parsed-html
    <!--
        <mime-mapping>
            <extension>shtml</extension>
            <mime-type>text/x-server-parsed-html</mime-type>
        </mime-mapping>
    -->

    去掉mime-mapping的shtml注釋。

    在test的web試下:
    index.shtml
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>ssi 示例</title>
    </head>

    <body>
    ssi area 
    <!--#include virtual="ssi.html" -->
    <p>

            footer 
    <!--#include virtual="footer.html" --><p>
            
            
    <p>
                
    <!--#config timefmt="%D" -->
            Me last modified 
    <!--#echo var="LAST_MODIFIED" -->

    </body>
    </html>

    footer.html
    <ul>
        
    <li>index</li>
        
    <li>about</li>
    </ul>

    ssi.html
    <p>this is ssi.html file</p><p>
    <p>中文</p>
    ssi.html file end
    <p/>


    現(xiàn)在可以,http://localhost:8080/test/index.shtml 有結(jié)果了。
    posted @ 2008-07-27 21:55 流浪汗 閱讀(1381) | 評(píng)論 (0)編輯 收藏
        有一個(gè)項(xiàng)目的代碼提交是用https協(xié)議的。一提交的時(shí)候出現(xiàn)如下錯(cuò)誤:

    svn: PROPFIND request failed on '/svn/trunk/xxx'
    svn: PROPFIND of '/svn/trunk/xxx': Could not create SSL connection through proxy server (https://.

        這下郁悶,看了下eclipse設(shè)置,又沒有設(shè)代理。google一下,看到一個(gè)郵件列表,有一個(gè)字眼“TSVN”。哦,快去看看TortoiseSVN。任意一個(gè)目錄右擊->TortoiseSVN->設(shè)置->網(wǎng)絡(luò),有學(xué)校時(shí)用的代理。去掉一試,好了沒錯(cuò)了。

        前端時(shí)間用Subclipse時(shí),一定要安裝TortoiseSVN才可保存密碼,現(xiàn)在又TortoiseSVN的設(shè)置Subclipse又有效。帶著探索心去看eclipse的設(shè)置。Team->svn那里有一個(gè)選項(xiàng):

    SVN接口:
    1.JavaHL(JNI)
    2.SVNkit(純Java)

    原來選的是JavaHL(JNI),現(xiàn)在明白了。改用SVNkit試一下,現(xiàn)在的subclipse不會(huì)理TortoiseSVN了。

    posted @ 2008-07-26 13:34 流浪汗 閱讀(3718) | 評(píng)論 (0)編輯 收藏
    有些windows操作系統(tǒng)被人"強(qiáng)奸"過的, 導(dǎo)致語言欄變灰色,無法顯示,在任務(wù)欄里不顯示.

    一般是ctfmon.exe問題. 看下C:\windows\system32\ctfmon.exe文件. 沒有就下載

    http://m.tkk7.com/Files/chenlb/ctfmon_xp.rar

    安裝它,

    然后在: 控制面板->區(qū)域和語言選項(xiàng)->語言->詳細(xì)信息->高級(jí)->去掉"關(guān)閉高級(jí)文字服務(wù)"

    即可.

    那一種(百度知道): http://zhidao.baidu.com/question/31477300.html

    看你是使用2003 還是XP系統(tǒng)

    要是XP系統(tǒng)的話了就設(shè)置兩個(gè)地方
    1.開始,運(yùn)行,msconfig,勾選ctfmon.exe

    控制面板--區(qū)域和語言選項(xiàng)--語言--詳細(xì)信息--高級(jí)--不要選“關(guān)閉高級(jí)文字服務(wù)”
    2.開始--控制面板--日期、時(shí)間、語言和區(qū)域設(shè)置--區(qū)域和語言選擇--語言--詳細(xì)信息--語言欄(選擇在桌面顯示語言欄 還有 選擇:在任務(wù)欄中顯示其他語言欄圖標(biāo))

    參考: http://www.nvyouwm.cn/html/jishuwendang/huanjingpeizhi/20080602/266_2.html
    posted @ 2008-07-12 13:26 流浪汗 閱讀(7579) | 評(píng)論 (9)編輯 收藏
    setTimeout(script,millisecond); 是從現(xiàn)在算起多少微秒后運(yùn)行該代碼(只運(yùn)行一次)

    setInterval(script,millisecond);  是每隔多少微秒運(yùn)行一次代碼

    示例:
    1.執(zhí)行一次
    <span id="time"></span> 秒
    <script type="text/javascript">
    var i = 1;
    var txt = document.getElementById("time");
    function addT(i) {
    txt.innerHTML
    =i;
    }
    setTimeout("addT(i++)",1000);
    </script>


    2.復(fù)制執(zhí)行
    <span id="time">3</span> 秒
    <script type="text/javascript">
    var i = 1;
    var txt = document.getElementById("time");
    function addT(i) {
    txt.innerHTML
    =i;
    }
    setInterval(
    "addT(i++)",1000); 
    </script>

    setTimeout也可以做成重復(fù)執(zhí)行
    <span id="time"></span> 秒
    <script type="text/javascript">
    var i = 1;
    var txt = document.getElementById("time");
    function addT(i) {
    txt.innerHTML
    =i;
    setTimeout(
    "addT(i++)",1000);
    }
    addT(i);
    </script>
    posted @ 2008-07-10 21:36 流浪汗 閱讀(1090) | 評(píng)論 (0)編輯 收藏

    linux下的很軟件都是 tar.gz后綴的,解壓久了不用就忙了,寫備忘。現(xiàn)我知的直接解壓方法有兩種

    1.gunzip與tar

    gunzip < *.tar.gz | tar -xvf -

    2.只用tar
    tar -zxvf *.tar.gz

    說明:
    z表示:通過gzip指令處理備份文件
    x表示:解壓
    v表示:輸出解壓過程信息
    f表示:指定備份文件
    posted @ 2008-07-08 11:14 流浪汗 閱讀(2536) | 評(píng)論 (0)編輯 收藏
    solr 1.3 還沒有正式發(fā)布,在這里記錄下從solr 1.2的主要改動(dòng):
    1. solrj     solr的java客戶端,可以嵌入搜索(不是http/xml交互)
    2. multi-core     多核心——1個(gè)web應(yīng)用可以用多種的搜索服務(wù),即可以多個(gè)schema.xml
    3. search components    搜索組件。
    4. distributed search    分布式搜索。

    api的變動(dòng):

    1. org.apache.util 包下的大部分類移到org.apache.common.util包下面。
    2. org.apache.solr.request包下面的很多類移到org.apache.solr.common.params包下面。
    3. org.apache.solr.request.StandardRequestHandler 類改為 org.apache.solr.handler.StandardRequestHandler,同時(shí)它改為org.apache.solr.handler.SearchHandler的子類
    4. org.apache.solr.request.DisMaxRequestHandler 類改為 org.apache.solr.handler.DisMaxRequestHandler,同時(shí)不推薦在 StandardRequestHandler 的初始參數(shù)用'defType=dismax' 。
    posted @ 2008-07-08 10:20 流浪汗 閱讀(463) | 評(píng)論 (0)編輯 收藏
        solr 分布式其實(shí)是分發(fā),這概念像Mysql的復(fù)制。所有的索引的改變都在主服務(wù)器里,所有的查詢都在從服務(wù)里。從服務(wù)器不斷地(定時(shí))從主服務(wù)器拉內(nèi)容,以保持?jǐn)?shù)據(jù)一致。

    先描述下我的環(huán)境:
    solr-master(192.168.1.181), solr-slave(192.168.1.155), jdke1.6.0_06, tomcat-5.5.26, solr-1.2 
    tomcat_home在 /home/chenlb/tomcat-5.5.26
    solr_home在 /home/chenlb/solr-home
    solr解壓后的目錄 /home/chenlb/solr-1.2.0
    最好兩機(jī)可以ssh無密碼交互,ssh無密碼登錄請(qǐng)看:http://m.tkk7.com/chenlb/archive/2008/07/03/212293.html

        solr的分發(fā)是用rsync的。
        快照與分發(fā)過程:

    1.snapshooter 命令在主服務(wù)器產(chǎn)生快照。一般在commit和optimize之后被solr調(diào)用。

    2.snappuller 命令在從服務(wù)器運(yùn)行,所做的事是從主服務(wù)器拉最新的快照。 用rsync的daemon模式來運(yùn)行可以獲得更好的性能與更底的CPU利用率。

    3.snapinstaller 命令在從服務(wù)器運(yùn)行,當(dāng)從服務(wù)器從主服務(wù)器拉完快照后才執(zhí)行。它會(huì)通知本地Solr服務(wù)器打開一個(gè)新的index reader,然后預(yù)熱這個(gè)新index reader的緩存,此時(shí)有請(qǐng)求,原來的index reader繼續(xù)為這此請(qǐng)求服務(wù)。一但預(yù)熱完成,Solr 啟用新的index reader,舊的被消亡。

        Solr 的Distribution(分發(fā)) 在Scripts文件里記錄。在solr_home/conf/scripts.conf文件里。

    我現(xiàn)在這樣配置:
    user=chenlb
    solr_hostname
    =localhost
    solr_port
    =8080
    rsyncd_port
    =18080
    data_dir
    =/home/chenlb/solr-home/data
    webapp_name
    =solr
    master_host
    =192.168.1.181
    master_data_dir
    =/home/chenlb/solr-home/data
    master_status_dir
    =/home/chenlb/solr-home/logs

    上面的配置兩機(jī)都一樣。

    1.安裝好solr后啟動(dòng)它們,怎樣在tomcat安裝solr請(qǐng)看:http://m.tkk7.com/chenlb/archive/2008/03/25/188459.html
    [chenlb@solr-master ~]$ ./tomcat-5.5.26/bin/startup.sh

    啟用且啟動(dòng)rsync
    [chenlb@solr-master ~]$ ./solr-home/bin/rsyncd-enable -u chenlb -v
    [chenlb@solr-master ~]$ ./solr-home/bin/rsyncd-start -u chenlb -v


    [chenlb@solr-slave ~]$ ./tomcat-5.5.26/bin/startup.sh

    2.solr-master
    先修改post.sh
    [chenlb@solr-master ~]$ cd solr-1.2.0/example/exampledocs/
    [chenlb@solr
    -master exampledocs]$ vi post.sh
    [chenlb@solr
    -master exampledocs]$
    #把http://localhost:8389/solr/update改下面的
    http://localhost:8080/solr/update

    提交數(shù)據(jù)
    [chenlb@solr-master exampledocs]$ ./post.sh *.xml

    產(chǎn)生快照
    [chenlb@solr-master ~]$ ./solr-home/bin/snapshooter -u chenlb -v

    說明:由于<listener event="postCommit" class="solr.RunExecutableListener">...</listener>沒有設(shè)置成功(出現(xiàn)java.io.IOException: Cannot run program "snapshooter" (in directory "solr/bin"): java.io.IOException: error=2, No such file or directory,現(xiàn)在還沒解決),可以只能手動(dòng)生成快照(當(dāng)然也可以cron)

    3.solr-slave
    啟用快照下拉
    [chenlb@solr-slave ~]$ ./solr-home/bin/snappuller-enable -u chenlb -v

    拉快照
    [chenlb@solr-slave ~]$ ./solr-home/bin/snappuller -u chenlb -v

    安裝
    [chenlb@solr-slave ~]$ ./solr-home/bin/snapinstaller -u chenlb -v


    現(xiàn)在可以在solr-slave里看結(jié)果了:
    http://192.168.1.155:8080/solr/select?q=solr
    http://192.168.1.181:8080/solr/select?q=solr

    看結(jié)果是否一樣。
    posted @ 2008-07-04 16:49 流浪汗 閱讀(3178) | 評(píng)論 (0)編輯 收藏

        由于svn服務(wù)器的調(diào)整,很多項(xiàng)目里的鏈接還是舊的服務(wù)器,又由于項(xiàng)目里有些東西還沒有提交,所不能刪除svn的元數(shù)據(jù),怎樣才能適應(yīng)svn的遷移呢?

        我的項(xiàng)目全在Eclipse下面,用subclipse客戶端,在subclipse找了好久沒找到此功能,最后在TortoiseSVN找,找到了右擊本地與svn相連的目錄-->"TortoiseSVN"-->"Reloate..."在to URL那改就行了。^_^
     
        subclipse遠(yuǎn)不如TortoiseSVN強(qiáng)大,且它還依賴TortoiseSVN——如果沒有TortoiseSVN,subclipse不能保存密碼。

    posted @ 2008-07-04 11:06 流浪汗 閱讀(1532) | 評(píng)論 (1)編輯 收藏
    ssh 無密碼登錄要使用公鑰與私鑰。linux下可以用用ssh-keygen生成公鑰/私鑰對(duì),下面我以CentOS為例。

    有機(jī)器A(192.168.1.155),B(192.168.1.181)。現(xiàn)想A通過ssh免密碼登錄到B。

    1.在A機(jī)下生成公鑰/私鑰對(duì)。
    [chenlb@A ~]$ ssh-keygen -t rsa -''

    -P表示密碼,-P '' 就表示空密碼,也可以不用-P參數(shù),這樣就要三車回車,用-P就一次回車。
    它在/home/chenlb下生成.ssh目錄,.ssh下有id_rsa和id_rsa.pub。

    2.把A機(jī)下的id_rsa.pub復(fù)制到B機(jī)下,在B機(jī)的.ssh/authorized_keys文件里,我用scp復(fù)制。
    [chenlb@A ~]$ scp .ssh/id_rsa.pub chenlb@192.168.1.181:/home/chenlb/id_rsa.pub 
    chenlb@
    192.168.1.181's password:
    id_rsa.pub                                    100%  223     0.2KB/s   00:00

    由于還沒有免密碼登錄的,所以要輸入密碼。

    3.B機(jī)把從A機(jī)復(fù)制的id_rsa.pub添加到.ssh/authorzied_keys (打錯(cuò)了,使用下面的代碼塊)文件里。
    [chenlb@B ~]$ cat id_rsa.pub >> .ssh/authorized_keys
    [chenlb@B 
    ~]$ chmod 600 .ssh/authorized_keys

    authorized_keys的權(quán)限要是600

    4.A機(jī)登錄B機(jī)。
    [chenlb@A ~]$ ssh 192.168.1.181
    The authenticity of host 
    '192.168.1.181 (192.168.1.181)' can't be established.
    RSA key fingerprint is 00:a6:a8:87:eb:c7:40:10:39:cc:a0:eb:50:d9:6a:5b.
    Are you sure you want to 
    continue connecting (yes/no)? yes
    Warning: Permanently added 
    '192.168.1.181' (RSA) to the list of known hosts.
    Last login: Thu Jul  
    3 09:53:18 2008 from chenlb
    [chenlb@B 
    ~]$

    第一次登錄是時(shí)要你輸入yes。

    現(xiàn)在A機(jī)可以無密碼登錄B機(jī)了。

    小結(jié):登錄的機(jī)子可有私鑰,被登錄的機(jī)子要有登錄機(jī)子的公鑰。這個(gè)公鑰/私鑰對(duì)一般在私鑰宿主機(jī)產(chǎn)生。上面是用rsa算法的公鑰/私鑰對(duì),當(dāng)然也可以用dsa(對(duì)應(yīng)的文件是id_dsa,id_dsa.pub)

    想讓A,B機(jī)無密碼互登錄,那B機(jī)以上面同樣的方式配置即可。

    參考:SSH-KeyGen 的用法 http://blog.163.com/chen98_2006@126/blog/static/158584272007101862513886/
    posted @ 2008-07-03 12:19 流浪汗 閱讀(13747) | 評(píng)論 (3)編輯 收藏
    我用CentOS為例。

    簡(jiǎn)介:
        cron來源于希臘單詞chronos(意為“時(shí)間”),是linux系統(tǒng)下一個(gè)自動(dòng)執(zhí)行指定任務(wù)的程序。例如,你想在每晚睡覺期間創(chuàng)建某些文件或文件夾的備份,就可以用cron來自動(dòng)執(zhí)行。

    CentOS的cron默認(rèn)是開機(jī)啟動(dòng)的,如果沒有開機(jī)啟動(dòng)可以用chkconfig
    [root@chenlb-pc ~]# chkconfig crond on

    查看crond是否開機(jī)啟動(dòng)
    [root@chenlb-pc ~]# chkconfig --list crond
    crond           0:關(guān)閉  1:關(guān)閉  2:啟用  3:啟用  4:啟用  5:啟用  6:關(guān)閉

    說明已經(jīng)是開機(jī)啟動(dòng)。

    cron是執(zhí)行crontab里的任務(wù),所以要把任務(wù)加到crontab里。

    1.查看當(dāng)前用戶的任務(wù)。
    [chenlb@chenlb-pc ~]$ crontab -l
    no crontab 
    for chenlb

    現(xiàn)在還沒有任務(wù),可以用crontab -e來編輯任務(wù)(可以直接輸入crontab是新建,然后回車,Ctrl+D保存,注意這樣會(huì)覆蓋以前的,不建議直接用crontab),然后再新的文件里輸入以下內(nèi)容。

    2.編輯任務(wù)
    [chenlb@chenlb-pc ~]$ crontab -e

    */1 * * * * echo `date` >> /home/chenlb/cron-log.txt

    上面的意思是指每一分鐘打印時(shí)間放到/home/chenlb/cron-log.txt文件里,過一分鐘后看是否有效,如下命令。
    [chenlb@chenlb-pc ~]$ tail /home/chenlb/cron-log.txt
    Wed Jul 
    2 15:43:01 CST 2008

    3.刪除任務(wù)
    [chenlb@chenlb-pc ~]$ crontab -r


    說明:如果是root除了有以上的功能,還有-u參數(shù)為用戶查看、編輯、刪除任務(wù),如用chenlb編輯任務(wù)。
    [root@chenlb-pc ~]# crontab -u chenlb -e

    解說下任務(wù)的語法:
        min hour day month week user command

    忽略用“*”,每多少的用“/多少”,多個(gè)的用“,”,到關(guān)系的用“-”

    ---------------------------------來自htmlor's blog的示例----------------------------------------------

    以下是cron語句中的字段與字段說明:

    字段 說明
    1 分鐘(0-59)
    2 小時(shí)(2-24)
    3 日期(1-31)
    4 月份(1-12;或英文縮寫Jan、Feb等)
    5 周幾(0-6,0為周日;或單詞縮寫Sun、Mon等)
    6 用戶名(執(zhí)行命令時(shí)以此用戶的身份)
    7 要執(zhí)行的命令(路徑)

    現(xiàn)在來看第一行:

    12 3 * * * root tar czf /usr/local/backups/daily/etc.tar.gz /etc >> /dev/null 2>&1

    這條語句將在每天的凌晨3點(diǎn)12分(03:12)運(yùn)行 tar czf /usr/local/backups/daily/etc.tar.gz /etc 命令。>> /dev/null 2>&1 表示把所有標(biāo)準(zhǔn)輸出發(fā)送到 /dev/null(linux的回收站),把標(biāo)準(zhǔn)錯(cuò)誤輸出(2)發(fā)送到和標(biāo)準(zhǔn)輸出(1)同樣的地方(即 /dev/null)。運(yùn)行這行命令將不會(huì)產(chǎn)生任何輸出。

    這條語句可以變得稍微復(fù)雜一點(diǎn):

    30 15 13 6 1 * root tar czf /usr/local/backups/daily/etc.tar.gz /etc >> /dev/null 2>&1

    它將在6月13日周一的15:30運(yùn)行 tar czf /usr/local/backups/daily/etc.tar.gz /etc 命令。

    以下語句可以達(dá)到同樣的效果:

    30 15 13 Jun Mon * root tar czf /usr/local/backups/daily/etc.tar.gz /etc >> /dev/null 2>&1

    如果你想以用戶joey的身份每小時(shí)的第15分鐘運(yùn)行某個(gè)程序,可以使用:

    15 * * * * joey /usr/bin/somecommand >> /dev/null 2>&1

    其中的星號(hào)(*)是通配符,表示cron將忽略這個(gè)字段。

    如果你想每?jī)尚r(shí)就運(yùn)行某個(gè)程序,可以在小時(shí)字段里使用 */2。它將會(huì)在2點(diǎn),4點(diǎn),6點(diǎn)……22點(diǎn),24點(diǎn)運(yùn)行。具體語句如下:

    0 */2 * * * joey /usr/bin/somecommand >> /dev/null 2>&1

    cron語句中還可以使用逗號(hào)(,)來指定多個(gè)時(shí)間。例如你想在每小時(shí)的15分和30分運(yùn)行某個(gè)程序,可以在分鐘字段使用 15,30

    15,30 * * * * joey /usr/bin/somecommand >> /dev/null 2>&1

    如果你想在每月的第一周(即1號(hào)到7號(hào))每天的指定時(shí)間運(yùn)行某個(gè)程序,可以在日期字段使用 1-7

    15,30 */2 1-7 * * joey /usr/bin/somecommand >> /dev/null 2>&1

    這條語句將在每月的第1-7日每?jī)尚r(shí)的15分和30分(02:15,02:30……22: 15,22:30等)運(yùn)行 /usr/bin/somecommand 命令。

    如果你想在每天的16:18執(zhí)行一個(gè)腳本集合,可以把所有要執(zhí)行的腳本放到一個(gè)目錄中(如 /home/username/cron),可以使用:

    18 16 * * * root run-parts /home/username/cron >> /dev/null 2>&1

    如果你想保存某個(gè)程序的輸出結(jié)果, 可以把 >> /dev/null 2>&1 替換為 >> /home/user/somecommand.log 2>&1



    參考:http://blog.htmlor.com/2006/07/25/cron_guide/
    posted @ 2008-07-02 16:23 流浪汗 閱讀(5400) | 評(píng)論 (0)編輯 收藏
     Solr 涉及的術(shù)語,簡(jiǎn)單介紹下:
    • Auto-warming(自動(dòng)預(yù)熱) 當(dāng)打開一個(gè)新的緩存時(shí),它把在舊緩存里命中較高的鍵/值添加到新的緩存里。
    • Constraint(限制) 限制對(duì)象集的方法。
    • Facet(層面) 對(duì)象集的一個(gè)方面或特定的一部分,這可以用來資源分類。
    • Filter(過慮器) 它由上下方?jīng)Q定,可能是:
      1. Constraint(限制)的那稱呼。
      2. 限制查詢結(jié)果的"fq"參數(shù)。
      3. 涉及特定的Lucene的"Filter"類。
    • Solr Home Dir(Solr主目錄) 又叫Solr Home Directory或Solr Home,它是Solr查找配置文件、數(shù)據(jù)、插件的主要目錄,默認(rèn)是./solr目錄,可以JNDI配置solr/home屬性,也可配置系統(tǒng)的solr.solr.home屬性。
    • Static warming(靜態(tài)預(yù)熱) 當(dāng)newSearcher 和 firstSearcher 的事件監(jiān)聽器強(qiáng)逼預(yù)熱事件時(shí),Solr會(huì)根據(jù)solrconfig.xml配置里的"static"查詢來填充緩存。

    來源:http://wiki.apache.org/solr/SolrTerminology

     

    說的不對(duì)的地方,希望指出,一起學(xué)習(xí)。

    posted @ 2008-06-27 13:29 流浪汗 閱讀(474) | 評(píng)論 (0)編輯 收藏

        兩字符串相似度計(jì)算方法有好多,現(xiàn)對(duì)基于編距的算法的相似度計(jì)算自己總結(jié)下。

     

        簡(jiǎn)單介紹下Levenshtein Distance(LD):LD 可能衡量?jī)勺址南嗨菩浴K鼈兊木嚯x就是一個(gè)字符串轉(zhuǎn)換成那一個(gè)字符串過程中的添加、刪除、修改數(shù)值。

        舉例:

    • 如果str1="test",str2="test",那么LD(str1,str2) = 0。沒有經(jīng)過轉(zhuǎn)換。
    • 如果str1="test",str2="tent",那么LD(str1,str2) = 1。str1的"s"轉(zhuǎn)換"n",轉(zhuǎn)換了一個(gè)字符,所以是1。

    如果它們的距離越大,說明它們?cè)绞遣煌?/p>

     

         Levenshtein distance最先是由俄國(guó)科學(xué)家Vladimir Levenshtein在1965年發(fā)明,用他的名字命名。不會(huì)拼讀,可以叫它edit distance(編輯距離)。

     

        Levenshtein distance可以用來:

    • Spell checking(拼寫檢查)
    • Speech recognition(語句識(shí)別)
    • DNA analysis(DNA分析)
    • Plagiarism detection(抄襲檢測(cè))

    LD用m*n的矩陣存儲(chǔ)距離值。算法大概過程:

    1. str1或str2的長(zhǎng)度為0返回另一個(gè)字符串的長(zhǎng)度。
    2. 初始化(n+1)*(m+1)的矩陣d,并讓第一行和列的值從0開始增長(zhǎng)。
    3. 掃描兩字符串(n*m級(jí)的),如果:str1[i] == str2[j],用temp記錄它,為0。否則temp記為1。然后在矩陣d[i][j]賦于d[i-1][j]+1 、d[i][j-1]+1、d[i-1][j-1]+temp三者的最小值。
    4. 掃描完后,返回矩陣的最后一個(gè)值即d[n][m]

    最后返回的是它們的距離。怎么根據(jù)這個(gè)距離求出相似度呢?因?yàn)樗鼈兊淖畲缶嚯x就是兩字符串長(zhǎng)度的最大值。對(duì)字符串不是很敏感。現(xiàn)我把相似度計(jì)算公式定為1-它們的距離/字符串長(zhǎng)度最大值。

     

        源碼:

    package com.chenlb.algorithm;

    /**
     * 編輯距離的兩字符串相似度
     * 
     * 
    @author chenlb 2008-6-24 下午06:41:55
     
    */
    public class Similarity {

        
    private int min(int one, int two, int three) {
            
    int min = one;
            
    if(two < min) {
                min 
    = two;
            }
            
    if(three < min) {
                min 
    = three;
            }
            
    return min;
        }
        
        
    public int ld(String str1, String str2) {
            
    int d[][];    //矩陣
            int n = str1.length();
            
    int m = str2.length();
            
    int i;    //遍歷str1的
            int j;    //遍歷str2的
            char ch1;    //str1的
            char ch2;    //str2的
            int temp;    //記錄相同字符,在某個(gè)矩陣位置值的增量,不是0就是1
            if(n == 0) {
                
    return m;
            }
            
    if(m == 0) {
                
    return n;
            }
            d 
    = new int[n+1][m+1];
            
    for(i=0; i<=n; i++) {    //初始化第一列
                d[i][0= i;
            }
            
    for(j=0; j<=m; j++) {    //初始化第一行
                d[0][j] = j;
            }
            
    for(i=1; i<=n; i++) {    //遍歷str1
                ch1 = str1.charAt(i-1);
                
    //去匹配str2
                for(j=1; j<=m; j++) {
                    ch2 
    = str2.charAt(j-1);
                    
    if(ch1 == ch2) {
                        temp 
    = 0;
                    } 
    else {
                        temp 
    = 1;
                    }
                    
    //左邊+1,上邊+1, 左上角+temp取最小
                    d[i][j] = min(d[i-1][j]+1, d[i][j-1]+1, d[i-1][j-1]+temp);
                }
            }
            
    return d[n][m];
        }
        
        
    public double sim(String str1, String str2) {
            
    int ld = ld(str1, str2);
            
    return 1 - (double) ld / Math.max(str1.length(), str2.length()); 
        }
        
        
    public static void main(String[] args) {
            Similarity s 
    = new Similarity();
            String str1 
    = "chenlb.blogjava.net";
            String str2 
    = "chenlb.javaeye.com";
            System.out.println(
    "ld="+s.ld(str1, str2));
            System.out.println(
    "sim="+s.sim(str1, str2));
        }
    }

    不知sim方法中的公式是合理,個(gè)人認(rèn)為差強(qiáng)人意思,^_^

     

    參考: http://www.merriampark.com/ld.htm

    posted @ 2008-06-25 10:08 流浪汗 閱讀(3844) | 評(píng)論 (2)編輯 收藏
        發(fā)現(xiàn)中國(guó)科學(xué)技術(shù)大學(xué)有快速的CentOS的鏡像。具體設(shè)置如下:
    1.以root用戶進(jìn)入CentOS系統(tǒng)。
    [root@chenlb ~]# cd /etc/yum.repos.d

    2.備份repo
    [root@chenlb yum.repos.d]# mv CentOS-Base.repo  CentOS-Base.repo.save

    3.從USTC下載新的repo
    [root@chenlb yum.repos.d]# wget http://centos.ustc.edu.cn/CentOS-Base.repo

    現(xiàn)在可以yum了。^_^

    鏈接:http://centos.ustc.edu.cn/
    posted @ 2008-06-24 23:45 流浪汗 閱讀(1529) | 評(píng)論 (2)編輯 收藏
        用String.substring方法,不小心會(huì)有越界異常。現(xiàn)實(shí)現(xiàn)一個(gè)沒拋出越界異常,越界就返回null,不過直接返回的再用其它方法,可能有Null異常。現(xiàn)還實(shí)現(xiàn)可以負(fù)index的,可能逆向的。
    package com.chenlb.util;   
      
    public class StringUtil {   
           
        
    /**  
         * start與end均可負(fù)數(shù)<br/>  
         * start < end正向取, start > end逆向取<br/>  
         * 示例:str="I am chenlb"<br/>  
         * StringUtil.substring(str, 0, 12) -> null<br/>  
         * StringUtil.substring(str, 12, 12) -> null<br/>  
         * StringUtil.substring(str, 12, 13) -> null<br/>  
         * StringUtil.substring(str, 4, 4) -> ""<br/>  
         * StringUtil.substring(str, 0, 4) -> "I am"<br/>  
         * StringUtil.substring(str, -4, -1) -> "enl"<br/>  
         * StringUtil.substring(str, -2, 4) -> "lbI am"<br/>  
         * StringUtil.substring(str, 4, 0) -> "ma I"<br/>  
         * StringUtil.substring(str, -1, -4) -> "lne"<br/>  
         * StringUtil.substring(str, 1, -4) -> "Iblne"<br/>  
         * StringUtil.substring(str, 0, -4) -> "blne"<br/>  
         * StringUtil.substring(str, -4, 0) -> "enlb"<br/>  
         * 
    @return 越界返回null, start==end返回空  
         * 
    @author chenlb 2008-6-18 下午12:39:51  
         
    */  
        
    public static String substring(String str, int start, int end) {   
            
    if(str == null) {   
                
    return null;   
            }   
            
    int len = str.length();   
            
    if(Math.abs(start) >= len) {   
                
    return null;   
            }   
            
    if(Math.abs(end) > len) {   
                
    return null;   
            }   
            StringBuilder sb 
    = new StringBuilder();   
            
    if(end > start) {    //正向   
                substring(sb, str, start, end);   
            } 
    else if(end == start) {   
                
    return "";   
            } 
    else {    //逆向 end < start   
                substring(sb, str, end, start);   
                sb.reverse();   
            }   
            
    return sb.toString();   
        }   
           
        
    private static void substring(StringBuilder sb, String str, int start, int end) {   
            
    int len = str.length();   
            
    if(start < 0) {   
                
    if(end < 0) {   
                    sb.append(str.substring(len
    +start, len+end));   
                } 
    else {   
                    sb.append(str.substring(len
    +start, len));   
                    sb.append(str.substring(
    0, end));   
                }   
            } 
    else {   
                sb.append(str.substring(start, end));   
            }   
        }   
    }  

    測(cè)試代碼:
    public void testSubstring() {   
            String str 
    = "I am chenlb";   
               
            assertEquals(
    null, StringUtil.substring(str, 012));   
            assertEquals(
    null, StringUtil.substring(str, 1212));   
            assertEquals(
    null, StringUtil.substring(str, 1213));   
               
            assertEquals(
    "", StringUtil.substring(str, 44));   
               
            assertEquals(
    "I am", StringUtil.substring(str, 04));   
            assertEquals(
    "am", StringUtil.substring(str, 24));   
            assertEquals(
    "I am chenlb", StringUtil.substring(str, 011));   
               
            assertEquals(
    "enl", StringUtil.substring(str, -4-1));   
            assertEquals(
    "lbI am", StringUtil.substring(str, -24));   
               
            assertEquals(
    "ma I", StringUtil.substring(str, 40));   
            assertEquals(
    "lne", StringUtil.substring(str, -1-4));   
            assertEquals(
    "Iblne", StringUtil.substring(str, 1-4));   
               
            assertEquals(
    "blne", StringUtil.substring(str, 0-4));   
            assertEquals(
    "enlb", StringUtil.substring(str, -40));   
    }  
    posted @ 2008-06-24 13:53 流浪汗 閱讀(559) | 評(píng)論 (0)編輯 收藏

    Windows網(wǎng)絡(luò)命令行程序 

     
    ipconfig /all 查看配置 
    ipconfig /renew 刷新配置 
    ipconfig 管理 DNS 和 DHCP 類別 ID
    Ping 測(cè)試連接
    Arp 解決硬件地址問題
    nbtstat 解決 NetBIOS 名稱問題
    netstat 顯示連接統(tǒng)計(jì)
    tracert 跟蹤網(wǎng)絡(luò)連接
    pathping 測(cè)試路由器

    posted @ 2008-06-24 13:51 流浪汗 閱讀(274) | 評(píng)論 (0)編輯 收藏

        今天運(yùn)行下程序,報(bào)錯(cuò)說“內(nèi)存不夠”。在Tomcat可以擴(kuò)大JVM的內(nèi)存棧呢?然后看那bin目錄下啟動(dòng)文件,找到catalina.bat文件的JAVA_OPTS(大概在103行,5.5.X),在再添加一個(gè)set JAVA_OPTS參數(shù)即可如:

    set JAVA_OPTS=%JAVA_OPTS% -Xms100m -Xmx512m 
    posted @ 2008-06-24 13:49 流浪汗 閱讀(375) | 評(píng)論 (0)編輯 收藏
        前段時(shí)間學(xué)習(xí)Linux命令,偶然發(fā)現(xiàn)curl命令很有用。這里簡(jiǎn)單介紹下。網(wǎng)絡(luò)上部分解析是:curl是一個(gè)利用URL語法在命令行方式下工作的文件傳輸工具。

       它可以取得有規(guī)律的url的內(nèi)容。比如:http://www.example.com/001.html 到 http://www.example.com/100.html ,它有一種表達(dá)式可以這些內(nèi)容下載下來,這功能絕對(duì)比迅雷強(qiáng),迅雷只支持一個(gè)變量,curl只你喜歡可任意多。它可繼點(diǎn)續(xù)傳,提交表單……

       來看下簡(jiǎn)單的使用:

    1.查看響應(yīng)的頭
    curl -I http://chenlb.javaeye.com 
    現(xiàn)在正如robbin說的可以看下X-Runtime: 0.47101

    2.在學(xué)校要代理才可以上javaeye.com。用-x設(shè)代理
    curl -x proxy.gdut.edu.cn:8080 -I http://chenlb.javaeye.com 

    3.把返回的內(nèi)容保存下來,用-o filename參數(shù)
    curl -o chenlb.html http://chenlb.javaeye.com  

    4.保存內(nèi)容時(shí)要filename很煩,用一個(gè)-O參數(shù)來指定用服務(wù)器的文件名,這個(gè)批量下載很有用。
    curl -O http://baike.baidu.com/view/[1-2].htm
    批量下載百科的1.htm 2.htm兩個(gè)頁面,這功能夠強(qiáng)。

    我常用的就是以上四個(gè)。

    5.很多要referer的,有-e參數(shù)可以設(shè)置
    curl -o me.html -e http://www.javaeye.com http://chenlb.javaeye.com  

    還有很多很多參數(shù),留給大家去發(fā)現(xiàn),比如:發(fā)送數(shù)據(jù),提交表單,設(shè)置用戶與密碼,用什么協(xié)議啊……
    posted @ 2008-06-24 13:47 流浪汗 閱讀(1513) | 評(píng)論 (0)編輯 收藏
          java命令引入jar時(shí)可以-cp參數(shù),但時(shí)-cp不能用通配符(多個(gè)jar時(shí)什么煩要一個(gè)個(gè)寫,不能*.jar),面通常的jar都在同一目錄,且多于1個(gè)。前些日子找到(發(fā)現(xiàn))-Djava.ext.dirs太好。

    如:

    java -Djava.ext.dirs=lib MyClass  
    posted @ 2008-06-22 23:58 流浪汗 閱讀(5109) | 評(píng)論 (0)編輯 收藏
    主站蜘蛛池模板: 成人毛片免费观看视频在线| 亚洲视频一区在线| 欧美a级在线现免费观看| 国产高潮流白浆喷水免费A片 | 亚洲欧洲精品一区二区三区| a级亚洲片精品久久久久久久 | www.亚洲精品| 成年性生交大片免费看| 最近免费中文字幕高清大全| 暖暖免费高清日本中文| 亚洲人成网站免费播放| 亚洲精品在线电影| 亚洲综合无码一区二区| 亚洲无人区午夜福利码高清完整版| 免费人妻无码不卡中文字幕18禁| 最近最新中文字幕完整版免费高清| 最新黄色免费网站| 国产亚洲精品欧洲在线观看| 亚洲私人无码综合久久网| 亚洲另类视频在线观看| 亚洲系列国产精品制服丝袜第| 国产亚洲精AA在线观看SEE| 久久精品国产亚洲Aⅴ蜜臀色欲| 免费少妇a级毛片人成网| 免费无码成人AV片在线在线播放| 无码日韩人妻av一区免费| 免费视频专区一国产盗摄| 1000部国产成人免费视频| 99久久免费中文字幕精品| 久久久久免费精品国产小说| 日本亚洲欧洲免费天堂午夜看片女人员 | 亚洲人成综合网站7777香蕉| 亚洲国产模特在线播放| 亚洲女人18毛片水真多| 亚洲另类春色校园小说| 亚洲人成网站看在线播放| 亚洲三级在线观看| 亚洲av最新在线观看网址| 免费播放美女一级毛片| 一级做a爰片久久毛片免费陪 | 美女黄色免费网站|