湖北30选5官方查询 http://www.twubdg.tw 筆記、原創、分享 Sat, 14 Nov 2015 12:33:21 +0000 zh-CN hourly 1 http://wordpress.org/?v=3.6 KVM 虛擬機增加硬盤 http://www.twubdg.tw/kvm-add-storage.html http://www.twubdg.tw/kvm-add-storage.html#comments Sat, 14 Nov 2015 12:32:09 +0000 admin http://www.twubdg.tw/?p=1976 采用模板的方式可能導致虛擬機的硬盤容量不夠,可以通過單獨增加一塊硬盤來作為數據的存儲。
1、首先使用dd命令在默認路徑下創建一個大小為10G的映像文件:

dd bs=1M count=10240 if=/dev/zero of=/var/lib/libvirt/images/guest1_data.img

另外也可以使用 qemu-img 命令來創建,具體可以參考:centos 6.6 安裝 KVM 虛擬機

2、使用virsh edit 命令來編輯 domain 的配置文件,在其中已有的disk 段后增加如下內容:

<disk type='file' device='disk'>
  <driver name='qemu' type='raw' cache='none'/>
  <source file='/var/lib/libvirt/images/guest1_data.img'/>
  <target dev='hdb' bus='ide'/>
  <address type='drive' controller='0' bus='0' target='0' unit='1'/>
</disk>

3、分區格式化以及自動掛載硬盤
使用fdisk -l 查看系統的硬盤,根據上次配置,應該可以看到設備 /dev/sdb,然后使用如下命令進行分區

fdisk /dev/sdb

然后進行格式化

mkfs.ext4	/dev/sdb1

假設把新的硬盤mount 到 /data 目錄,可以采用命令

mount /dev/sdb1 /data 

這種方式如果機器重啟后就需要重新mount,所以可以把他加入到fstab 中,這樣系統啟動時就能自動mount上去

/dev/sdb1   /data   ext4    defaults    0   0    
]]>
http://www.twubdg.tw/kvm-add-storage.html/feed 0
KVM 克隆虛擬機 http://www.twubdg.tw/kvm-clone.html http://www.twubdg.tw/kvm-clone.html#comments Mon, 09 Nov 2015 05:17:30 +0000 admin http://www.twubdg.tw/?p=1973 安裝一個guest系統后安裝一些必要的軟件包。然后把這個系統作為一個模板,采用克隆的方式可以十分快捷的創建另外的guest 系統。通過如下命令即可完成

virt-clone --connect=qemu:///system -o template_centos66  -n new_guest -f /var/lib/libvirt/images/new_guest.img

其中 o (字母o)參數是模板guest系統的domain名, n 參數 為新guest domain 名, f 參數為硬盤鏡像的文件。

]]>
http://www.twubdg.tw/kvm-clone.html/feed 0
virsh 無法重啟和關閉KVM虛擬機 http://www.twubdg.tw/virsh-cannot-reboot-shutdown-kvm.html http://www.twubdg.tw/virsh-cannot-reboot-shutdown-kvm.html#comments Mon, 09 Nov 2015 05:15:52 +0000 admin http://www.twubdg.tw/?p=1971 virsh 可以通過 reboot、shutdown 來重啟或關閉對應的虛擬機。由于其原理是host通過發送acpi指令來控制虛擬機的電源,如果guest 系統沒有安裝acpi服務器或該服務器沒有啟動,那么虛擬機將不會重啟或關閉,那么只有使用destroy 來強制關閉。

安裝 acpid 服務

centos 系統
yum install acpid

ubuntu 系統
apt-get install acpid

開機自動啟動

chkconfig acpid on

啟動服務

/etc/init.d/acpid start

如果啟動acpid服務報錯,那么需要重啟guest 系統。

]]>
http://www.twubdg.tw/virsh-cannot-reboot-shutdown-kvm.html/feed 0
centos 6.6 安裝 KVM 虛擬機 http://www.twubdg.tw/centos-install-kvm.html http://www.twubdg.tw/centos-install-kvm.html#comments Mon, 09 Nov 2015 04:56:17 +0000 admin http://www.twubdg.tw/?p=1966 1、首先檢查系統是否支持kvm,有兩個先決條件

