2014年6月25日星期三

Node.js implements Google API in Command Line

很高興在Google IO Taipei講了一場關於Node.js跟BigQuery結合的分享
跟杭JS同樣的講題,但補充了sql2bq與gcli兩個套件
其中gcli是idea自google api explore裡面的api結構
關於gcli可以參考Github: https://github.com/peihsinsu/gapis
下面簡介一下CLI操作上跟API Explore的對應:

1. "-a [api name]": 帶入的api name是關於目前使用的api是哪一個,其中名稱的簡寫通常是右邊的function名稱的第一個,在這邊即是compute這個字。另外"-v [version]"則是帶入欲操作的api version


2. "-s [scope]"讓操作當下帶入認證所需要的scope資訊,可以讓工具所取到的access token可以binding所給予的授權,增加安全性... 



3. "-f [function name]",這邊指的就是"compute.images.list"這串字,讓使用者可以直接敲入api的function結構去使用每一個google的api


4. "-d [conditions]"是讓您放入網址列的變動參數部分,例如某個操作用到這樣的網址:https://www.googleapis.com/bigquery/v2/projects/mitac-cp300/queries,其中紅色部分是提供在網址列嵌入的,這是REST API的一個特性,我們把它用"-d"的方式來帶入指令...,與scope一樣,可以透過多個-b來輸入多個參數


5. "-b [body]"是用來帶入API call中的一些payload參數,讓屬於post form的一些參數可以直接被帶入做查詢...,與scope一樣,可以透過多個-b來輸入多個參數


於是,整個操作就會類似下面這樣:


2014年4月16日星期三

OpenSSL 1.0.1g update note

For prevent the heartbleed bug, update the centos 6.5 to new version openssl

# Get the source and compile
wget https://www.openssl.org/source/openssl-1.0.1g.tar.gz -O openssl-1.0.1g.tar.gz

tar -zxf openssl-1.0.1g.tar.gz
cd openssl-1.0.1g
./config
make
make test
make install

# Update the real config
mv /usr/bin/openssl /root/
ln -s /usr/local/ssl/bin/openssl /usr/bin/openssl

# Check
$ openssl version
OpenSSL 1.0.1g 7 Apr 2014

Eclipse Content Assist

Eclipse中如果欲操縱物件下的method時候
通常在物件打完後打"."就會有可以操作的method提示
而這時候如果不小心按了其他按鈕...提示就會消失
怎麼透過快速鍵來重新叫出提示呢.....

從Eclipse Preferences > General > Keys中
尋找"content assist"部分
然後滑鼠點進下方的Binding的部分,再鍵盤上面操作自己想要的快速鍵
例如:Alt + / 



確認後就可以在編輯器中實驗....





2014年3月11日星期二

Add Tomcat to Service

一般透過yum或apt-get安裝tomcat後,常常因為安裝的目錄結構被重新分配過,而造成原本deploy的方法不適用... 而自己下載安裝的版本,卻又因為缺少/etc/init.d下的執行檔而無法讓他在reboot的時候自動啟動,下面是透過設定好Linux下服務的相關Service Start Script,並將他加入到服務中...


STEP: 增加啟動/關閉腳本,其中藍色部分是重點,必須要填寫此部分才能夠讓chkconfig識別

vi /etc/init.d/tomcat

#!/bin/bash

# description: Tomcat Start Stop Restart

# processname: tomcat

# chkconfig: 345 20 80


export JAVA_HOME=/usr/lib/jvm/jdk1.7.0_45

export TOMCAT_HOME=/opt/apache-tomcat-7.0.50


case $1 in

start)

       sh $TOMCAT_HOME/bin/startup.sh

       ;;

stop)

       sh $TOMCAT_HOME/bin/shutdown.sh

       ;;

restart)

       sh $TOMCAT_HOME/bin/shutdown.sh

       sh $TOMCAT_HOME/bin/startup.sh

       ;;

status)

       ps -ef | grep tomcat

       ;;

esac

exit 0


STEP2: 設定可執行權限給user

chmod 755 /etc/init.d/tomcat


STEP3: 設定rc1.d, rc2.d

ln -s /etc/init.d/tomcat /etc/rc1.d/K99tomcat

ln -s /etc/init.d/tomcat /etc/rc2.d/S99tomcat


STEP4: 使用chkconfig增加到服務

chkconfig --add tomcat

2013年10月14日星期一

Noder add Markdown project read support

常常在用Markdown做筆記,但是市面上Markdown的Editor都太heavy
所以就在noder上加了md review的功能..
因為是以project為base,所以頁面的layout會需要帶入menu頁面
如果未指定,目前左邊會空一小塊出來...找時間再調整他...
操作如下,請享用 :D

使用Noder讀取Markdown專案

目前新增了讀取本地端Markdown file的功能,您可以透過下面指令開啟md讀取功能

    $ noder -m XXX.md  

上面指令將會以XXX.md作為側邊的menu,並將瀏覽的md檔案render在main block中,整體性的顯示。


