隨筆-153  評論-235  文章-19  trackbacks-0
            2008年8月3日
          如鼠標移到 class 為 box 的 div 標簽中背景變色

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

          據說 IE6.0、Firefox2.0、Opera 9.23都不支持

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

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

          是沒有達到鼠標稱到上面有劃線。

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

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

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

          注:不區分大小寫匹配任何以gif,jpg,jpeg結尾的文件

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

          1、下面是可以用來判斷的表達式:
          -f和!-f用來判斷是否存在文件
          -d和!-d用來判斷是否存在目錄
          -e和!-e用來判斷是否存在文件或目錄
          -x和!-x用來判斷文件是否可執行
          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;
            }
          }

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

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

          轉:http://www.phpchina.com/html/70/t-162870.html,http://idev.yo2.cn/go/19761.html
          posted @ 2010-02-03 10:25 流浪汗 閱讀(12025) | 評論 (0)編輯 收藏
          top命令是Linux下常用的性能分析工具,能夠實時顯示系統中各個進程的資源占用狀況,類似于Windows的任務管理器。下面詳細介紹它的使用方法。

             
           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

              統計信息區
              前五行是系統整體的統計信息。第一行是任務隊列信息,同 uptime 命令的執行結果。其內容如下:

              01:06:48 當前時間
              up 1:22 系統運行時間,格式為時:分
              1 user 當前登錄用戶數
              load average: 0.06, 0.60, 0.48 系統負載,即任務隊列的平均長度。
              三個數值分別為 1分鐘、5分鐘、15分鐘前到現在的平均值。

              第二、三行為進程和CPU的信息。當有多個CPU時,這些內容可能會超過兩行。內容如下:

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

              最后兩行為內存信息。內容如下:

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

          進程信息區
              統計信息區域的下方顯示了各個進程的詳細信息。首先來認識一下各列的含義。

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

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

              更改顯示內容
              通過 f 鍵可以選擇顯示的內容。按 f 鍵之后會顯示列的列表,按 a-z 即可顯示或隱藏對應的列,最后按回車鍵確定。

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

              按大寫的 F 或 O 鍵,然后按 a-z 可以將進程按照相應的列進行排序。而大寫的 R 鍵可以將當前的排序倒轉。

           命令使用

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

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

          想發布新版的 mmseg4j 到現在已經有二個多月了。主要是因為這段時間忙其它事情了。現 Lucene 2.9 發布了,solr 1.4 也應該會比較快就要發布了。對 mmseg4j 兼容新版的 lucene/solr 也是個任務。

          現 mmseg4j 發布新版 1.8,可以下載:mmseg4j-1.8.zip 包括了源碼與詞庫,還有創建文件。下面說下此版的主要變更:

          new:

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

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

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

          changes:

          1、默認在 classpath 中加載 data 目錄(詞庫目錄),找不到再找 user.dir/data 目錄。但是優先 mmseg.dic.path 系統屬性指定的。

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

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

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

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

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

          bugs:

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

          2、MMSegTokenizer 在 lucene 2.4 編譯的 在 lucene 2.9 中會報 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 流浪汗 閱讀(3452) | 評論 (1)編輯 收藏
          中文分詞 mmseg4j 1.7.2 版發布,其實兩天前就發布了,只是沒有寫博客而已。與引版本發布的還有 1.6.2,兩者基本一樣,只是詞庫的數據結構不同,1.7的是鍵樹,1.6的是數組與二分查找。 mmseg4j 1.7.2 版的主要更新:
          • 修復由 1.7-beta 升級到 1.7 版的 bug:添加 lowerCaseFilter 后的一個 bug: NullPointerException。
          • 核發程序與 lucene 和 solr 擴展分開打包, 同時給出低版本的 lucene 擴展(lucene 1.9 到 2.2; lucene 2.3)
          如何從源碼編譯:下載源碼:mmseg4j-1.7.2-srcmmseg4j-1.6.2-src。解壓到如:e:/mmseg4j-1.7.2-src。然后到這個目錄,運行:

           




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

           

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

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

          還要感謝網友“苦澀可樂”提示 NullPointerException 的bug。

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

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

          java 代碼

          groovy 代碼

           

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

          上一編配置得沒什么問題:http://www.aygfsteel.com/chenlb/archive/2008/07/04/212398.html 。現竟然出錯,郁悶。

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

          二樓的回復:

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

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

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

          其實 `` 雖然用著方便,
          但不適合內插變量。
          有變量作為參數的情況下,建議用 system。

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

          機子里有幾個rsync服務,我部署的時候是復制相關的配置,rsync服務端口沒改,子機同步這個服務的時候(子機同步端口與rsync一致,是錯的,重復的),然后做同步的時候出現上面的問題。改了其它端口后就可以。

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

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

          現我在虛擬機里開三臺機子,分別命名為:master(172.16.249.210),slave-1(172.16.249.211),slave-2(172.16.249.212)。

          master可以無密碼登錄到slave機。
          每臺機子都匹配ip對應名。
          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

          格式化后可以啟動了:
          [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 流浪汗 閱讀(802) | 評論 (0)編輯 收藏

           

          Required Software

          1. JavaTM 1.5.x
          2. ssh與sshd

          如果沒有安裝請自行安裝。我以CentOS 4.6為例。

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

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

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

          如果不設置啟動后用不了。

          先從簡單開始。

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

          [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/*


          如果,正常可以看到內容。像這樣。

          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里添加本機ip對應master,例如我的:172.16.249.210    master
          保證可以無密碼登錄。請看那一篇文章:http://www.aygfsteel.com/chenlb/archive/2008/07/03/212293.html

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

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

          啟動Hadoop:
          [chenlb@master hadoop-0.17.1]$ bin/start-all.sh 

          默認可以在${HADOOP_HOME}/logs里看到日志。

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


          把文件放到分布式文件系統里:

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

          此時已經在分布文件系統里建立了input文件夾。而conf是本地的文件夾。

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

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

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

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

          成功運行后可以關閉它了:
          [chenlb@master hadoop-0.17.1]$ bin/stop-all.sh

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

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

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

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

          測試后可以返回結果,但合并的時候發了點時間,我的機子上40-60ms,單個搜索基本是0ms

          測試數據是14W結果,分開索引到兩個tomcat里。看了后臺,一個搜索有兩次請求,其中合并的那機子是三次請求。時間可能花在請求里,還有就是合并可能緩存不到。

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

          當索引很大的時候可能Distributed Searching用的上場, 個人之見。

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

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


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

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

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

          然后改my-medium.ini文件為my.ini,當然也可以不改名,但要改內容

          basedir="E:/mysql-5.0.45/"

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

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

          當然可能是其它字符集, 如:gbk

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

          雙擊mysql-startup.bat即可啟動。

          用mysqladmin關閉mysql服務:
          E:/mysql-5.0.45/bin/mysqladmin -u root shutdown


          ^_^
          posted @ 2008-08-03 16:22 流浪汗 閱讀(3090) | 評論 (1)編輯 收藏
          主站蜘蛛池模板: 开鲁县| 将乐县| 淮北市| 桑日县| 乌拉特前旗| 图片| 桃江县| 志丹县| 介休市| 青川县| 临潭县| 芮城县| 淳安县| 济阳县| 开阳县| 彝良县| 南华县| 望谟县| 东兰县| 汤阴县| 清丰县| 衢州市| 徐汇区| 阿克陶县| 凤翔县| 宜黄县| 大港区| 开江县| 扎兰屯市| 绍兴市| 邛崃市| 房产| 修文县| 专栏| 阿城市| 民权县| 珠海市| 疏勒县| 普兰店市| 福安市| 太康县|