a、系統是x86的,通過命令

uname -a

b、CPU 支持虛擬化技術

egrep 'vmx|svm' /proc/cpuinfo

如果看到有輸出結果,即證明cpu 支持虛擬化。同時特別注意需要檢查 BIOS 中是否開啟VT,如果沒有啟用,虛擬機將會十分慢

2、使用yum安裝kvm

安裝kvm內核
yum install -y qemu-kvm.x86_64 qemu-kvm-tools.x86_64

安裝virt管理工具
yum install libvirt.x86_64 libvirt-cim.x86_64 libvirt-client.x86_64 libvirt-java.noarch libvirt-python.x86_64

加載kvm 內核

modprobe kvm
modprobe kvm-intel

查看內核是否開啟

modprobe -ls | grep kvm

3、配置網絡橋接,
進入目錄 /etc/sysconfig/network-scripts,復制一份原有的ifcfg-eth0 為 ifcfg-br0

cp ifcfg-eth0 ifcfg-br0

修改ifcfg-br0,內容如下:

DEVICE="br0"
BOOTPROTO=static
ONBOOT="yes"
TYPE="Bridge"
IPADDR=192.168.31.60
GATEWAY=192.168.31.1
NETMASK=255.255.255.0
DEFROUTE=yes

IPADDR、GATEWAY、NETMASK根據自己的實際情況修改。

修改 ifcfg-eth0, 內容如下:

DEVICE="eth0"
BOOTPROTO=none
NM_CONTROLLED="no"
ONBOOT="yes"
TYPE="Ethernet"
BRIDGE="br0"
HWADDR=F8:DB:88:FF:99:E3
DEFROUTE=yes
IPV4_FAILURE_FATAL=yes
NAME="System eth0"

重啟網絡服務即可。

/etc/init.d/network restart

如果出現問題,關閉 NetworkManager 后重試。

chkconfig NetworkManager off

service NetworkManager stop

4、使用virt-install 工具安裝 guest 系統。

a、創建硬盤映像文件

使用 qemu-img 命令創建
qemu-img create -f raw /var/lib/libvirt/images/test.img 8G

或使用 dd 命令創建
dd bs=1M count=8096 if=/dev/zero of=/var/lib/libvirt/images/test.img

qemu-img 是創建是文件格式是稀疏文件,優點是速度超快,由于是稀疏文件,性能可能會比第二種略差,通過如下命令查看詳情

qemu-img info /var/lib/libvirt/images/test.img

輸出為:注意其中 disk size 為 0

image: test.img
file format: raw
virtual size: 8.0G (8589934592 bytes)
disk size: 0

更多關于稀疏文件的信息,請自行搜索。

b、通過iso文件安裝系統

virt-install --name=test --ram 1024 --vcpus=2 --disk path=/var/lib/libvirt/images/test.img,size=3 --accelerate --cdrom /home/CentOS-6.6-x86_64-minimal.iso --graphics vnc,listen=0.0.0.0 --network bridge=br0 --force --autostart --connect qemu:///system

使用 vnc 客戶端連接,IP 用host的ip,如果是第一個虛擬機,端口為 5900, 如果出現連不上,確認host的iptables的狀態,最好是先關閉iptables。連上后就像安裝系統一樣一步步來安裝即可。

]]>
http://www.twubdg.tw/centos-install-kvm.html/feed 0
使用OpenVPN搭建VPN服務器 http://www.twubdg.tw/openvpn-vpn-server.html http://www.twubdg.tw/openvpn-vpn-server.html#comments Fri, 06 Nov 2015 11:15:59 +0000 admin http://www.twubdg.tw/?p=1959 環境公司內網一臺 CentOS 6.6 服務器 A,網卡eth0 內網IP:192.168.8.60, 公司公網IP為 116.228.12.88, 使用路由器的 DMZ 功能把公網映射到內網服務器A(即內網IP:192.168.8.60)。

1、在服務器上安裝OpenVPN。由于默認的Centos軟件源里面沒有OpenVPN的軟件包,可以通過添加rpmforge的repo,從而實現yum安裝openvpn。
針對CentOS 5

rpm -ivh http://apt.sw.be/redhat/el5/en/x86_64/rpmforge/RPMS/rpmforge-release-0.5.2-2.el5.rf.x86_64.rpm

針對CentOS 6

rpm -ivh http://apt.sw.be/redhat/el6/en/x86_64/rpmforge/RPMS/rpmforge-release-0.5.2-2.el6.rf.x86_64.rpm

注意:服務器是32位還是64位,由于我的服務器安裝centos 是64位,所以上傳安裝的源是64位,如果是32位,可以通過瀏覽地址:http://apt.sw.be/redhat/el6/en 找到對應的版本的地址。

2、生成OpenVPN 所需的證書。

OpenVPN 自帶了 easy-rsa 工具,可以通過它很方便的生成所需的證書。復制 工具目錄到 /etc/openvpn 下并賦予執行權限。

cp -R /usr/share/doc/openvpn-*/easy-rsa /etc/openvpn 
cd /etc/openvpn/easy-rsa/2.0
chmod +x  *

執行下述命令創建證書。

ln -s openssl-1.0.0.cnf openssl.cnf
. vars
./clean-all
./build-ca server
./build-key-server server
./build-key client
./build-dh

3、創建 OpenVPN 的配置文件server.conf, 文件放在 /etc/openvpn

port        1194
proto       tcp
dev         tun
ca          /etc/openvpn/easy-rsa/2.0/keys/ca.crt
cert        /etc/openvpn/easy-rsa/2.0/keys/server.crt
key         /etc/openvpn/easy-rsa/2.0/keys/server.key
dh          /etc/openvpn/easy-rsa/2.0/keys/dh1024.pem
server      10.1.1.0 255.255.255.0

auth-user-pass-verify   /etc/openvpn/auth/checkpsw.sh via-env
script-security 3 system
client-cert-not-required
username-as-common-name

push        "redirect-gateway def1 bypass-dhcp"
push        "dhcp-option DNS 8.8.8.8"
push        "dhcp-option DNS 114.114.114.114"
log         /var/log/openvpn.log
keepalive   10 120
verb        3
client-to-client
comp-lzo
persist-key
persist-tun

其中server 后面對應的IP 是指VPN虛擬的網段,也就是客戶端獲取IP就是在這個段中,注意,不要和現有的局域網IP段有沖突。
auth-user-pass-verify 下面的四行是配置客戶端可以使用用戶名密碼的方式認證,特別注意一定要加上 script-security 3 system, 后面的system 也不能少,我就是在這個上面浪費好多時間。

checkpsw.sh 腳本內容如下:

#!/bin/sh
PASSFILE="/etc/openvpn/auth/psw-file"
LOG_FILE="/etc/openvpn/auth/openvpn-password.log"
TIME_STAMP=`date "+%Y-%m-%d %T"`

if [ ! -r "${PASSFILE}" ]; then
  echo "${TIME_STAMP}: Could not open password file \"${PASSFILE}\" for reading." >> ${LOG_FILE}
  exit 1
fi

CORRECT_PASSWORD=`awk '!/^;/&&!/^#/&&$1=="'${username}'"{print $2;exit}' ${PASSFILE}`

if [ "${CORRECT_PASSWORD}" = "" ]; then
  echo "${TIME_STAMP}: User does not exist: username=\"${username}\", password=  \"${password}\"." >> ${LOG_FILE}
  exit 1
fi

if [ "${password}" = "${CORRECT_PASSWORD}" ]; then
  echo "${TIME_STAMP}: Successful authentication: username=\"${username}\"." >> ${LOG_FILE}
  exit 0
fi

echo "${TIME_STAMP}: Incorrect password: username=\"${username}\", password= \"${password}\"." >> ${LOG_FILE}
exit 1

其中 PASSFILE 是用戶名密碼的文件路徑,LOG_FILE 輸出的日志文件。 注意:checkpsw.sh 需要有執行權限。PASSFILE 的格式為:用戶名+空格+密碼, 例如:

netingcn mypassword

4、啟動OpenVPN并將設置其為開機自動啟動。

啟動服務
/etc/init.d/openvpn start

加入開機自動啟動
chkconfig openvpn on

OpenVPN 服務的日志位于 /var/log/openvpn.log, 如果啟動異常,可以查看該日志,一般情況是由于生產證書那里出現問題,可以重新生成一次。

5、服務器其他設置。
關閉selinux

sed -i '/^SELINUX=/c\SELINUX=disabled' /etc/selinux/config

開啟ip forward

sed -i '/net.ipv4.ip_forward/s/0/1/g' /etc/sysctl.conf 
sysctl -w net.ipv4.ip_forward=1

開啟iptables NAT

iptables -t nat -A POSTROUTING -s 10.1.1.0/24 -j SNAT --to-source 192.168.8.60

特別注意:to source 的值,有些文章提到是公司的公網IP,這個說法有些不太準確,如果該服務器的網卡綁定是公網IP,也就是說作為路由服務器,那么就是用公網IP,由于我的這臺服務器是局域網內的一臺機器,只有局域網IP,所以這里用的是本機的IP。

如果沒有添加iptables 規則,出現的結果是能連上vpn server,但是不能上網。另外可能還需要用到的規則如下:

iptables -A FORWARD -i tun0 -s 10.1.1.0/24 -j ACCEPT
iptables -A FORWARD -i eth0 -d 10.1.1.0/24 -j ACCEPT
iptables -I INPUT -p tcp --dport 1194 -m comment --comment "openvpn" -j ACCEPT
iptables -t nat -A POSTROUTING -s 10.1.1.0/24 -o eth0 -j MASQUERADE

客戶端官網下載地址:https://openvpn.net/index.php/download/community-downloads.html

下面以Win 7 客戶端為例,安裝好客戶端后,打開默認安裝路徑:C:\Program Files\OpenVPN\config, 在下面建立一個 client.ovpn 文件,
證書認證方式的內容如下:

client
dev tun
proto tcp
remote 116.228.12.88 1194
resolv-retry infinite
nobind
persist-key
persist-tun
ca ca.crt
cert client.crt
key client.key
comp-lzo
verb 3
redirect-gateway def1
route-method exe
route-delay 2

需要復制服務器的 ca.crt,client.crt 和 client.key 到當前目錄, remote 用公司公網IP

用戶名密碼認證的方式如下:

client
dev tun
proto tcp
remote 116.228.208.10 2294
resolv-retry infinite
nobind
persist-key
persist-tun
ca ca.crt
;auth-user-pass
auth-user-pass pass.txt
comp-lzo
verb 3
redirect-gateway def1
route-method exe
route-delay 2

只需要復制服務器的 ca.crt 到當前目錄即可,同時在當前目錄建立一個名為 pass.txt,把用戶名密碼填入,注意格式為:

用戶名
密碼

至此配置完成,右鍵點擊客戶端然后選connect,應該就可以連上。

]]>
http://www.twubdg.tw/openvpn-vpn-server.html/feed 0
git之臨時忽略文件 http://www.twubdg.tw/git-temporary-ignore.html http://www.twubdg.tw/git-temporary-ignore.html#comments Thu, 09 Jul 2015 04:15:29 +0000 admin http://www.twubdg.tw/?p=1949 git 中要在版本庫中忽略某些文件,第一選擇選擇應該是使用 “.gitignore” 配置文件,該方式是永久忽略,如果要忽略某個已經在版本庫中的文件,那么先要從版本庫中移除,然后.gitignore中的配置才會生效。

git 還有一種臨時忽略文件的方式,命令為:

git update-index --assume-unchanged

這種方式忽略可以讓該文件還繼續保留在版本庫中,但是本地修改文件后,不會提示有修改,也就不需要提交。

既然是臨時忽略,那么也可以解除臨時忽略,命令為:

git update-index --no-assume-unchanged

如果時間久了,自己都不記得那些文件是臨時忽略的該怎么辦?可以使用命令:

git ls-files -v

這個命令將列出所有文件的狀態,文件名前面符號含義如下:

   H
       cached

   h
       Assume Unchanged 

   S
       skip-worktree

   M
       unmerged

   R
       removed/deleted

   C
       modified/changed

   K
       to be killed

   ?
       other

當文件比較多時,還可以借助 grep 命令來篩選,例如:

git ls-files -v| grep '^h'

git 既然支持 alias,可以通過配置alias來簡化操作,編輯 .gitconfig 文件,把下述配置加入到 alias 段即可

hide = update-index --assume-unchanged

unhide = update-index --no-assume-unchanged

ignored = !git ls-files -v | grep "^h"
]]>
http://www.twubdg.tw/git-temporary-ignore.html/feed 0
jquery on() 方法綁定動態元素 http://www.twubdg.tw/jquery-on-append.html http://www.twubdg.tw/jquery-on-append.html#comments Wed, 08 Jul 2015 04:26:40 +0000 admin http://www.twubdg.tw/?p=1943 jQuery on()方法是官方推薦的綁定事件的一個方法。使用 on() 方法可以給將來動態創建的動態元素綁定指定的事件,例如append等。

<div id="test">
    <div class="evt">evt1</div>
</div>

錯誤的用法,下面方法只為第一個class 為 evt 的div 綁定了click事件,使用append動態創建的div則沒有綁定

<script>
    // 先綁定事件再添加div
    $('#test .evt').on('click', function() {alert($(this).text())});
    $('#test').append('<div class="evt">evt2</div>');
</script>

正確的用法如下:

<script>
    $('body').on('click', '#test .evt', function() {alert($(this).text())});
    $('#test').append('<div class="evt">evt2</div>');
</script>
]]>
http://www.twubdg.tw/jquery-on-append.html/feed 0
uploadify 發送多余請求的問題 http://www.twubdg.tw/uploadify-useless-request-issue.html http://www.twubdg.tw/uploadify-useless-request-issue.html#comments Wed, 08 Jul 2015 03:04:44 +0000 admin http://www.twubdg.tw/?p=1935 使用 uploadify 上傳控件上傳圖片時,發現當uploadify.swf加載完成后會再次發送一個請求,假設當前頁的URL是 http://www.twubdg.tw/demo/upload-test.php, 那么可以在瀏覽器中發現這個地址http://www.twubdg.tw/demo/的請求。想要讓其不發送這個多余請求,解決辦法是修改對應的js,在 js 中找到如下代碼:

this.settings.button_image_url=SWFUpload.completeURL(this.settings.button_image_url);

將上面的代碼修改為如下即可。注意可能某些版本中“=”前后會有空格,查找的時候可以只用 this.settings.button_image_url 這段作為關鍵詞

this.settings.button_image_url = this.settings.button_image_url ?  SWFUpload.completeURL(this.settings.button_image_url) : this.settings.button_image_url;
]]>
http://www.twubdg.tw/uploadify-useless-request-issue.html/feed 0
mysql 命令自動補齊 http://www.twubdg.tw/mysql-completion.html http://www.twubdg.tw/mysql-completion.html#comments Sun, 05 Jul 2015 16:09:04 +0000 admin http://www.twubdg.tw/?p=1933 mysql命令行工具自帶這個功能,但是默認是禁用的。想啟用其實很簡單,打開配置文件找到no-auto-rehash,用符號 # 將其注釋,另外增加auto-rehash即可。

[mysql]
#no-auto-rehash
auto-rehash
]]>
http://www.twubdg.tw/mysql-completion.html/feed 0
git 命令自動補全 http://www.twubdg.tw/git-completion.html http://www.twubdg.tw/git-completion.html#comments Sun, 05 Jul 2015 15:56:48 +0000 admin http://www.twubdg.tw/?p=1930 只需要完成下面兩部,就可以實現在mac osx 下git 命令自動補齊

首先下載自動補齊腳本,使用curl命令如下:

curl https://raw.githubusercontent.com/git/git/master/contrib/completion/git-completion.bash -o ~/.git-completion.bash

編輯.profile 文件,在最后增加如下代碼:

if [ -f ~/.git-completion.bash ]; then
    source ~/.git-completion.bash
fi

重啟終端后應該就可以愉快的使用tab來自動補全了。

]]>
http://www.twubdg.tw/git-completion.html/feed 0
30选5怎么中奖