2013年10月7日星期一

Java中Collection的操作,可以透過Collections.singleton()來移除相似內容的元素:

import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;

public class TestMain {
  public static void main(String args[]) {
    String init[] = { "One", "Two", "Three", "One", "Two", "Three" };
    
    List list1 = new ArrayList(Arrays.asList(init));
    List list2 = new ArrayList(Arrays.asList(init));
    
    // 移除list1中的第一個出現的"One"
    list1.remove("One");
    System.out.println("List1 value: "+list1);
    
    // 移除"One"
    list2.removeAll(Collections.singleton("One"));           
    System.out.println("The SingletonList is :"+list2);
 }
}

執行結果:

List1 value: [Two, Three, One, Two, Three]

The SingletonList is :[One, Two, Three, One, Two, Three]

2013年8月21日星期三

Setting rsync service on SmartOS

Rsync是一套歷久彌新的Linux/Unix系統備份工具,透過rsync可以達到差異的備份方式,讓整個備份的動作可以更有效能的執行... 而MiCloud上提供的主機預設都預載有rsync的功能,而Linux上使用可能大家已經有嚐試過,這邊複習一下,也順便說一下Windows (沒錯,Windows上也可以透過rsync來將資料備份到遠端的rsync server上唷!)上操作rsync的方式。

Rsync Server設定

Step 1: 編輯設定檔
$ vi /etc/rsync.conf
內容:
log file = /tmp/rsyncd.log
pid file = /tmp/rsyncd.pid
port=873
[backup]
hosts allow = 192.168.1.10              #允許的clisnt IP
hosts deny = *                          #除上面allow設定的IP,不允許存取的Client,請設為* 全部
comment = ewant upload file backup
path = /home/backup/upload
uid = root
gid = root
auth users =backup
secrets file = /etc/rsyncd.secrets
read only = no
exclude = temp/ .*                      #要排除的備份檔案或目錄,須以空格區分

設定檔中的backup是備份的模組,這個名稱可以自由取,將會用在client端操作指令上

Step 2: 編輯密碼檔
$ vi /etc/rsyncd.secrets
內容:
backup:xxxxxxxxxxxxxxxxx

上面rsyncd.secrets文件中是存放"帳號:密碼"的內容,最後,密碼檔案必須將權限變更為600,不然連線上會有異常...

Step 3: 啟動服務
$ rsync --daemon --config=/etc/rsync.conf --no-detach

啟動服務的部份,如果沒有加上--no-detach的話,則服務會啟動在背景運作

Client端操作(SmartOS/Linux/Mac)

大部分的Linux/Unix系統都有預載rsync了,這部份部戲談安裝部分...

Step 1: 編輯密碼檔
$ vi .rsync
內容:
xxxxxxxxxxxxxxxxx

此步驟勢將server side step 2中設定的密碼部分寫入密碼檔,檔案位置存放在可以讀取的位置即可,名稱也不拘,之後指令需要指定密碼檔的路徑與名稱

Step 2: 執行同步
client端的同步指令如下:
rsync -avz --password-file=[密碼檔][欲同步資料夾] backup@[rsync server ip位置]::[模組名稱]
範例:
$ rsync -avz --password-file=.rsync /tmp/test backup@192.168.1.10::backup


Client端操作(Windows)

Windows的安裝,請至: https://www.itefix.no/i2/cwrsync-get 取得安裝檔,安裝與基本的操作可以參考官方文件。安裝完成後,需要設定環境變數PATH可以吃得到安裝的目錄下的bin,這樣才可以使用到下面的rsync指令,我所安裝的版本因為只有cygrsync.exe,這邊我直接做一個快捷,命名為rsync.cmd,這樣日後操作上比較方便。

Step 1: 編輯密碼檔
同Linux系列的Step 1

Step 2: 執行同步
指令的操作部分,指令格式不便,但因為系統先天性差別,路徑的寫法稍微與Linux系列有所不同...
  • 其中路徑仍然只吃"/"而不是Windows慣用的"\"
  • 針對磁碟位置的定義,最前面要加上"/cygdrive",例如: c:/opt/rsync.conf,則路徑定義為:/cygdrive/c/opt/rsync.conf
  • 操作人員,不能是Administrator (這部份滿怪的,但是實際上操作如果是Administrator,則會出現"password file must be owned by root when running as root"的錯誤,說明文件在這裡)
範例:
$ rsync -avz --password-file=/cygdrive/c/Users/simon/.rsync /cygdrive/d/tmp/test backup@192.168.1.10::backup

不透過Rsync Server,直接做Rsync

架設rsync server雖然說不難,但是終究多了個餓步驟,其實rsync也可以像scp一樣直接來的... 指令如下:

rsync -r [預備份資料] [備份目的地]

範例:
$ rsync -r /cygdrive/d/tmp/test backup@192.168.1.10:/home/backup/upload

上面操作是針對Windows的系統(路徑有指定了/cygdrive),如果是Linux系列的使用者,直接使用Linux路徑即可∼

參考文獻: