posts - 41, comments - 15, trackbacks - 0, articles - 1
            BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

          2014年6月17日

          有時候在客戶端使用svg畫圖,而在服務(wù)器端需要同樣的圖片,在服務(wù)器端重新畫一遍是非常費事的。這時候我們就可以利用已有的svg直接通過下面的類轉(zhuǎn)換成png格式。

          使用這個方法需要引用batic相關(guān)的包,maven pom文件如下:

          <!-- svg 生成png格式圖片  -->
          <dependency><groupId>batik</groupId><artifactId>batik-svggen</artifactId><version>1.6</version></dependency>        
          <dependency><groupId>batik</groupId><artifactId>batik-awt-util</artifactId><version>1.6</version></dependency>
          <dependency><groupId>batik</groupId><artifactId>batik-bridge</artifactId><version>1.6</version></dependency>
          <dependency><groupId>batik</groupId><artifactId>batik-css</artifactId><version>1.6</version></dependency>
          <dependency><groupId>batik</groupId><artifactId>batik-dom</artifactId><version>1.6</version></dependency>
          <dependency><groupId>batik</groupId><artifactId>batik-gvt</artifactId><version>1.6</version></dependency>
          <dependency><groupId>batik</groupId><artifactId>batik-parser</artifactId><version>1.6</version></dependency>
          <dependency><groupId>batik</groupId><artifactId>batik-script</artifactId><version>1.6</version></dependency>
          <dependency><groupId>batik</groupId><artifactId>batik-svg-dom</artifactId><version>1.6</version></dependency>
          <dependency><groupId>batik</groupId><artifactId>batik-transcoder</artifactId><version>1.6</version></dependency>
          <dependency><groupId>batik</groupId><artifactId>batik-util</artifactId><version>1.6</version></dependency>
          <dependency><groupId>batik</groupId><artifactId>batik-xml</artifactId><version>1.6</version></dependency>
          <!-- 此處不能使用2.9.1版本,使用2.9.1生成png會失敗 -->
          <dependency><groupId>xerces</groupId><artifactId>xercesImpl</artifactId><version>2.5.0</version></dependency>
          <dependency><groupId>xml-apis</groupId><artifactId>xmlParserAPIs</artifactId><version>2.0.2</version></dependency>
          <dependency><groupId>org.axsl.org.w3c.dom.svg</groupId><artifactId>svg-dom-java</artifactId><version>1.1</version></dependency>
          <dependency><groupId>xml-apis</groupId>    <artifactId>xml-apis</artifactId><version>2.0.0</version></dependency>
          <dependency><groupId>org.w3c.css</groupId> <artifactId>sac</artifactId>    <version>1.3</version></dependency>
          <!-- svg 生成png格式圖片結(jié)束  -->
          package com.yhb.web.util;
          import java.io.ByteArrayInputStream;
          import java.io.File;
          import java.io.FileOutputStream;
          import java.io.IOException;
          import java.io.InputStream;
          import java.io.OutputStream;
          import java.io.UnsupportedEncodingException;
          import java.net.URL;
          import org.apache.batik.transcoder.TranscoderException;
          import org.apache.batik.transcoder.TranscoderInput;
          import org.apache.batik.transcoder.TranscoderOutput;
          import org.apache.batik.transcoder.image.PNGTranscoder;
          public final class FileUtil {
          /** 
               *@Description: 將svg字符串轉(zhuǎn)換為png 
               *@Author: 
               *@param svgCode svg代碼 
               *@param pngFilePath  保存的路徑 
               *@throws IOException io異常 
               *@throws TranscoderException svg代碼異常 
              */  
          public static void convertToPng(String svgCode,String pngFilePath) throws IOException,TranscoderException{  
           
                  File file = new File (pngFilePath);  
            
                  FileOutputStream outputStream = null;  
                  try {  
                      file.createNewFile ();  
                      outputStream = new FileOutputStream (file);  
                      convertToPng (svgCode, outputStream);  
                  } finally {  
                      if (outputStream != null) {  
                          try {  
                              outputStream.close ();  
                          } catch (IOException e) {  
                              e.printStackTrace ();  
                          }  
                      }  
                  }  
              }  
          /** 
               *@Description: 將svgCode轉(zhuǎn)換成png文件,直接輸出到流中 
               *@param svgCode svg代碼 
               *@param outputStream 輸出流 
               *@throws TranscoderException 異常 
               *@throws IOException io異常 
               */  
              public static void convertToPng(String svgCode,OutputStream outputStream) throws TranscoderException,IOException{  
                  try {  
                  byte[] bytes = svgCode.getBytes ("UTF-8");  
                      PNGTranscoder t = new PNGTranscoder ();  
                      TranscoderInput input = new TranscoderInput (new ByteArrayInputStream (bytes));  
                      TranscoderOutput output = new TranscoderOutput (outputStream);  
                      t.transcode (input, output);  
                      outputStream.flush ();  
                  } finally {  
                      if (outputStream != null) {  
                          try {  
                              outputStream.close ();  
                          } catch (IOException e) {  
                              e.printStackTrace ();  
                          }  
                      }  
                  }  
              }  
          }

          posted @ 2015-10-19 15:17 yuhaibo736 閱讀(317) | 評論 (0)編輯 收藏

          方法1: 設(shè)定環(huán)境變量
          set NLS_SORT=SCHINESE_RADICAL_M ;export NLS_SORT (sh)
          or setenv NLS_SORT SCHINESE_RADICAL_M (csh)
          or regedit 
          HKLC/SOFTWARE/ORACLE/home0/NLS_SORT        (win)

          方法2: 在session中修改
          alter session set NLS_SORT='SCHINESE_RADICAL_M'

          方法3: 直接使用NLSSORT函數(shù) (推薦)
          select name,id from t
          order by NLSSORT(name,'NLS_SORT = SCHINESE_STROKE_M')

          設(shè)置NLS_SORT值:

          SCHINESE_RADICAL_M 按照部首(第一順序)、筆劃(第二順序)排序 

          SCHINESE_STROKE_M 按照筆劃(第一順序)、部首(第二順序)排序 

          SCHINESE_PINYIN_M 按照拼音排序

          posted @ 2014-08-29 14:13 yuhaibo736 閱讀(1288) | 評論 (0)編輯 收藏

              在IBATIS中,框架內(nèi)置了對OSCache的支持,如果我們想使用EHCache,則需要通過我們手工實現(xiàn)來完成二級緩存的功能機(jī)制。

              在mybatis中,開發(fā)組織只提供了一些默認(rèn)的二級緩存實現(xiàn)的機(jī)制,并沒有直接內(nèi)置的支持OSCache和EHCache等二級緩存機(jī)制,而是作為一個集成jar包來提供二級緩存的實現(xiàn),在官方網(wǎng)站上我們可以找到mybatis-ehcache-1.0.1-bundle.zip,mybatis-oscache-1.0.1-bundle.zip等ehcache和oscache提供二級緩存的獨立工具包. 這里我就拿oscache在mybatis中的使用來舉例說明:

                 1.   將mybatis-oscache-1.0.1-bundle.zip中涉及到的jar包放入到classpath路徑下 
                       maven下可以這樣配置
                         <dependencies>  
                              
          ... 

                              <dependency> 

                                  <groupId>org.mybatis.caches</groupId> 

                                  <artifactId>mybatis-oscache</artifactId>      
                                   <version>1.0.2-SNAPSHOT</version> 

                              </dependency>             

                              <dependency>
                                  <groupId>javax.jms</groupId>
                                  <artifactId>jms</artifactId>
                                  <version>1.1</version>
                              </dependency>

                              <dependency>
                                   <groupId>opensymphony</groupId>
                                   <artifactId>oscache</artifactId>
                                   <version>2.4</version>
                                   <exclusions>       
                                         <exclusion>
                                             <groupId>com.sun.jdmk</groupId>
                                             <artifactId>jmxtools</artifactId>
                                         </exclusion>
                                     <exclusion>
                                     <groupId>com.sun.jmx</groupId>
                                     <artifactId>jmxri</artifactId>
                                 </exclusion>
                               </exclusions>
                          </dependency>

                              ... 

                          </dependencies>

                 2.   在mapper文件中的配置如下:

                       <mapper namespace="org.test.AuthMapper" >         

                           <cache  type="org.mybatis.caches.oscache.OSCache"/>

                       </mapper>
                      注意下面兩點
                       (a)在
          <select id="getAuth" parameterType="Map" resultType="Auth"  useCache="false">中使用useCache="false"或useCache="true"來決定是否使用二級緩存。    
                       (b)在增刪改中<insert id="insertAuth" parameterType="Auth"  flushCache="true">使用flushCache="true"或flushCache="flase"來決定對這些進(jìn)行操作后清空該xml文件中所有查詢語句的二級緩存。 

                 3.  在src目錄下創(chuàng)建一個oscache.properties的屬性文件,在里面指定緩存的各種屬性的設(shè)置:
                       cache.memory=true             
                       cache.path=c:\\myapp\\cache
                       cache.persistence.class=com.opensymphony.oscache.plugins.diskpersistence.DiskPersistenceListener
                       cache.persistence.overflow.only=true
                       cache.capacity=100000

                      

          posted @ 2014-08-11 18:22 yuhaibo736 閱讀(2733) | 評論 (0)編輯 收藏

          import java.awt.Color;
          import java.io.FileOutputStream;

          import com.itextpdf.text.BaseColor;
          import com.itextpdf.text.Document;
          import com.itextpdf.text.Element;
          import com.itextpdf.text.Font;
          import com.itextpdf.text.PageSize;
          import com.itextpdf.text.Phrase;
          import com.itextpdf.text.Rectangle;
          import com.itextpdf.text.pdf.BaseFont;
          import com.itextpdf.text.pdf.PdfPCell;
          import com.itextpdf.text.pdf.PdfPTable;
          import com.itextpdf.text.pdf.PdfWriter;

          public class CellEvents {


           /**
            * @param args
            */
           public static void main(String[] args) {
            Object[] objArr = new Object[]{100,20,300};
            
            Document document = new Document(PageSize.A4.rotate(),50,50,50,50);
            try{
             //bfSongti = BaseFont.createFont("/simsun.ttc,1", BaseFont.IDENTITY_H, BaseFont.NOT_EMBEDDED);
             Font songtiSFivefont = new Font(BaseFont.createFont("/simsun.ttc,1", BaseFont.IDENTITY_H, BaseFont.NOT_EMBEDDED), 9f);//宋體小五號字
                   //設(shè)置存放位置
                   PdfWriter.getInstance(document, new FileOutputStream("D:/test.pdf"));
                   document.open();
           
                   PdfPTable table = new PdfPTable(5);
             table.setSpacingBefore(10f);
             table.getDefaultCell().setPadding(5);
             //HowbuyBorderPdfPTableEvent event = new HowbuyBorderPdfPTableEvent();
             //table.setTableEvent(event);
             //table.getDefaultCell().setBorder(Rectangle.NO_BORDER);
             table.getDefaultCell().setVerticalAlignment(Element.ALIGN_MIDDLE);
             table.getDefaultCell().setHorizontalAlignment(Element.ALIGN_CENTER);
             PdfPCell cellTitle = new PdfPCell(new Phrase("總資產(chǎn)\n(萬元)",songtiSFivefont));
             cellTitle.setBorderWidth(2f);
             cellTitle.setBackgroundColor(new BaseColor(new Color(153, 51, 0)));
             cellTitle.setBorderColor(new BaseColor(new Color(153, 51, 0)));
             cellTitle.setHorizontalAlignment(Element.ALIGN_CENTER);
             cellTitle.setVerticalAlignment(Element.ALIGN_MIDDLE);
             cellTitle.setMinimumHeight(25);
             table.addCell(cellTitle);
           
             cellTitle = new PdfPCell(new Phrase(""));
             cellTitle.setBorder(Rectangle.NO_BORDER);
             cellTitle.setHorizontalAlignment(Element.ALIGN_CENTER);
             cellTitle.setVerticalAlignment(Element.ALIGN_MIDDLE);
             table.addCell(cellTitle);
             
             cellTitle = new PdfPCell(new Phrase("當(dāng)前收益\n(萬元)",songtiSFivefont));
             cellTitle.setBorderWidth(2f);
             cellTitle.setBackgroundColor(new BaseColor(new Color(153, 51, 0)));
             cellTitle.setBorderColor(new BaseColor(new Color(153, 51, 0)));
             cellTitle.setHorizontalAlignment(Element.ALIGN_CENTER);
             cellTitle.setVerticalAlignment(Element.ALIGN_MIDDLE);
             table.addCell(cellTitle);
           
             cellTitle = new PdfPCell(new Phrase("",songtiSFivefont));
             cellTitle.setBorder(Rectangle.NO_BORDER);
             cellTitle.setHorizontalAlignment(Element.ALIGN_CENTER);
             cellTitle.setVerticalAlignment(Element.ALIGN_MIDDLE);
             table.addCell(cellTitle);
             
             
             cellTitle = new PdfPCell(new Phrase("累計收益\n(萬元)",songtiSFivefont));
             cellTitle.setBorderWidth(2f);
             cellTitle.setBackgroundColor(new BaseColor(new Color(153, 51, 0)));
             cellTitle.setBorderColor(new BaseColor(new Color(153, 51, 0)));
             cellTitle.setHorizontalAlignment(Element.ALIGN_CENTER);
             cellTitle.setVerticalAlignment(Element.ALIGN_MIDDLE);
             table.addCell(cellTitle);
             
             float[] widths2 = { 24.5f, 12.25f,24.5f,12.25f,24.5f};

             table.setWidths(widths2);
             
             table.setHorizontalAlignment(Element.ALIGN_LEFT);//
             table.setWidthPercentage(70);
             double zzc = objArr[0]==null ? 0:Double.parseDouble(objArr[0].toString());
             double dqsy = objArr[1]==null ? 0:Double.parseDouble(objArr[1].toString());
             double ljsy = objArr[2]==null ? 0:Double.parseDouble(objArr[2].toString());
             PdfPCell cell1 = new PdfPCell(new Phrase(String.valueOf(zzc),songtiSFivefont));
             cell1.setBorderWidth(2f);
             cell1.setBorderColor(new BaseColor(new Color(153, 51, 0)));
             cell1.setHorizontalAlignment(Element.ALIGN_CENTER);
             cell1.setVerticalAlignment(Element.ALIGN_MIDDLE);
             cell1.setMinimumHeight(20);
             table.addCell(cell1);
             
             cell1 = new PdfPCell(new Phrase("",songtiSFivefont));
             cell1.setBorder(Rectangle.NO_BORDER);
             cell1.setHorizontalAlignment(Element.ALIGN_CENTER);
             cell1.setVerticalAlignment(Element.ALIGN_MIDDLE);
             table.addCell(cell1);
             
             cell1 = new PdfPCell(new Phrase(String.valueOf(dqsy),songtiSFivefont));
             cell1.setBorderWidth(2f);
             cell1.setBorderColor(new BaseColor(new Color(153, 51, 0)));
             cell1.setHorizontalAlignment(Element.ALIGN_CENTER);
             cell1.setVerticalAlignment(Element.ALIGN_MIDDLE);
             table.addCell(cell1);
             
             cell1 = new PdfPCell(new Phrase("",songtiSFivefont));
             cell1.setBorder(Rectangle.NO_BORDER);
             cell1.setHorizontalAlignment(Element.ALIGN_CENTER);
             cell1.setVerticalAlignment(Element.ALIGN_MIDDLE);
             table.addCell(cell1);
             
             cell1 = new PdfPCell(new Phrase(String.valueOf(ljsy),songtiSFivefont));
             cell1.setBorderWidth(2f);
             cell1.setBorderColor(new BaseColor(new Color(153, 51, 0)));
             cell1.setHorizontalAlignment(Element.ALIGN_CENTER);
             cell1.setVerticalAlignment(Element.ALIGN_MIDDLE);
             table.addCell(cell1);
             document.add(table);
            }catch(Exception ex){
             ex.printStackTrace();
            }
                  document.close();

           }

          }

          posted @ 2014-06-24 16:27 yuhaibo736 閱讀(1465) | 評論 (0)編輯 收藏

          相信很多人都聽過nginx,這個小巧的東西慢慢地在吞食apache和IIS的份額。那究竟它有什么作用呢?可能很多人未必了解。

          說到反向代理,可能很多人都聽說,但具體什么是反向代理,很多人估計就不清楚了。摘一段百度百科上的描述:

          Html代碼 復(fù)制代碼 收藏代碼
          1. 反向代理(Reverse Proxy)方式是指以代理服務(wù)器來接受internet上的連接請求,然后將請求轉(zhuǎn)發(fā)給內(nèi)部網(wǎng)絡(luò)上的服務(wù)器,并將從服務(wù)器上得到的結(jié)果返回給internet上請求連接的客戶端,此時代理服務(wù)器對外就表現(xiàn)為一個服務(wù)器。 

          這里講得很直白。反向代理方式實際上就是一臺負(fù)責(zé)轉(zhuǎn)發(fā)的代理服務(wù)器,貌似充當(dāng)了真正服務(wù)器的功能,但實際上并不是,代理服務(wù)器只是充當(dāng)了轉(zhuǎn)發(fā)的作用,并且從真正的服務(wù)器那里取得返回的數(shù)據(jù)。這樣說,其實nginx完成的就是這樣的工作。我們讓nginx監(jiān)聽一個端口,譬如80端口,但實際上我們轉(zhuǎn)發(fā)給在8080端口的tomcat,由它來處理真正的請求,當(dāng)請求完成后,tomcat返回,但數(shù)據(jù)此時沒直接返回,而是直接給nginx,由nginx進(jìn)行返回,這里,我們會以為是nginx進(jìn)行了處理,但實際上進(jìn)行處理的是tomcat。

          說到上面的方式,也許很多人又會想起來,這樣可以把靜態(tài)文件交由nginx來進(jìn)行處理。對,很多用到nginx的地方都是作為靜態(tài)伺服器,這樣可以方便緩存那些靜態(tài)文件,比如CSS,JS,html,htm等文件。

          閑話就不多說了,我們直接來看看nginx怎么使用。

          1)要用到的軟件當(dāng)然要下載啦。到nginx官網(wǎng)下一個。http://nginx.org/en/download.html可以到這里去下。我現(xiàn)在用的版本是1.1.7,但基本上以后的版本都兼容,而且我們用到的并不涉及到太底層的,應(yīng)該不會有什么變化。

          這里,由于我的是windows,當(dāng)然下windows版啦。下完后首先要啟動吧。進(jìn)入到nginx文件夾,直接start nginx就OK了。

          比如我下載后放在D:\software\developerTools\server\nginx-1.1.7,直接cmd后cd D:\software\developerTools\server\nginx-1.1.7,有些不習(xí)慣命令行的可能會奇怪,它沒有進(jìn)行到那個文件夾。windows并不會在分區(qū)間跳轉(zhuǎn),除非你自己指定了。所以我們要直接d:如下:

          然后,我們直接start nginx,這里也許你會看到一個窗口一閃而過,根據(jù)我們使用tomcat的經(jīng)驗,如果一閃而過,證明有錯誤了,是吧?但實際上不是。

          此時我們打開任務(wù)管理器,可以看到兩個nginx.exe在那里好好的。這說明我們已經(jīng)啟動了,至于為什么兩個,我們這里不深究。

          現(xiàn)在,我們已經(jīng)啟動了nginx,這時就可以啟動tomcat,想著直接訪問http://localhost就可以直接訪問tomcat了。

          先不急,我們來看看啟動后的nginx是怎樣的。直接訪問http://localhost可以看到:

              我們可以看到nginx啟動成功,現(xiàn)在訪問是直接進(jìn)到nginx的目錄里面了。

          那么這些實際上是在哪里配置的。這就涉及到nginx的一個重要配置文件nginx.conf了。

          2)我們可以看到nginx文件夾內(nèi)有一個conf文件夾,其中有好幾個文件,其他先不管,我們打開nginx.conf,可以看到一段:

          這段代碼在server里面,相當(dāng)于一個代理服務(wù)器,當(dāng)然可以配置多個。

          下面我們仔細(xì)來分析一下:

          listen:表示當(dāng)前的代理服務(wù)器監(jiān)聽的端口,默認(rèn)的是監(jiān)聽80端口。注意,如果我們配置了多個server,這個listen要配置不一樣,不然就不能確定轉(zhuǎn)到哪里去了。

          server_name:表示監(jiān)聽到之后需要轉(zhuǎn)到哪里去,這時我們直接轉(zhuǎn)到本地,這時是直接到nginx文件夾內(nèi)。

          location:表示匹配的路徑,這時配置了/表示所有請求都被匹配到這里

          root:里面配置了root這時表示當(dāng)匹配這個請求的路徑時,將會在這個文件夾內(nèi)尋找相應(yīng)的文件,這里對我們之后的靜態(tài)文件伺服很有用。

          index:當(dāng)沒有指定主頁時,默認(rèn)會選擇這個指定的文件,它可以有多個,并按順序來加載,如果第一個不存在,則找第二個,依此類推。

          下面的error_page是代表錯誤的頁面,這里我們暫時不用,先不管它。

          那我們知道了具體的配置了,怎么讓它訪問localhost時轉(zhuǎn)到tomcat時。實際上就修改兩個地方:

          Java代碼 復(fù)制代碼 收藏代碼
          1. server_name localhost:8080
          2.  
          3. location / { 
          4.     proxy_pass http://localhost:8080 

          我們就修改了上面兩個地方,我的tomcat在8080端口,可以根據(jù)自己的需要修改。這里有一個新元素proxy_pass,它表示代理路徑,相當(dāng)于轉(zhuǎn)發(fā),而不像之前說的root必須指定一個文件夾。

          此時我們修改了文件,是不是就意思著必須先關(guān)了nginx再重新啟動了,其實不必,nginx可以重新加載文件的。

          我們直接運行:

          Html代碼 復(fù)制代碼 收藏代碼
          1. nginx -s reload 

          高興得太早了,我們發(fā)現(xiàn)有一個錯誤:

          什么來的,45行發(fā)現(xiàn)錯誤,不希望在那一行找到},于是我們仔細(xì)找,發(fā)現(xiàn)我們加入的proxy_pass很奇怪,沒有;號結(jié)尾,這就是問題了,直接修改,然后再運行一下,發(fā)現(xiàn)沒錯誤,OK了。

          如果不想直接加載,而只是想看看自己的配置文件有沒有問題,可以直接輸入:

          Xml代碼 復(fù)制代碼 收藏代碼
          1. nginx -t 

          這可以檢查配置文件中是否有錯。 下面我們所有的修改都假設(shè)我們修改完成后運行了nginx -s reload進(jìn)行重新加載配置文件,請注意。

          一切沒問題了,然后我們再重新打開http://localhost,我們看到下面的頁面:

          這時,我們發(fā)現(xiàn)它并不是剛才的welcome頁面了,而是tomcat的管理頁面了,不管我們點擊什么鏈接都是沒問題的,相當(dāng)于直接訪問http://localhost:8080一樣。

          3)上面我們直接試了一個小例子,讓nginx進(jìn)行轉(zhuǎn)發(fā),即所謂的反向代理。但實際上我們的需求不會是這樣的,我們需要分文件類型來進(jìn)行過濾,比如jsp直接給tomcat處理,因為nginx并不是servlet容器,沒辦法處理JSP,而html,js,css這些不需要處理的,直接給nginx進(jìn)行緩存。

          下面我們來進(jìn)行一下配置,讓JSP頁面直接給tomcat,而html,png等一些圖片和JS等直接給nginx進(jìn)行緩存。

          這時最主要用的還是location這個元素,并且涉及到一部分正則,但不難:

          Xml代碼 復(fù)制代碼 收藏代碼
          1. location ~ \.jsp$ { 
          2.         proxy_pass http://localhost:8080; 
          3.          
          4. location ~ \.(html|js|css|png|gif)$ { 
          5.     root D:/software/developerTools/server/apache-tomcat-7.0.8/webapps/ROOT; 

          我們先要去掉之前配的location /,避免全部請求被攔截了。

          然后我們再來看看http://localhost

          當(dāng)我們不指定jsp頁面的時候,它會出現(xiàn)找不到,因為,此時并沒有相應(yīng)的location匹配,所以就會有404錯誤,這時就跳到了nginx自定義的error頁面去了。

          而當(dāng)我們用http://localhost/index.jsp去訪問時,我們看到了熟悉的頁面:

          而且圖片那些都顯示正常,因為圖片是png的,所以直接在tomcat/webapps/ROOT目錄下直接查找,當(dāng)然,如果我們點擊Manager Application HOW-TO這個鏈接,我們發(fā)現(xiàn):

          它還是找不到,為什么呢?因為這是個html頁面,但它并不在ROOT目錄下,而是在docs目錄下,但當(dāng)我們匹配html時,我們卻到ROOT目錄下去找,所以還是找不到這個頁面。

          一般情況下,如果我們需要用nginx來進(jìn)行靜態(tài)文件伺服,一般都會把所有靜態(tài)文件,html,htm,js,css等都放在同一個文件夾下,這樣就不會有tomcat這樣的情況了,因為tomcat下的是屬于不同的項目,這個我們就沒辦法了。

          3)有些人會說,這些都只會找一臺服務(wù)器,但如果我們想在一臺服務(wù)器掛了的時候,自動去找另外一臺,這怎么辦?這實際上nginx都考慮到了。

          這時,我們之前用的proxy_pass就有大用途了。

          我們把之前的第一個例子,即全部都代理的修改一下:

          最后修改如下:

          Xml代碼 復(fù)制代碼 收藏代碼
          1. upstream local_tomcat { 
          2.     server localhost:8080; 
          3.  
          4. server{ 
          5.         location / { 
          6.            proxy_pass http://local_tomcat; 
          7.         } 
          8.         #......其他省略 

          我們在server外添加了一個upstream,而直接在proxy_pass里面直接用http://+upstream的名稱來使用。

          我們還是直接來http://localhost,還是和第一個一樣的效果,所有鏈接都沒問題,說明我們配置正確。

          upstream中的server元素必須要注意,不能加http://,但proxy_pass中必須加。

          我們剛才說可以在一個服務(wù)器掛了的情況下連到另外一個,那怎么弄呢?

          其實很簡單,在upstream中的local_tomcat中配置多一個server。比如我現(xiàn)在弄多一個jetty,端口在9999,所以我們配置如下:

          Xml代碼 復(fù)制代碼 收藏代碼
          1. upstream local_tomcat { 
          2.     server localhost:8080; 
          3.     server localhost:9999; 

          此時,我們關(guān)閉tomcat,而只開jetty。我們來運行http://localhost看看效果:

          我們看到它請求到了jetty的頁面,但由于jetty的機(jī)制,這時沒有顯示jetty主頁,這個我們先不管。但我們的在一個服務(wù)器掛的情況下自動使用另外一個的功能實現(xiàn)了。

          但有時我們就不想它掛的時候訪問另外一個,而只是希望一個服務(wù)器訪問的機(jī)會比另外一個大,這個可以在server最后加上一個weight=數(shù)字來指定,數(shù)字越大,表明請求到的機(jī)會越大。

          Xml代碼 復(fù)制代碼 收藏代碼
          1. upstream local_tomcat { 
          2.     server localhost:8080 weight=1
          3.     server localhost:9999 weight=5

          這時我們給了jetty一個更高的權(quán)值,讓它更有機(jī)會訪問到,實際上當(dāng)我們刷新http://localhost訪問的時候發(fā)現(xiàn)jetty訪問機(jī)率大很多,tomcat幾乎沒機(jī)會訪問,一般情況下,如果我們必須這樣用,不要相關(guān)太大,以免一個服務(wù)器負(fù)載太大。

          當(dāng)然,server還有一些其他的元素,比如down表示暫時不用到該服務(wù)器等等。這些可以參考nginx的wiki。也許寫了一大堆,有人會有問題,那nginx怎么關(guān)閉呢?這倒是個問題,其實直接運行nginx -s stop就可以關(guān)閉了。

          基本上nginx的用法是這樣,深入的以后我們?nèi)绻玫皆賹W(xué)習(xí)。

          posted @ 2014-06-17 15:24 yuhaibo736 閱讀(1383) | 評論 (0)編輯 收藏

          主站蜘蛛池模板: 临潭县| 泗阳县| 息烽县| 雅安市| 礼泉县| 陆河县| 武陟县| 启东市| 手机| 乐山市| 通辽市| 贺州市| 屏东县| 姚安县| 门头沟区| 望江县| 钟山县| 信宜市| 邻水| 察隅县| 腾冲县| 昌宁县| 湟源县| 合作市| 卫辉市| 开封县| 兴化市| 镇宁| 日土县| 海口市| 绥宁县| 淳安县| 永昌县| 铜鼓县| 西充县| 绩溪县| 镇坪县| 鹤岗市| 大渡口区| 上犹县| 眉山市|