qqjianyue代碼工

          砌java代碼
          posts - 62, comments - 9, trackbacks - 0, articles - 10
            BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

          2009年12月11日

          1. Change to aliyun repository

          2. Chinese input method
          sudo apt-get install ibus-pinyin
          #remmeber to logout and re-logon to change system 'Region&Language' setting

          3. Shadowsocks and genpac
          sudo apt install -y shadowsocks-libev
          #sudo vi /etc/shadowsocks-libev/shadowsock.json
          {
              
          "server":"x.x.x.x",
              
          "server_port":xx,
              
          "local_port":1080,
              
          "password":"xxxxx",
              
          "timeout":60,
              
          "method":"aes-256-cfb"
          }

          nohup ss-local -c /etc/shadowsocks-libev/shadowsock.json >/dev/null 2>&1 &

          sudo apt install phython-pip
          sudo -H
          pip install genpac


          如果pip error "TypeError: unsupported operand type(s) for -=: 'Retry' and 'int'"
          sudo python -m pip install --upgrade --force pip

          mkdir pac
          cd pac
          touch user-rules.txt
          genpac --pac-proxy "SOCKS5 127.0.0.1:1080" --gfwlist-proxy="SOCKS5 127.0.0.1:1080" --output="autoproxy.pac" --gfwlist-url="https://raw.githubusercontent.com/gfwlist/gfwlist/master/gfwlist.txt" --user-rule-from="user-rules.txt"

          配置系統自動代理為:
          /home/xxx/pac/autoproxy.pac

          4. JDK8
          https://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html
          download and setup environment variable manually


          5.gcloud
          http://ubuntuhandbook.org/index.php/2014/10/google-cloud-sdk-made-into-canonical-partners-repository/

          posted @ 2018-11-03 08:39 Qzi 閱讀(204) | 評論 (0)編輯 收藏

          官方說明:http://source.android.com/source/initializing.html
          環境:
          Ubuntu 12.04 64bit
          JDK6(installation: http://www.gaggl.com/2012/04/installing-java6-jdk-on-ubuntu-12-04/)

          $ make -v
          GNU Make 3.81
          Copyright (C) 2006  Free Software Foundation, Inc.
          This is free software; see the source for copying conditions.
          There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A
          PARTICULAR PURPOSE.
          This program built for x86_64-pc-linux-gnu
          $ python -V
          Python 2.7.3
          android 當前 mainfest version: 4.2


          按照官方說明從下載到運行emulator,沒有nexus,所以沒做實際機器燒錄。步驟請根據官方說明做,以下只列出過程遇到的問題:
          1.repo sync
          經常出現斷線,網上有很多參考辦法,我是每次忽略這些錯誤,直到運行完畢退出,我再重新運行:
          repo sync -f
          知道所有代碼下載完畢(4.2的有16G)
          2.每次跑emulator都要cd到代碼目錄先進行環境初始化
          source build/envsetup.sh
          lunch full-eng
          3.emulator出錯
          $ emulator
          emulator: WARNING: system partition size adjusted to match image file (229 MB > 200 MB)
          Segmentation fault (core dumped)
          改成用emulator-arm -partition-size 1024
          full long command reference:
          http://stackoverflow.com/questions/9022750/running-emulator-after-building-android-from-source

          posted @ 2013-04-20 10:57 Qzi 閱讀(306) | 評論 (0)編輯 收藏

          Spring 聲明式事務讓我們從復雜的事務處理中得到解脫。使得我們再也無需要去處理獲得連接、關閉連接、事務提交和回滾等這些操作。再也無需要我們在與事務相關的方法中處理大量的 try catch  finally 代碼。 我們在使用 Spring 聲明式事務時,有一個非常重要的概念就是事務屬性。事務屬性通常由事務的傳播行為,事務的隔離級別,事務的超時值和事務只讀標志組成。我們在進行事務劃分時,需要進行事務定義,也就是配置事務的屬性。

           

          Spring  TransactionDefinition 接口中定義這些屬性 , 以供 PlatfromTransactionManager 使用 , PlatfromTransactionManager  spring 事務管理的核心接口。

           

          l         getTimeout() 方法,它返回事務必須在多少秒內完成。

          l         isReadOnly() , 事務是否只讀,事務管理器能夠根據這個返回值進行優化,確保事務是只讀的。

          l         getIsolationLevel() 方法返回事務的隔離級別,事務管理器根據它來控制另外一個事務可以看到本事務內的哪些數據。

           

           TransactionDefinition 接口中定義了五個不同的事務隔離級別:

           

          l         ISOLATION_DEFAULT 這是一個 PlatfromTransactionManager 默認的隔離級別,使用數據庫默認的事務隔離級別 . 另外四個與 JDBC 的隔離級別相對應

          l         ISOLATION_READ_UNCOMMITTED 這是事務最低的隔離級別,它充許別外一個事務可以看到這個事務未提交的數據。這種隔離級別會產生臟讀,不可重復讀和幻像讀。 例如 : Mary的原工資為 1000, 財務人員將 Mary 的工資改為了 8000 ,但未提交事務 與此同時, Mary正在讀取自己的工資 Mary 發現自己的工資變為了 8000 ,歡天喜地! 而財務發現操作有誤,而回滾了事務 ,Mary 的工資又變為了 1000. 像這樣 ,Mary 記取的工資數 8000 是一個臟數據。

          l         ISOLATION_READ_COMMITTED 保證一個事務修改的數據提交后才能被另外一個事務讀取。另外一個事務不能讀取該事務未提交的數據。這種事務隔離級別可以避免臟讀出現,但是可能會出現不可重復讀和幻像讀。

          l         ISOLATION_REPEATABLE_READ 這種事務隔離級別可以防止臟讀,不可重復讀。但是可能出現幻像讀。它除了保證一個事務不能讀取另一個事務未提交的數據外,還保證了避免下面的情況產生 ( 不可重復讀 )  在事務 1 中, Mary 讀取了自己的工資為 1000, 操作并沒有完成 在事務 2 中,這時財務人員修改了 Mary 的工資為 2000, 并提交了事務 . 在事務 1 中,Mary 再次讀取自己的工資時,工資變為了 2000 在一個事務中前后兩次讀取的結果并不致,導致了不可重復讀。 使用 ISOLATION_REPEATABLE_READ 可以避免這種情況發生。

          l         ISOLATION_SERIALIZABLE 這是花費最高代價但是最可靠的事務隔離級別。事務被處理為順序執行。除了防止臟讀,不可重復讀外,還避免了幻像讀。 目前工資為 1000 的員工有 10人。 事務 1, 讀取所有工資為 1000 的員工。 共讀取 10 條記錄 這時另一個事務向 employee表插入了一條員工記錄,工資也為 1000 事務 1 再次讀取所有工資為 1000 的員工 共讀取到了 11 條記錄,這就產生了幻像讀。 ISOLATION_SERIALIZABLE 能避免這樣的情況發生。但是這樣也耗費了最大的資源。

           

           

          getPropagationBehavior () 返回事務的傳播行為,由是否有一個活動的事務來決定一個事務調用。  TransactionDefinition 接口中定義了七個事務傳播行為:

           

          l         PROPAGATION_REQUIRED 如果存在一個事務,則支持當前事務。如果沒有事務則開啟一個新的事務。 使用 spring 聲明式事務, spring 使用 AOP 來支持聲明式事務,會根據事務屬性,自動在方法調用之前決定是否開啟一個事務,并在方法執行之后決定事務提交或回滾事務。 單獨調用 methodB 方法 相當于 Spring 保證在 methodB 方法中所有的調用都獲得到一個相同的連接。在調用 methodB 時,沒有一個存在的事務,所以獲得一個新的連接,開啟了一個新的事務。 單獨調用 MethodA 時,在 MethodA 內又會調用 MethodB. 執行效果相當于 調用 MethodA 時,環境中沒有事務,所以開啟一個新的事務 . 當在 MethodA 中調用MethodB 時,環境中已經有了一個事務,所以 methodB 就加入當前事務。

          l         PROPAGATION_SUPPORTS 如果存在一個事務,支持當前事務。如果沒有事務,則非事務的執行。但是對于事務同步的事務管理器, PROPAGATION_SUPPORTS 與不使用事務有少許不同。 單純的調用 methodB 時, methodB 方法是非事務的執行的。 當調用 methdA ,methodB 則加入了 methodA 的事務中 , 事務地執行。

          l         PROPAGATION_MANDATORY 如果已經存在一個事務,支持當前事務。如果沒有一個活動的事務,則拋出異常。 當單獨調用 methodB 時,因為當前沒有一個活動的事務,則會拋出異常 throw new IllegalTransactionStateException("Transaction propagation ''mandatory'' but no existing transaction found"); 當調用 methodA 時, methodB 則加入到 methodA 的事務中,事務地執行。

          l         PROPAGATION_REQUIRES_NEW 總是開啟一個新的事務。如果一個事務已經存在,則將這個存在的事務掛起。 當單獨調用 methodB 時,相當于把 methodb 聲明為 REQUIRED 。開啟一個新的事務,事務地執行。 當調用 methodA  情況有些大不一樣 . 相當于下面的效果。 在這里,我把 ts1 稱為外層事務, ts2 稱為內層事務。從上面的代碼可以看出, ts2 ts1 是兩個獨立的事務,互不相干。 Ts2 是否成功并不依賴于 ts1 。如果 methodA 方法在調用 methodB 方法后的 doSomeThingB 方法失敗了,而 methodB 方法所做的結果依然被提交。而除了 methodB 之外的其它代碼導致的結果卻被回滾了。 使用PROPAGATION_REQUIRES_NEW, 需要使用 JtaTransactionManager 作為事務管理器。

          l         PROPAGATION_NOT_SUPPORTED 總是非事務地執行,并掛起任何存在的事務。 當單獨調用 methodB 時,不啟用任何事務機制,非事務地執行。 當調用 methodA 時,相當于下面的效果 使用 PROPAGATION_NOT_SUPPORTED, 也需要使用 JtaTransactionManager 作為事務管理器。

          l         PROPAGATION_NEVER 總是非事務地執行,如果存在一個活動事務,則拋出異常 單獨調用methodB ,則非事務的執行。 調用 methodA 則會拋出異常

          l         PROPAGATION_NESTED 如果一個活動的事務存在,則運行在一個嵌套的事務中 . 如果沒有活動事務 , 則按 TransactionDefinition.PROPAGATION_REQUIRED 屬性執行 這是一個嵌套事務 , 使用 JDBC 3.0 驅動時 , 僅僅支持 DataSourceTransactionManager 作為事務管理器。需要 JDBC 驅動的 java.sql.Savepoint 類。有一些 JTA 的事務管理器實現可能也提供了同樣的功能。 使用 PROPAGATION_NESTED ,還需要把 PlatformTransactionManager nestedTransactionAllowed 屬性設為 true;  nestedTransactionAllowed 屬性值默認為false; 如果單獨調用 methodB 方法,則按 REQUIRED 屬性執行。 如果調用 methodA 方法,相當于下面的效果  methodB 方法調用之前,調用 setSavepoint 方法,保存當前的狀態到 savepoint 。如果 methodB 方法調用失敗,則恢復到之前保存的狀態。但是需要注意的是,這時的事務并沒有進行提交,如果后續的代碼 (doSomeThingB() 方法 ) 調用失敗,則回滾包括 methodB 方法的所有操作。 嵌套事務一個非常重要的概念就是內層事務依賴于外層事務。外層事務失敗時,會回滾內層事務所做的動作。而內層事務操作失敗并不會引起外層事務的回滾。

           

           

          PROPAGATION_NESTED  PROPAGATION_REQUIRES_NEW 的區別:

           

          它們非常類似 , 都像一個嵌套事務,如果不存在一個活動的事務,都會開啟一個新的事務。使用PROPAGATION_REQUIRES_NEW 時,內層事務與外層事務就像兩個獨立的事務一樣,一旦內層事務進行了提交后,外層事務不能對其進行回滾。兩個事務互不影響。兩個事務這是一個真正的嵌套事務。同時它需要 JTA 事務管理器的支持。 使用 PROPAGATION_NESTED 時,外層事務的回滾可以引起內層事務的回滾。而內層事務的異常并不會導致外層事務的回滾,它是一個真正的嵌套事務。 DataSourceTransactionManager 使用 savepoint 支持PROPAGATION_NESTED 時,需要 JDBC 3.0 以上驅動及 1.4 以上的 JDK 版本支持。其它的JTA TrasactionManager 實現可能有不同的支持方式。 PROPAGATION_REQUIRED 應該是我們首先的事務傳播行為。它能夠滿足我們大多數的事務需求。

          posted @ 2011-11-29 10:25 Qzi 閱讀(242) | 評論 (0)編輯 收藏

          參考這篇文章:http://blog.csdn.net/bluishglc/article/details/6632280 
          一。Maven的執行方式
          maven對構建(build)的過程進行了抽象和定義,這個過程被稱為構建的生命周期(lifecycle)。生命周期(lifecycle)由多個階段(phase)組成,每個階段(phase)會掛接一到多個goal。goal是maven里定義任務的最小單元,goal分為兩類,一類是綁定phase的,就是執行到某個phase,那么這個goal就會觸發,另外一類不綁定,就是單獨任務,這就相當于ant里的target。
          1。以phase來構建
          例如:
          mvn clean
          mvn compile
          mvn test
          mvn package
          表明maven會執行到某個生命周期(lifecycle)的某個階段(phase)
          這個phase以及它前面所有phase綁定的目標(goal)都會執行, 每個phase都會邦定maven默認的goal或者沒有goal, 或者自定義的goal。
          也可以通過傳入參數跳過(skip)某些phase,例如:
          mvn install -Dmaven.test.skip=true

          1。以goal來構建
          這類就是沒有綁定phase的goal,但是這類goal卻通常會有個執行前提,就是project必須執行到某個phase,
          那么執行這個goal,其實也會觸發maven執行到前提要求的phase。
          例如jetty:run是個非綁定phase的goal,它的前提是test-compile,這個前提是由plugin的代碼邏輯制定的

          /**
           * @goal run
           * @requiresDependencyResolution runtime
           * @execute phase="test-compile"
           * @description Runs jetty6 directly from a maven project
           */
          public class Jetty6RunMojo extends AbstractJettyRunMojo
          {
              ...
          }
          二。Maven lifecycle, phase概覽
          Maven預設了三個Lifecycle ,各包含了下列Phases.
          1. Clean Lifecycle
            • pre-clean
            • clean
            • post-clean
          2. Default Lifecycle
            • validate
            • initialize
            • generate-sources
            • process-sources
            • generate-resources
            • process-resources
            • compile
            • process-classes
            • generate-test-sources
            • process-test-sources
            • process-test-resources
            • test-compile
            • process-test-classes
            • test
            • prepare-package
            • package
            • pre-integration-test
            • integration-test
            • post-integration-test
            • verify
            • install
            • deploy
          3. Site Lifecycle
            • pre-site
            • site
            • post-site
            • site-deploy

          posted @ 2011-09-22 10:01 Qzi 閱讀(9290) | 評論 (0)編輯 收藏

          1.Window
          • java -classpath .;jar1;jar2 MainClass
            注意: -classpath參數必須放于前面。
          • java -jar jar1
            jar包的MANIFEST.MF文件:
            Manifest-Version: 1.0
            Main-Class: com.Main1
            Class-Path: jar1.jar;jar2.jar

            注意: 使用-jar參數,那么主jar包必須含有MANIFEST.MF信息,并且指定Main-Class & Class-Path。命令行的-classpath參數將被忽略
          2.Linux
          區別:
          目錄分隔符由\變成/
          jar包分隔符由;變成:

          Window測試環境是Sun java version "1.6.0_14"
          其他版本沒有驗證

          posted @ 2011-09-16 17:10 Qzi 閱讀(330) | 評論 (0)編輯 收藏

          posted @ 2011-09-16 16:59 Qzi 閱讀(268) | 評論 (0)編輯 收藏

          1.綁定本地接口,自動生成代理對象
          復制下面鏈接代碼
          // Endpoint Address
          String endpointAddress = "http://localhost:8111/helloWorld";
          // Add a port to the Service
          service.addPort(PORT_NAME, SOAPBinding.SOAP11HTTP_BINDING, endpointAddress);
          HelloService hw = service.getPort(HelloService.class);

          posted @ 2011-09-16 16:58 Qzi 閱讀(622) | 評論 (0)編輯 收藏

          java -Dhttp.proxyHost=127.0.0.1 -Dhttp.proxyPort=8888 -Dhttps.proxyHost=127.0.0.1 -Dhttps.proxyPort=8888

          posted @ 2011-09-16 16:58 Qzi 閱讀(520) | 評論 (0)編輯 收藏

          Java Keytool Commands for Creating and Importing

          These commands allow you to generate a new Java Keytool keystore file, create a CSR, and import certificates. Any root or intermediate certificates will need to be imported before importing the primary certificate for your domain.

          • Generate a Java keystore and key pair

            keytool -genkey -alias mydomain -keyalg RSA -keystore keystore.jks -keysize 2048

          • Generate a certificate signing request (CSR) for an existing Java keystore

            keytool -certreq -alias mydomain -keystore keystore.jks -file mydomain.csr

          • Import a root or intermediate CA certificate to an existing Java keystore

            keytool -import -trustcacerts -alias root -file Thawte.crt -keystore keystore.jks

          • Import a signed primary certificate to an existing Java keystore

            keytool -import -trustcacerts -alias mydomain -file mydomain.crt -keystore keystore.jks

          • Generate a keystore and self-signed certificate (see How to Create a Self Signed Certificate using Java Keytool for more info)

            keytool -genkey -keyalg RSA -alias selfsigned -keystore keystore.jks -storepass password -validity 360 -keysize 2048

          Java Keytool Commands for Checking

          If you need to check the information within a certificate, or Java keystore, use these commands.

          • Check a stand-alone certificate

            keytool -printcert -v -file mydomain.crt

          • Check which certificates are in a Java keystore

            keytool -list -v -keystore keystore.jks

          • Check a particular keystore entry using an alias

            keytool -list -v -keystore keystore.jks -alias mydomain

          Other Java Keytool Commands

          • Delete a certificate from a Java Keytool keystore

            keytool -delete -alias mydomain -keystore keystore.jks

          • Change a Java keystore password

            keytool -storepasswd -new new_storepass -keystore keystore.jks

          • Export a certificate from a keystore

            keytool -export -alias mydomain -file mydomain.crt -keystore keystore.jks

          • List Trusted CA Certs

            keytool -list -v -keystore $JAVA_HOME/jre/lib/security/cacerts

          • Import New CA into Trusted Certs

            keytool -import -trustcacerts -file /path/to/ca/ca.pem -alias CA_ALIAS -keystore $JAVA_HOME/jre/lib/security/cacerts

          posted @ 2011-09-16 16:24 Qzi 閱讀(395) | 評論 (0)編輯 收藏

          第一種方式:適合于全部HTML標簽
          <acronym title="World Wide Web">
          WWW
          </acronym>

          第二種方式:IMG之類的標簽例如:
          <img src="#" alt="鼠標移動到上方會顯示并且未加載圖片時也會顯示">

          第三種方式:input之類的標簽例如:
          <input type="button" value="確定" title="鼠標移動到上方會顯示并且未加載圖片時也會顯示">

          posted @ 2010-05-28 16:31 Qzi 閱讀(231) | 評論 (0)編輯 收藏

          第一:簡單的使用axis2包自己實現調用

          package common;

          import javax.xml.namespace.QName;
          import org.apache.axis2.AxisFault;
          import org.apache.axis2.addressing.EndpointReference;
          import org.apache.axis2.client.Options;
          import org.apache.axis2.rpc.client.RPCServiceClient;

          public class WebServiceUtils
          {
           // ----------------------------------------------------- Properties
           public static int TIMEOUT = 100000;

           // ----------------------------------------------------- Constructors

           // ----------------------------------------------------- Methods
           /**
            *
            * 調用axis2的webservice的方法
            *
            * @return
            */
           @SuppressWarnings("unchecked")
           static public Object[] invokeWebService( String url, String nameSpace, String method, Object[] args, Class[] returnTypes )
             throws AxisFault
           {
            RPCServiceClient serviceClient = new RPCServiceClient();
            Options options = serviceClient.getOptions();
            EndpointReference targetEPR = new EndpointReference( url );
            options.setTo( targetEPR );
            options.setTimeOutInMilliSeconds( TIMEOUT );
            QName opName = new QName( nameSpace, method );
            Object[] results = serviceClient.invokeBlocking( opName, args, returnTypes );
            return results;
           }
          }


          第二:

          public static OMElement getEchoOMElement() {
                  OMFactory fac = OMAbstractFactory.getOMFactory();
                  OMNamespace omNs = fac.createOMNamespace(
                          "http://example1.org/example1", "example1");
                  OMElement method = fac.createOMElement("echo", omNs);
                  OMElement value = fac.createOMElement("Text", omNs);
                  value.addChild(fac.createOMText(value, "Axis2 Echo String "));
                  method.addChild(value);

                  return method;
              }

           public static void main(String[] args) {
                  try {
                     OMElement payload = ClientUtil.getEchoOMElement();
                      Options options = new Options();
                    
                      options.setTo(targetEPR);
                      options.setAction("urn:echo");

                      //Blocking invocation
                      ServiceClient sender = new ServiceClient();
                      sender.setOptions(options);
                      OMElement result = sender.sendReceive(payload);

                      System.out.println(result);
                    
                      System.out.println(options.getTo());

                  } catch (AxisFault axisFault) {
                      axisFault.printStackTrace();
                  }
              }

           
          第三:

          利用插件生成客戶端
          private static String URL="http://localhost:8080/axis2/services/WeatherService"; 
              public static void main(String[] args) throws RemoteException {
                  try {
                      WeatherServiceStub stub;
                      if (args != null && args.length != 0) {
                          stub = new WeatherServiceStub(args[0]);
                        
                      } else {
                          stub = new WeatherServiceStub(URL);
                      }
                      WeatherServiceStub.SetWeather setWether = new WeatherServiceStub.SetWeather();
                      WeatherServiceStub.Weather wether = new WeatherServiceStub.Weather();
                    
                      wether.setForecast("east");
                      wether.setRain(true);
                      wether.setTemperature(12.3f);
                      wether.setForecast("big");
                    
                      setWether.setWeather(wether);
                      stub.setWeather(setWether);
                    
                      WeatherServiceStub.GetWeatherResponse gw = new WeatherServiceStub.GetWeatherResponse();
                      System.out.println(gw.get_return());       
                    
                  } catch (AxisFault e) {
                      // TODO Auto-generated catch block
                      e.printStackTrace();
                  }
              }


          本文部分來自CSDN博客,轉載請標明出處:http://blog.csdn.net/yhhah/archive/2009/05/07/4158487.aspx

          posted @ 2010-01-20 23:16 Qzi 閱讀(10508) | 評論 (0)編輯 收藏

          IE的 script 元素支持onreadystatechange事件,不支持onload事件。
          FF的script 元素不支持onreadystatechange事件,只支持onload事件。
          如果要在一個<script src="xx.js"> 加載完成執行一個操作,FF使用onload事件就行了,IE下則要結合onreadystatechange事件和this.readyState
          var loadScript = function(fileName,callback) {
           var scriptTag = document.createElement("script");
            scriptTag.src = fileName;
            document.body.appendChild(scriptTag);
            if (callback) {
             scriptTag.onload = callback;//ff
             scriptTag.onreadystatechange = function()//ie
             {
              if (scriptTag.readyState == "loaded") {
              callback();
             }
            }
           }
          }

          posted @ 2009-12-11 18:57 Qzi 閱讀(478) | 評論 (0)編輯 收藏

          主站蜘蛛池模板: 云南省| 陆川县| 韶山市| 如皋市| 厦门市| 南投市| 合江县| 白城市| 龙里县| 洛隆县| 邳州市| 保靖县| 剑川县| 承德市| 涿鹿县| 呼伦贝尔市| 和硕县| 天水市| 景东| 布尔津县| 关岭| 永寿县| 信阳市| 安陆市| 余姚市| 丹东市| 同心县| 蓬莱市| 绥棱县| 台湾省| 内江市| 北流市| 吉木乃县| 临武县| 石柱| 宝清县| 保靖县| 泽库县| 邢台市| 普兰店市| 汨罗市|