2011年9月30日 星期五

[KVM]在 TUI 環境下建置 Virtualized guest

   如果妳有 X Window,不管是在 VM Server 也就是 『Host』 或是另一台『Desktop』,妳都可以利用『Virt-Manager』進行相當完整且深入的管理,基本上除非有特別的嗜好,否則並沒有非得在 TUI 環境下建置 VM guest 的必要,而且,只能使用 TUI 的環境來建置 VM guest 的狀況在實務上幾乎是不存在的。

    不過,如果要談在 TUI 環境下來管理妳的 VM ,不從建置開始談好像有點不完整,所以這邊還是從如何建置一台全新的  VM guest 開始談起。

   以下都是從我的筆電使用 ssh 遠端連線到 VM Server 進行實作,使用到的工具有『virsh』、『virt-install』及『vinagre』。

    妳可以選擇進到『virsh』或是在 TUI 使用 Command 來建置 VM guest ,不過事實上是同一件事,這邊是選擇 進到『virsh』。

    所要建置的VM guest 規劃如下,

        a.OS : Ubuntu 10.04.3 Server
        b.Architecture : X86_64
        c.CPU *1 / RAM : 1024 MB
        d.HD : Format : qcow2 size: 8G
        e.Network : Bridge:br0
        
    1. 建立虛擬硬碟

        如果不需要指定虛擬硬碟的格式可以跳過這一步。

        a. 列出現有 Storage Pool 清單

            主要是要確認一下 Storage Pool 的名稱,因為我打算將虛擬硬碟的映像放在『VM-Image』這個 Storage Pool 中。


virsh # pool-list --all

名稱               狀態                    自動啟動
-----------------------------------------                                                    
default                啟用                yes     
image                 啟用                yes     
VM-Image           啟用                yes
Iso                     非啟用中           yes    





    



        b. 產生虛擬硬碟     

virsh # vol-create-as --format qcow2 VM-Image test.qcow2.img 8G
Vol test.qcow2.img created




        也可以使用『kvm-image』來產生虛擬硬碟,不過要到使用『virt-install 』建置 VM quest 之後 『virsh』才能管理這顆虛擬硬碟。

max@riyu:~$ kvm-img create -f qcow2 /media/SDA3/VmImage/disk.qcow2.img 8G    
Formatting '/media/SDA3/VmImage/disk.qcow2.img', fmt=qcow2 size=8589934592 encryption=off cluster_size=0





        確認一下

virsh # vol-list VM-Image
名稱                                    Path                                  
-----------------------------------------
test.qcow2.img       /media/SDA3/VmImage/test.qcow2.img    




       

    2. 建置 VM guest

      依照規劃需要下一串又臭又長的命令來作這件事。

       退出『virsh』後,使用如下命令來建置一台 VM guest

max@riyu:~$ virt-install \
> --connect qemu:///system \
> --name=Test \
> --vcpus=1 \
> --arch=x86_64 \
> --ram=1024 \
> --os-type=linux \
> --virt-type=kvm \
> --cdrom=/media/SDC7/001.LinuxISO/ubuntu-10.04.3-server-amd64.iso \
> --disk path=/media/SDA3/VmImage/test.qcow2.img,size=8 \
> --force \
> --network bridge=br0,model=virtio \
> --vnc  --vncport=5900
Traceback (most recent call last):
  File "/usr/lib/python2.6/logging/handlers.py", line 71, in emit
    if self.shouldRollover(record):
  File "/usr/lib/python2.6/logging/handlers.py", line 144, in shouldRollover
    msg = "%s\n" % self.format(record)
  File "/usr/lib/python2.6/logging/__init__.py", line 648, in format
    return fmt.format(record)
  File "/usr/lib/python2.6/logging/__init__.py", line 439, in format
    s = self._fmt % record.__dict__
UnicodeDecodeError: 'ascii' codec can't decode byte 0xe4 in position 1: ordinal not in range(128)



Starting install...
Creating domain... 0 B 00:00
Unable to connect to graphical console: virt-viewer not installed. Please install the 'virt-viewer' package.
Domain installation still in progress. You can reconnect to
the console to complete the installation process.





       
    接下來要透過 VNC 進到剛出生的 VM quest 來進行作業系統的安裝,不過要從遠端主機透過VNC 連到 VM quest 還需要動一些手腳而且有點安全上的疑慮,所以這邊就直接利用 ssh 的『X11Forwarding』將從 VM Server 透過 VNC 連到 VM quest 的畫面送到我的筆電。

    3. 重新連線到 VM Server

         要記得開啟 『X11Forwarding』。

max@minako:~$ ssh -X max@10.0.0.100                    





    4. 從 VM Server 端啟動『vinagre』       

max@riyu:~$ vinagre localhost:5900                   


   


    由於這次連線已經啟動了『X11Forwarding』,所以『vinagre』的執行畫面會送回筆電。



        之後就跟一般安裝作業系統的程序一樣,作業系統安裝完畢,妳就有一台  VM 可以用啦。     


virsh # list 
 Id 名稱                  狀態
----------------------------------
  6 Test                 執行中
                   

2011年9月21日 星期三

[Bash Script]將筆電中的資料備份到備份主機 (V201109210305)

前一版邏輯有嚴重錯誤而且寫得太囉唆了,全部重寫~~~~~~~
ChangeLog
1. if 條件判斷改用設檢查旗標的方式同時用了『複合條件判斷』以濃縮長度。
2.『全變數化』以方便維護跟新增備份標的。

筆電中放著不少重要資料,還是備份一下比較安心。

條件一樣是,
1.筆電在家且連得到備份主機才進行備份
2.自動砍掉三天以前的備份

Script 內容如下,

#!/bin/bash
#DailyBackUpV201109210305.sh
#備份筆電中的重要資料
#Verio:3.0
#Time:201109210305
#Max Lin max@mpsstudio.org

#定義變數
LogFile="$HOME/BackUpLog/DailyBackUp.log"
RemoteHost="10.128.0.100"
TEMPDir="/tmp/DocBack"
LXDETEMPDir=""$TEMPDir"/LXDE"
ScriptTEMPDir=""$TEMPDir"/Script"
DocTEMPDir=""$TEMPDir"/Doc"
MyPassWord="1979576"
MyAccount="亞利安人"
MountHomeDir='/home/max/sharedir'
LocalMountDir=""$MountHomeDir"/100DocBackup"
RemoteHostMountOption="rw,noperm,nosuid,username="$MyAccount",password="$MyPassWord",iocharset=utf8,codepage=cp950"
LXDEBackDir="/home/max/.config/lxpanel/LXDE/"
ScriptBackDir="/home/max/Script"
DocMountPoint="/media/DATABack"
DocBackDir=""$DocMountPoint"/002.文件/"

#Start

#確認遠端備份主機連線狀態
ping -c 2 $RemoteHost > /dev/null
ConnectCheck=$?

#確認備份儲存目錄是否已掛載
mount | grep "100DocBackup" > /dev/null
RemoteHostMountCheck=$?
if [ $RemoteHostMountCheck -ne '0' ] ; then

#掛載遠端文件備份掛載目錄
echo "$MyPassWord" | sudo -S mount -t cifs //"$RemoteHost"/DocBackup "$LocalMountDir" -o "$RemoteHostMountOption"
RemoteHostMountCheck=$?
else
RemoteHostMountCheck=0
fi


if [ $ConnectCheck -eq '0' -a $RemoteHostMountCheck -eq '0' ]; then

echo "`date '+%Y%m%d'` ---- 備份作業開始 --------" >> $LogFile
echo "`date '+%Y%m%d'` ==== 備份開始時間`date '+%H:%M:%S'`" >> $LogFile

#備份LXDE設定檔
mkdir -p "$LXDETEMPDir"
tar jcvf "$LXDETEMPDir"/LXDEConfigBackUp`date '+%Y%m%d'`.tar.bz2 "$LXDEBackDir"
LXDETar=$?
cp -r "$LXDETEMPDir"/* "$LocalMountDir"
LXDECpCheck=$?

if [ $LXDETar -eq '0' -a $LXDECpCheck -eq '0' ] ; then
echo "`date '+%Y%m%d'` LXDE設定檔備份作業完成~~~" >> $LogFile
else
echo "`date '+%Y%m%d'` LXDE設定檔備份作業未完成!!!!" >> $LogFile
fi


#備份Script
mkdir -p "$ScriptTEMPDir"
tar jcvf "$ScriptTEMPDir"/ScriptBackUp`date '+%Y%m%d'`.tar.bz2 "$ScriptBackDir"
ScriptTar=$?
cp -r "$ScriptTEMPDir"/* "$LocalMountDir"
ScriptCpCheck=$?
if [ $ScriptTar -eq '0' -a $ScriptCpCheck -eq '0' ] ; then
echo "`date '+%Y%m%d'` Script備份作業完成~~~" >> $LogFile
else
echo "`date '+%Y%m%d'` ScriptCpCheck備份作業未完成!!!!" >> $LogFile
fi

#文件備份
mkdir -p "$DocTEMPDir"
mount | grep "$DocMountPoint"
DocMountPointCheck=$?
if [ $DocMountPointCheck -eq '0' ] ; then
tar jcvf "$DocTEMPDir"/DocBackUp`date '+%Y%m%d'`.tar.bz2 "$DocBackDir"
DocTar=$?
cp -r "$DocTEMPDir"/* "$LocalMountDir"
DocCpCheck=$?
else
echo "$MyPassWord" | sudo -S mount -t ext4 /dev/sda4 "$DocMountPoint"
ReMountCheck=$?
if [ $ReMountCheck -eq '0' ] ; then
tar jcvf "$DocTEMPDir"/DocBackUp`date '+%Y%m%d'`.tar.bz2 "$DocBackDir"
DocTar=$?
cp -r "$DocTEMPDir"/* "$LocalMountDir"
DocCpCheck=$?
DocMountPointCheck=0
else
DocMountPointCheck=1
fi

fi
if [ $DocMountPointCheck -eq '0' -a $DocTar -eq '0' -a $DocCpCheck -eq '0' ]; then

echo "`date '+%Y%m%d'` Doc備份作業完成~~~" >> $LogFile
else
echo "`date '+%Y%m%d'` Doc備份作業未完成!!!!" >> $LogFile
fi

#刪除暫存目錄
rm -rf $TEMPDir
#刪除遠端備份目錄中三天前的備份檔
find ""$LocalMountDir"/" -type f -mtime +3 -exec rm -f {} \;
#確認文件備份目錄是否還掛載著
mount="$DocMountPoint"
DocMountPointCheck=$?
if [ $DocMountPointCheck -eq '0' ] ; then
#卸載遠端備份目錄
echo "$MyPassWord" | sudo -S umount "$DocMountPoint"
fi
#確認備份儲存目錄是否仍掛載
mount | grep "$LocalMountDir" > /dev/null
RemoteHostMountCheck=$?
if [ $RemoteHostMountCheck -eq '0' ] ; then
#卸載遠端備份目錄
echo "$MyPassWord" | sudo -S umount "$LocalMountDir"
fi
echo "`date '+%Y%m%d'` ==== 備份結束時間`date '+%H:%M:%S'`" >> $LogFile
echo "`date '+%Y%m%d'` >>>> 備份作業完成 <<<<<<<<" >> $LogFile
else

echo "`date '+%Y%m%d'` 遠端備份目錄離線中或無法掛載遠端儲存設備,備份作業未開始!!!!"

fi                         

2011年9月19日 星期一

[Bash Script]如果Routing Table 出現兩筆 Default Gateway 怎麼辦?

    因為家裡的動物機群跟一般主機分屬於兩個不同網段同時分別透過兩台IP分享器連網,我在家時為了方便筆電會用有線連『動物機群網段』,同時用無線網卡連到『一般主機網段』。

    可是每次開機時因為同時有兩張網卡(有線+無線)所以就會得到兩個 『DefaultGateway』,有兩個『DefaultGateway』基本上就跟沒有『DefaultGateway』是一樣的,會無法連線,所以老是要手動刪掉『動物機群網段』的『DefaultGateway』,有點煩了所以寫隻簡單的Script讓他自動處理這個問題。

    想法很簡單~~~~

    1. 先檢查看看對接到『動物機群網段』的有線網卡『eth0』是不是『DefaultGateway』,如果是就刪掉。

    2. 接著再檢查對接到『一般主機網段』的無線網卡是不是『DefaultGateway』,如果是,那就....... 沒事~~~,如果不是就加上這個『DefaultGateway』。

    Scritp 如下,

#!/bin/bash 
#
# DefaultGatewayCheck.sh
# 自動設定我要的 Default Gateway
# Version:2.0
# 201109190237
# Max Lin max@mpsstudio.org
# 
 
#!/bin/bash
#
Checketh0=`route -n | grep "UG"| grep "eth0"`
Checkwlan0=`route -n | grep "UG"| grep "wlan0"`

if [ "$Checketh0" ] ; then

    echo '28825252' | sudo -S route del default gw 10.128.0.1                        
fi

if [ ! "$Checkwlan0" ] ; then

    echo '28825252' | sudo -S route add default gw 10.0.0.1

fi




































    測試:

1.檢視現有 Routing Table

max@minako:~$ route -n
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
192.168.122.0   0.0.0.0         255.255.255.0   U     0      0        0 virbr0
169.254.0.0     0.0.0.0         255.255.0.0     U     1000   0        0 eth0
10.0.0.0        0.0.0.0         255.128.0.0     U     2      0        0 wlan0
10.128.0.0      0.0.0.0         255.128.0.0     U     1      0        0 eth0
0.0.0.0         10.0.0.1        0.0.0.0         UG    0      0        0 wlan0 
 
    沒有『動物機群網段』的『DefaultGateway』
 
2.加上『動物機群網段』的『DefaultGateway』到 Routing Table
 
max@minako:~$ sudo route add default gw 10.128.0.1 
 
3.確認一下
 
max@minako:~$ route -n
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
192.168.122.0   0.0.0.0         255.255.255.0   U     0      0        0 virbr0
169.254.0.0     0.0.0.0         255.255.0.0     U     1000   0        0 eth0
10.0.0.0        0.0.0.0         255.128.0.0     U     2      0        0 wlan0
10.128.0.0      0.0.0.0         255.128.0.0     U     1      0        0 eth0
0.0.0.0         10.128.0.1      0.0.0.0         UG    0      0        0 eth0
0.0.0.0         10.0.0.1        0.0.0.0         UG    0      0        0 wlan0 
 
  
  『動物機群網段』的『DefaultGateway』在 Routing Table 中 
 
4.執行 Script
 
max@minako:~$ ./CheckGw.sh 
 
5.看一下Routing Table
 
max@minako:~$ route -n
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
192.168.122.0   0.0.0.0         255.255.255.0   U     0      0        0 virbr0
169.254.0.0     0.0.0.0         255.255.0.0     U     1000   0        0 eth0
10.0.0.0        0.0.0.0         255.128.0.0     U     2      0        0 wlan0
10.128.0.0      0.0.0.0         255.128.0.0     U     1      0        0 eth0
0.0.0.0         10.0.0.1        0.0.0.0         UG    0      0        0 wlan0
 
 『動物機群網段』的『Default Gateway』沒了
 
6.刪掉『一般主機網段』的『Default Gateway』
max@minako:~$ sudo route del default gw 10.0.0.1
 
max@minako:~$ route -n
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
192.168.122.0   0.0.0.0         255.255.255.0   U     0      0        0 virbr0
169.254.0.0     0.0.0.0         255.255.0.0     U     1000   0        0 eth0
10.0.0.0        0.0.0.0         255.128.0.0     U     2      0        0 wlan0
10.128.0.0      0.0.0.0         255.128.0.0     U     1      0        0 eth0
 
一筆『Default Gateway』都沒有
 
7.再跑一下Script 
 
max@minako:~$ ./CheckGw.sh 
max@minako:~$ route -n
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
192.168.122.0   0.0.0.0         255.255.255.0   U     0      0        0 virbr0
169.254.0.0     0.0.0.0         255.255.0.0     U     1000   0        0 eth0
10.0.0.0        0.0.0.0         255.128.0.0     U     2      0        0 wlan0
10.128.0.0      0.0.0.0         255.128.0.0     U     1      0        0 eth0
0.0.0.0         10.0.0.1        0.0.0.0         UG    0      0        0 wlan0
 
 
嗯.....有效
 

2011年9月18日 星期日

[Misc]關於 LVM(Logical Volume Manager)的基本概念(無LAB)

      簡單整理一下Linux LVM的一些基本概念。

     首先先複習一下使用一顆實體硬碟的流程~~~

    當妳要加裝一顆硬碟時妳會怎麼做?打開電話簿翻到『好人&馱獸』那一區??

     那妳後面應該都看不懂~~~~~

    使用一顆實體硬碟的流程是....

     1. 首先要有一顆硬碟。
     2. 接著將這顆硬碟裝到電腦上。
     3. 開Power。
     4. 劃分分割區。
     5. 格式化。
     6. 掛載。

     除開不關電源直接裝硬碟、連接線接錯或裝反、硬碟電源線沒裝或是買到籤王等意外,妳現在可以開始用硬碟了。

     我的學生應該都要記得吧?!?!第一堂課的東西.....

     雖然說的跟講義不大相同,不過意思是一樣的。

      接著進入主題.............

1.『Partition』 是建置『Linux LVM』的基本成員,要參加『 LVM』 的『Parition』首先要變身為『PV(Physical Volume)』。

    怎麼變身呢?

    用『 fdisk』 跟他說「你是LVM」......就好了嗎?還早..........

    喔.....前面的意思是所有要參加『LVM』的『Partitiom』都要一一使用『fdisk』指定其『Partition Type』為『8e』。

    接著再用『pvcreate』跟那些『 Partition』 說「你是PV」....這樣就變身完畢了。

2.當所有參加『LVM』的成員都知道自己是『PV』後再使用『vgcreate』將他們群組成一個『VG(Volume Group)』。

    這個時候基本上妳就可以把一個『VG』當成一顆大硬碟。

    其實到這邊還蠻像是在生一個『Raid 0』的感覺,『Raid 0』是將一堆大小不同的實體硬碟合體成一個邏輯大硬碟的技術,所不同的是『Raid 0』只要有一個成員脫團,整個 『Raid 0』就GG 了,『LVM』的話,一個『PV』也就是『Partition』壞掉,換掉就好了。

  到這邊是建置『Linux LVM』的前置作業。

3. 當『VG』合體完畢後你就有了一顆大硬碟,回到一開始提到的實體硬碟使用流程....

     1. 首先要有一顆硬碟。
     2. 接著將這顆硬碟裝到電腦上。
     3. 開Power。
     4. 劃分分割區。
     5. 格式化。
     6. 掛載。

    當然,前三點就不需了,接下來就直接到『 4.劃分分割區』 這個動作。

    接著就是使用『lvcreate』來''劃分''出 『LV(Logical Volume)』了。

    從『VG』中切割出『LV』來用,這一步就像是在切『Partition』一樣。

    現在妳可以將切出來的『LV』掛載到掛載點開始使用他了。

    所以整個『LVM』的建置流程就是,『PV』→『VG』→『LV』。

    LAB的部份....看哪天有空再說。

2011年9月16日 星期五

[JAVA]Install JDK 6.0 & JRE 6.0 on Ubuntu 11.04

雖然Ubuntu 11.04 已經有了『OpenJDK 6.0』,不過還是想換成『SUN』的『JDK』。

1. 打開『synaptic』,點選[設定] => [套件庫],點選「其他軟體」頁籤

將『Canonical 夥伴』及『Canonical 夥伴 (源碼)』勾選起來。
(※  『Canonical 夥伴 (源碼)』可以不用勾,我是順便)


    [關閉]之後記得『重新載入』一下

 
2.在『快速過濾』填入「sun-java-6」,然後選取『sun-java6-jre』、『sun-java6-jdk』、『sun-java6-plugin』
(※ 其他需不需要裝看個人嗜好) 


3.可是系統中還有一個『Openjdk』怎麼辦?

    使用切換程式切換過來,

     切換前:

$ java -version
java version "1.6.0_22"
OpenJDK Runtime Environment (IcedTea6 1.10.2) (6b22-1.10.2-0ubuntu1~11.04.1)
OpenJDK 64-Bit Server VM (build 20.0-b11, mixed mode) 







切換後:

$ sudo update-java-alternatives -s java-6-sun 
[sudo] password for max: 
max@minako:~$ java -version 
java version "1.6.0_26" 
Java(TM) SE Runtime Environment (build 1.6.0_26-b03) 
Java HotSpot(TM) 64-Bit Server VM (build 20.1-b02, mixed mode)









4.設定環境變數

     修改『/etc/environment』

    修改前:

PATH="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games"



修改後:

JAVA_HOME="/usr/lib/jvm/java-6-sun"
PATH="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/lib/jvm/java-6-sun/bin"
CLASSPATH=".:/usr/lib/jvm/java-6-sun/lib:/usr/lib/jvm/java-6-sun/lib/dt.jar:/usr/lib/jvm/java-6-sun/lib/tools.jar"



 

    重登入以後測試一下環境變數,


$ echo $CLASSPATH
.:/usr/lib/jvm/java-6-sun/lib:/usr/lib/jvm/java-6-sun/lib/dt.jar:/usr/lib/jvm/java-6-sun/lib/tools.jar
max@minako:~$ echo $PATH
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/lib/jvm/java-6-sun/bin
max@minako:~$ echo $JAVA_HOME
/usr/lib/jvm/java-6-sun


 
     完工~~~~

[XOOPS]換掉整個 Banner

    預設的Banner我不是很喜歡所以想換掉......

    先打開所使用的版型的『theme.html』,找到下面這一段程式碼,

<!-- customized header contents -->
    <{$xoops_module_header}>
</head>
<body id="<{$xoops_dirname}>" class="<{$xoops_langcode}>">

<!-- Start Header -->
<table cellspacing="0">
    <tr id="header">
        <td id="headerlogo"><a href="<{xoAppUrl /}>" title="<{$xoops_sitename}>"><img src="<{xoImgUrl xoops-logo.png}>" alt="<{$xoops_sitename}>" /></a></td>
        <td id="headerbanner"><{$xoops_banner}></td>
    </tr>
    <tr>
        <td id="headerbar" colspan="2">&nbsp;</td>
    </tr>
</table>
<!-- End header -->















接著就妳高興怎麼改就怎麼改啦~~~

當然前提是要看得懂 html 跟那些 XOOPS 變數的意義......

[XOOPS]特定使用者登入後才出現的物件

    如果希望某個連結是在特定帳號登入後才出現,可以透過下列程式碼來達成這個效果,

<{if $xoops_uname == '特定帳號' }>
  <a href="<{xoAppUrl 想要出現的連結}>" style="text-decoration:none"
     target="_self"><font color="#3367FF">[ 連結顯示名稱 ]</font></a>
<{/if}>








特定帳號登入前:


特定帳號登入後:

[XOOPS] 使用者登入後才顯示歡迎詞

如果要在使用者登入後才顯示歡迎詞可以在 Theme 的『theme.html』中加上下列程式碼在要出現歡迎詞的地方。

 <{if $xoops_uname }>
          歡迎詞 !!!
<{/if}>
                                       








登入前:


登入後:

2011年9月14日 星期三

[KVM]使用『Virt-manager』管理KVM - 建立 VM

    由於我是在 Ubuntu 11.04 Desktop 上安裝『Virt-manager』,Ubuntu 11.04所收錄的『Virt-manager』是 0.8.6,其他版本的『Virt-manager』在版面上或有不同但是設定的次序是大同小異。

    我主要用過 0.8.2 及 0.8.6 兩個版本 的『Virt-manager』,在這邊主要以 0.8.6 來進行示範。

1. 啟動『Virt-manager』

    我的 Ubuntu 11.04 Desktop 所使用的桌面環境是 LXDE,在畫面左下方的[選單]=>[系統工具]中看到虛擬機器管理員。


    若是Gnome則是畫面左上角的[應用程式]=>[系統工具] 中可以看到。


    下面是開啟『Virt-manager』的畫面,


2.新增連線

    接著要連線到 KVM 所在的主機

    a.單擊 [檔案] => [Add Connection]


    會出現一個新增連線的設定視窗,


    b. 將『Connect to remote host』勾選起來


    c. 設定連線資訊

        接著就填入連線所需的資訊,然後單擊 [連接( n )]。




    如果是『Virt-manager』0.8.2 就只能用 root 連線到遠端主機。

    d.啟動連線

      雙擊剛剛建立的連線,連線成功會出現密碼輸入視窗。


     
    登入完畢後會列出現有的VM清單。


3.設定 Storage Pool

    這邊規劃將之後建立的VM  image 檔 及 OS 的iso檔分開存放, VM  image 檔放在『/media/SDA3/VmImage』, OS iso檔放在『/media/SDC7/001.LinuxISO』。

    a. 以KVM管理帳號的身份透過 SSH 連到KVM主機

$ ssh max@192.168.1.100                     



b. 新增存放目錄

$ mkdir -p /media/SDA3/VmImage
$ mkdir -p /media/SDA3/Iso                    




c.使用『virsh』定義VM  image 檔 及 OS 的iso檔的存放目錄

        語法如下,

virsh pool-define-as <Name> <Format> - - - - "Path"          

   

         (1). 定義VM  image 檔存放目錄


$virsh pool-define-as VM-Image dir - - - - "/media/SDA3/VmImage"     





        (2). 定義iso 檔存放目錄


$virsh pool-define-as Iso dir - - - - "/media/SDC7/001.LinuxISO/"         




        (3). 列出 Stroage Pool


$ virsh pool-list --all
名稱                  狀態     自動啟動
-----------------------------------------
default              啟用     yes       
image                啟用     yes       
TcViewLite           啟用     yes       
Iso                  非啟用中 no        
VM-Image             非啟用中 no   





   






         (4).啟動新增的Storage Pool 並設為自動啟動


$ virsh pool-start VM-Image                                 
Pool VM-Image started

$ virsh pool-start Iso
Pool Iso started

$ virsh pool-autostart VM-Image
Pool VM-Image marked as autostarted

$ virsh pool-autostart Iso
Pool Iso marked as autostarted
 
$ virsh pool-list --all
名稱               狀態     自動啟動
-----------------------------------------
default              啟用     yes       
image                啟用     yes       
Iso                  啟用     yes       
TcViewLite           啟用     yes       
VM-Image             啟用     yes       

























4.建立VM

    接著我們就使用『Virt-manager』來建立一台VM。

    a.對著剛剛建立的連線單擊右鍵,點擊 [新增]



     輸入 VM 的名稱及選擇安裝方式。


    b.設定OS Type 及 Version


    c. 選取 OS iso 檔





    d.設定 RAM及CPU數量

        設定值最大均不能超過Host所擁有的實體記憶體大小及CPU數量,若是多核心CPU 則不能超過總核心數。


    e. 產生虛擬硬碟

        因為要將VM存在『/media/SDC7/001.LinuxISO/』所以這邊另外選擇存放位置


    f. 點選要存放的 Storage Pool 然後單擊[New Volume]


    g. 新增儲存卷冊

        預設的儲存卷冊名稱會與 VM 同名,副檔名會是『img』,因為這邊所選擇的儲存卷冊格式為『qcow 2』所以在副檔名前再加上『.qemu』以為標示。

        記得要設定儲存卷冊容量的最大值,這邊是設定為約6Gb的大小。


    點選剛剛新增的儲存卷冊


    f. 設定網路卡

        我們可以選擇使用『NAT』虛擬網路,若 Host有建立橋接網路卡也可以選擇『Specify shared device name』。

        由於網路卡相關設定可以在VM建立之後再變更設定,所以這邊先選用『NAT』虛擬網路。

     另外,Virt-type 選擇『kvm』,Architecture選擇『x86_64』。


    單擊『完成』就產生一台VM,之後會直接進入OS安裝畫面。

2011年9月12日 星期一

[Linux] Chrome 與 scim 合不來的解法~~~

IBus 的中文輸入法實在需要高深的技巧才能好好的用,所以只好換成 scim~~~

換完之後.......Chrome(Google Chrome、Google Brower、Google 瀏覽器) 與 scim 居然合不來mmmmmm囧~

.Chrome沒辦法使用scim的中文輸入.....怎麼辦呢?

要改一下『/etc/X11/xinit/xinput.d/scim』。

$ sudo vim /etc/X11/xinit/xinput.d/scim                          




將『GTK_IM_MODULE=xim』及『QT_IM_MODULE=xim』改成『GTK_IM_MODULE=scim』及『GTK_IM_MODULE=scim』。

#GTK_IM_MODULE=xim
#QT_IM_MODULE=xim

GTK_IM_MODULE=scim
QT_IM_MODULE=scim                                              







存檔後再重新載入scim的設定檔即可。

2011年9月11日 星期日

[LXDE] LXDE 調校及使用紀錄 on Ubuntu 11.04 之桌面工作階段設定

改用LXDE後發現『電源管理』、『藍芽管理』、『音量控制』還有『網路管理』等工具的圖示並沒有出現在桌面右下方的啟動匣中,顯然並沒有在登入時自動啟動。

在網路上找到的解法多半是以修改啟動設定檔的方式來呼叫對應工具。

不過,使用LXDE所提供的『桌面工作階段設定』會更方便。

『桌面工作階段設定』在『偏好設定』中可以找到。


將要在登入時自動啟動的工具勾選起來。

重新登入後就會在桌面右下方的啟動匣中看到『電源管理』、『藍芽管理』、『音量控制』還有『網路管理』等工具的圖示了。


[LXDE] LXDE 調校及使用紀錄 on Ubuntu 11.04 之電源管理工具

    LXDE 好像沒有提供電源管理的工具,所以借用Gnom的『gnome-power-manager』。

1. 如果使用的是Lubuntu可以另外把他裝起來,
 $ sudo apt-get install gnome-power-manager                           



2. 如果是裝Ubuntu 11.04 之後再加裝 LXDE 的話就可以直接使用,
$ gnome-power-manager                                                           

         
    在右下方的啟動匣中就會看到電源管理工具的圖示。

3. 要讓『gnome-power-manager』在開機時自動啟動要編輯  『/etc/xdg/lxsession/LXDE/autostart』,
 $ sudo vim /etc/xdg/lxsession/LXDE/autostart                                        


 
    將『@gnome-power-manager』 加上去。
@xscreensaver -no-splash
@lxpanel --profile LXDE
@pcmanfm --desktop --profile LXDE @/usr/lib/policykit-1-gnome/polkit-gnome-authentication-agent-1 @gnome-power-manager  #<-----加上這一行




Update:
其實直接使用『桌面工作階段』會更方便。
http://www.mpsstudio.org/2011/09/lxde-lxde-on-ubuntu-1104.html


※ Reference : http://silvervine-ninelives.blog.so-net.ne.jp/2010-08-27-1   

2011年9月8日 星期四

[Ubuntu]不用輸入密碼使用 sudo 的方法

當我們要在Ubuntu使用特權命令時,需要在命令前面加上一個sudo

$ sudo apt-get update
[sudo] password for max:                                               




輸入密碼後就可以執行。

但如果要在Script中使用需要root權限的命令,並在無人看守的時候執行這隻Scrip
要叫誰來輸入密碼呢?

有一個簡易的方法可以免手動輸入密碼。

只要使用echo透過pipe就可以將密碼送給sudo了,不過sudo要記得加上『-S』這個option讓sudo從stdin讀取密碼。

$ echo '<Your_Password>' | sudo -S apt-get update