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

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

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

    qqjianyue代碼工

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

    2018年11月3日

    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 閱讀(199) | 評論 (0)編輯 收藏

    2013年4月20日

    官方說明: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 閱讀(303) | 評論 (0)編輯 收藏

    2011年11月29日

    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 閱讀(240) | 評論 (0)編輯 收藏

    2011年9月22日

    參考這篇文章: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 閱讀(9283) | 評論 (0)編輯 收藏

    2011年9月16日

    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 閱讀(326) | 評論 (0)編輯 收藏

    posted @ 2011-09-16 16:59 Qzi 閱讀(263) | 評論 (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 閱讀(616) | 評論 (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 閱讀(516) | 評論 (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 閱讀(389) | 評論 (0)編輯 收藏

    2010年5月28日

    第一種方式:適合于全部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 閱讀(226) | 評論 (0)編輯 收藏

    主站蜘蛛池模板: 伊人久久免费视频| 亚洲自偷自偷精品| 9久9久女女免费精品视频在线观看| 高潮毛片无遮挡高清免费视频| 亚洲免费观看网站| 亚洲不卡av不卡一区二区| 免费a级毛片视频| 国内外成人免费视频| 久草在视频免费福利| 91精品视频在线免费观看| 中国内地毛片免费高清| 免费福利资源站在线视频| 男人的天堂av亚洲一区2区| 2019亚洲午夜无码天堂| 亚洲另类精品xxxx人妖| 亚洲视频一区在线| 亚洲一区二区电影| 91成年人免费视频| 亚洲一级片在线观看| 二区久久国产乱子伦免费精品| 国产精品亚洲玖玖玖在线观看| 久久久久久久久亚洲| 国产亚洲精品精品国产亚洲综合| 免费一级大黄特色大片| 日本黄页网站免费| 日本牲交大片免费观看| 日韩免费福利视频| 国产乱子伦精品免费女| 亚洲AV无码乱码在线观看| 又粗又大又硬又爽的免费视频 | 4455永久在线观免费看| 最近中文字幕电影大全免费版| 久久A级毛片免费观看| 91热久久免费精品99| 免费福利在线播放| 久久WWW免费人成人片| 免费无码黄网站在线观看| 国产成人免费A在线视频| 亚洲国产电影av在线网址| 久久夜色精品国产亚洲av| 亚洲欧洲自拍拍偷午夜色无码|