Linux Server 伺服器建置筆記 (用 Ubuntu 設定基礎網路 & SSH伺服器)

這邊整理了一些手動 Linux server 伺服器安裝,需注意的一些事情與指令。
備忘一下以備不時之需。
(如果是設定雲端主機的話,部分步驟可以跳過,它預設都幫你建好了。)

製作可開機 USB (Bootable USB)

使用 UNetbootin 軟體

軟體下載:https://unetbootin.github.io/

選擇 USB drive,選擇 ISO 就可以了
針對目標機器做開機。

Mac 系統的話,可以使用 Etcher
軟體下載:https://www.balena.io/etcher/

做法差不多


選擇作業系統:

  • Debian 系列:可選擇 Ubuntu, Debian
  • RedHat 系列:可選擇 RHEL, CentOS, Fedora
  • BSD 系列:可選擇 FreeBSD
  • SUSE 系列:可選擇 OpenSUSE

前二項是筆者較為熟悉的,推薦 Ubuntu, Debian, CentOS 做為選項。

ISO 的版本很多:

  • Desktop ISO:有一個完整的 Live CD 可供試用
  • Server ISO:有預載一些伺服器使用的套件
  • Minimal ISO:只是檔案小,預設網路驅動了之後,大多都從網路上抓

不知怎麼選擇的話,預設就選 Desktop ISO
(以下撰文用 ubuntu 做示範)

網路指令相關

這邊列出常用的網路指令,如果網路不通的事情,當然要優先處理。

列出網路介面與 IP 位址

$ ip a
$ ip addr show
$ ifconfig

這幾個指令都可以,輸出格式稍有不同。

列出路由閘道 Gateway 設定

$ route -n

設定網路連線資訊

這邊介紹一個新東西:netplan
網路對它介紹不多,但個人覺得非常可以取代目前網路設定不方便的窘境。

假設你要設定的網路連線資訊如下:

  • 目標介面: eth0

  • IP 位址 (IP Address): 192.168.10.200

  • 子網路遮罩 (Netmask): 255.255.255.0 (/24)

  • 網路閘道 (Gateway): 192.168.10.1

  • 主要 DNS 為 8.8.8.8

  • 次要 DNS 為 168.95.1.1

(請根據你的自身環境修改,這裡只是舉例)

只要找到 /etc/netplan/01-netcfg.yaml 這個檔案並編輯

$ sudo vi /etc/netplan/01-netcfg.yaml

修改成類似以下內容:

network:
  version: 2
  renderer: networkd
  ethernets:
    eth0:
      addresses: [192.168.10.200/24]
      gateway4: 192.168.10.1
      nameservers:
        addresses: [8.8.8.8,168.95.1.1]
      dhcp4: no

(請根據你的自身環境修改,這裡只是舉例)

就這樣而已,省二、三個指令,簡單又直覺。

如果你要 dhcp (自動取得 IP 位址) 那更簡單了:

network:
  version: 2
  renderer: networkd
  ethernets:
    eth0:
      dhcp4: yes

然後存檔離開

執行一個很直覺的指令: netplan try

$ sudo netplan try
Do you want to keep these settings?

Press ENTER before the timeout to accept the new configuration
Changes will revert in 120 seconds

是否要保留設定?按 Enter 保留設定,不然 120 秒後會復原。
就跟切換螢幕解析度一樣簡單。

爾或者可以用 netplan apply 直接套用。

$ sudo netplan apply

(舊式) 設定 IP 位址 (IP Address)

$ sudo ip addr add 192.168.10.200/24 dev eth0

這邊用 192.168.10.200 做為例子,請修改成恰當的值。

(舊式) 設定網路閘道 Gateway

$ sudo route add default gw 192.168.10.1 eth0

這邊用 192.168.10.1 做為例子,請修改成恰當的值。

(舊式) 設定 DNS

$ sudo echo nameserver 8.8.8.8″ > /etc/resolv.conf

這邊用 8.8.8.8 的 Google DNS 做為例子,你也可以調整成你喜歡的。

DHCP Relase

釋放從 DHCP 取得的 IP 位址

$ sudo dhclient -r

指令等同 Windows 裡的 ipconfig /release

DHCP Renew

從 DHCP 重新取得新的 IP

$ sudo dhclient

指令等同 Windows 裡的 ipconfig /renew

啟動/關閉 網路介面 (ip 指令)

$ ip link set dev eth0 up
$ ip link set dev eth0 down

例如介面名稱為 eth0,請自行修改成合適的網路名稱。

啟動/關閉 網路介面 (ifconfig 指令)

$ /sbin/ifconfig eth0 up
$ /sbin/ifconfig eth0 down

例如介面名稱為 eth0,請自行修改成合適的網路名稱。

列出所有網路介面與狀態

$ ip link show
$ ifconfig -a

這二個都可以

檢查外部公有 IP (Public IP)

$ curl ipinfo.io/ip

一個簡單的指令可以查詢外部公有IP地址 (Public IP)

SSH 相關

安裝 SSH Server (應該預設就有安裝了)

應該預設就有安裝了,如果沒有安裝,請手動用指令安裝之。
(以下為 ubuntu 的指令)

$ sudo apt install -y ssh openssh-server

開機預設啟動 ssh

$ sudo systemctl enable ssh

啟動 ssh

$ sudo systemctl start ssh

查看 ssh 狀態

$ sudo systemctl status ssh

使用 ssh key 取代密碼登入

增加方便性也加強安全性,建議用 ssh key (pem) 檔案來登入 ssh。

產生 ssh key

$ ssh-keygen

指定檔案,例如 id_rsa 檔案(檔名可自訂)。
密碼 passphrase 可以留空

將會產生 id_rsa (私鑰) 與 id_rsa.pub (公鑰) 檔案。

接下來的步驟將是把您的公鑰複製到伺服器上(或者是把私鑰下載回使用者電腦上)。
使用者(你)透過電腦上的私鑰來做連線。

自動複製 ssh key

(在 Client 端執行此指令)
這個步驟是自動把您的公鑰複製到伺服器上。

$ ssh-copy-id -i ~/.ssh/id_rsa -p 22 [email protected]

如果不能運作也不用太糾結,等等有手動的方式。

運行結果:

/usr/bin/ssh-copy-id: INFO: Source of key(s) to be installed: "/Users/user/.ssh/id_rsa.pub"
The authenticity of host '[192.168.10.200]:22 ([192.168.10.200]:22)' can't be established.
ECDSA key fingerprint is SHA256:wYmwxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxcFme8.
Are you sure you want to continue connecting (yes/no/[fingerprint])? yes
/usr/bin/ssh-copy-id: INFO: attempting to log in with the new key(s), to filter out any that are already installed
/usr/bin/ssh-copy-id: INFO: 1 key(s) remain to be installed -- if you are prompted now it is to install the new keys
[email protected]'s password:

Number of key(s) added:        1

Now try logging into the machine, with:   "ssh -p '22' '[email protected]'"
and check to make sure that only the key(s) you wanted were added.

另外一個指令,作法相同。

$ cat ~/.ssh/id_rsa.pub | ssh -p 22 [email protected] "mkdir -p ~/.ssh && cat >> ~/.ssh/authorized_keys"

或者手動複製產生之公鑰 (PublicKey) 到伺服器的 ~/.ssh/authorized_keys 檔案。
(如果沒有 .ssh 隱藏資料夾與 authorized_keys 檔案,請自行建立。)

設定 SSH 關閉密碼登入

$ vi /etc/ssh/sshd_config

找到這行並修改

PasswordAuthentication no

設定免密碼 sudo

(這個步驟非必要)
在設定之前,先調整預設開啟的編輯器。
因為小弟長期習慣用 vim 所以用此指令先切換預設開啟的編輯器

$ sudo update-alternatives --config editor
There are 4 choices for the alternative editor (providing /usr/bin/editor).

  Selection    Path                Priority   Status
------------------------------------------------------------
* 0            /bin/nano            40        auto mode
  1            /bin/ed             -100       manual mode
  2            /bin/nano            40        manual mode
  3            /usr/bin/vim.basic   30        manual mode
  4            /usr/bin/vim.tiny    15        manual mode

Press <enter> to keep the current choice[*], or type selection number: 3
update-alternatives: using /usr/bin/vim.basic to provide /usr/bin/editor (editor) in manual mode

ubuntu 預設是開 nano 編輯器,可以用這個來修改
可以選擇 3 改用 vim 編輯器。

然後使用該指令編輯設定檔

$ sudo visudo

找到

%sudo   ALL=(ALL:ALL) ALL

把它改成

%sudo   ALL=(ALL:ALL) NOPASSWD: ALL

然後存檔離開。

連線 SSH

這個可以做為 bash script 以後方便使用。

$ ssh -i ~/.ssh/id_rsa -p 22 [email protected]

參考資料

https://www.cyberciti.biz/faq/ubuntu-linux-install-openssh-server/
https://www.digitalocean.com/community/tutorials/how-to-configure-ssh-key-based-authentication-on-a-linux-server
https://vitux.com/ubuntu-ip-address-management/
https://www.cyberciti.biz/faq/howto-linux-renew-dhcp-client-ip-address/
https://tldp.org/HOWTO/Linux+IPv6-HOWTO/ch05s02.html

[Fedora 14-17] 架設VPN Server (pptpd)

安裝PPTPD及相關服務

yum install -y rp-pppoe gcc pptp pptp-setup  ppp ppp-devel
 
安裝方式有二種:
 
RPM安裝(要依照Linux的版本安裝)
 
例如Fedora 14 (32bit)
wget http://poptop.sourceforge.net/yum/stable/fc14/i386/pptpd-1.3.4-2.fc14.i686.rpm
rpm -ivh pptpd-1.3.4-2.fc14.i686.rpm
 
Fedora 14 (64bit)
wget http://poptop.sourceforge.net/yum/stable/fc14/x86_64/pptpd-1.3.4-2.fc14.x86_64.rpm
rpm -ivh pptpd-1.3.4-2.fc14.x86_64.rpm
 
YUM安裝(要依照Linux的版本安裝)
 
rpm -ivh http://poptop.sourceforge.net/yum/stable/fc14/pptp-release-current.noarch.rpm
yum install pptpd
 
 
下載並安裝核心模組
 
 
wget http://sourceforge.net/projects/poptop/files/mppe%20module%20builder/kernel_ppp_mppe-1.0.2%20dkms-2.0.6/kernel_ppp_mppe-1.0.2-3dkms.noarch.rpm/download
 
wget http://downloads.sourceforge.net/project/poptop/mppe%20module%20builder/kernel_ppp_mppe-1.0.2%20dkms-2.0.6/kernel_ppp_mppe-1.0.2-3dkms.noarch.rpm?r=http%3A%2F%2Fsourceforge.net%2Fprojects%2Fpoptop%2Ffiles%2Fmppe%2520module%2520builder%2Fkernel_ppp_mppe-1.0.2%2520dkms-2.0.6%2F&ts=1341655470&use_mirror=nchc
 
wget http://downloads.sourceforge.net/project/poptop/mppe%20module%20builder/kernel_ppp_mppe-1.0.2%20dkms-2.0.6/dkms-2.0.6-1.noarch.rpm?r=http%3A%2F%2Fsourceforge.net%2Fprojects%2Fpoptop%2Ffiles%2Fmppe%2520module%2520builder%2Fkernel_ppp_mppe-1.0.2%2520dkms-2.0.6%2F&ts=1341655518&use_mirror=nchc
 
rpm -ivh dkms-2.0.6-1.noarch.rpm
rpm -ivh kernel_ppp_mppe-1.0.2-3dkms.noarch.rpm
 
 
若沒有按照版本安裝會有類似以下錯誤: 
Error! Bad return status for module build on kernel: 3.4.2-1.fc16.x86_64 (x86_64)
Consult the make.log in the build directory
/var/lib/dkms/kernel_ppp_mppe/1.0.2/build/ for more information.
 
Error! Could not locate ppp_generic.ko for module kernel_ppp_mppe in the DKMS tree.
You must run a dkms build for kernel 3.4.2-1.fc16.x86_64 (x86_64) first.
 
========================================================
 
設定PPTPD
 
 
設定Client看到的伺服器IP,以及DHCP分發的IP範圍
vi /etc/pptpd.conf
加入以下:
localip 10.0.0.1
remoteip 10.0.0.10-100
 
—————————————————-
 
設定pptpd的加密方式和發給Client的DNS
vi /etc/ppp/options.pptpd
refuse-pap
refuse-chap
refuse-mschap
 
require-mschap-v2
require-mppe-128
 
ms-dns 168.95.1.1
 
—————————————————-
 
設定帳號密碼(若使用ppp撥號(xDSL),撥號的帳密也會在這裡)
格式為:
帳號、使用的服務、密碼、接受的IP(通常為*號)
中間用空格隔開
 
vi /etc/ppp/chap-secrets
內容大致為:
# client        server           secret             IP addresses
[email protected]”      *         “your password”
test pptpd 12345 *
 
 
—————————————————- 
 
設定系統IP轉發
vi /etc/sysctl.conf
修改
net.ipv4.ip_forward = 1
 
讓系統重新載入設定值
sysctl -p
 
—————————————————-
 
設定防火牆
 
主要是設定讓PPTP的Client能夠NAT上網
請依照對外連線的網路卡代號取代掉ppp0
ppp+的代表用來連接VPN Client的網卡,不需更動
vi /etc/sysconfig/iptables
 
 
*nat
:PREROUTING ACCEPT [0:0]
:OUTPUT ACCEPT [0:0]
:POSTROUTING ACCEPT [0:0]
-A POSTROUTING -o ppp0 -j MASQUERADE
COMMIT
 
*filter
:INPUT ACCEPT [0:0]
:FORWARD ACCEPT [0:0]
:OUTPUT ACCEPT [0:0]
-A INPUT -m state –state ESTABLISHED,RELATED -j ACCEPT
-A INPUT -p icmp -j ACCEPT
-A INPUT -i lo -j ACCEPT
-A INPUT -m state –state NEW -m tcp -p tcp –dport 22 -j ACCEPT
# 其他要開啟服務的port依照格式寫在這裡
 
#—-vpn—-
-A INPUT -i ppp0 -p tcp –dport 1723 -j ACCEPT
-A INPUT -i ppp0 -p gre -j ACCEPT
-A FORWARD -i ppp+ -o ppp0 -j ACCEPT
-A FORWARD -i ppp0 -o ppp+ -j ACCEPT
#—-vpn—-
 
-A INPUT -j REJECT –reject-with icmp-host-prohibited
-A FORWARD -j REJECT –reject-with icmp-host-prohibited
COMMIT
 
—————————————————-
 
重啟防火牆(Fedora 14以上使用)
systemctl restart iptables.service
systemctl restart ip6tables.service
 
重啟防火牆(Fedora 14含以下使用)
/etc/init.d/iptables restart

 

 
========================================================
 
啟動PPTPD等服務
 
 
啟動PPTPD服務
/etc/init.d/pptpd start
重啟PPTPD服務
/etc/init.d/pptpd restart
斷除所有VPN連線
/etc/init.d/pptpd restart-kill
 
 
查看相關的Log
tail -n 30 /var/log/messages
 
查看連線情況
netstat -an | grep :1723 | sort
 
========================================================
 

[Fedora12-14] 設定遠端桌面連線 (rdp)

大家都有用過WIndows的遠端桌面連線吧

其名稱叫做Remote Desktop Protocol (RDP)

是一個網路協定,微軟WinXP之後的都有他的Client可以說是非常方便

而Linux呢?沒有原生的RDP的Server

但有VNC,而且有個xrdp的軟體能夠『透過rdp協定』來連線vnc

設定上有一點點小複雜,不過應該還好

————————————————–

安裝vnc server

我之前也有寫過VNC的架設,大家可以參考一下

http://j796160836.pixnet.net/blog/post/20787531

這裡的設定跟之前寫的差不多,避免變成二篇文章後

大家設定不起來,還是簡單節錄一下

 

這裡我們用的是tightvnc server

直接下yum指令安裝

[[email protected] ~]# yum install vnc-server -y

 

安裝完畢後就可啟動服務

[[email protected] ~]# /etc/init.d/vncserver start

然後開一個user來做VNC連線登入的帳號,本例是vncDesktop

(也可以跟本機帳號一樣,如果是這樣就省略開帳號的動作)

[[email protected] ~]# useradd vncDesktop

設定密碼

[[email protected] ~]# passwd vncDesktop

如果是root登入,需要切換到該使用者,來設定vnc使用的密碼

[[email protected] ~]# su vncDesktop

設定vnc使用的密碼(這裡的密碼到時候就會是遠端桌面使用的密碼)

[[email protected] ~]# vncpasswd

再切換回root

[[email protected] ~]# su –

 

這裡需要設定哪個使用者需啟用vnc服務

[[email protected] ~]# vi /etc/sysconfig/vncservers

解除註解並修改

VNCSERVERS=”2:vncDesktop
VNCSERVERARGS[2]=”-geometry 800×600 -nolisten tcp -localhost”

 

 

2冒號  不可省略,指的是Terminal的號碼
VNCSERVERARGS註解要拿掉

 

 

然後重啟vnc服務,套用新設定

[[email protected] ~]# /etc/init.d/vncserver restart

這時候,如果沒有提示錯誤的話

應該會跑vnc在5902的port

這個port防火牆可以不開,也不需要開,因為我們要用xrdp去連vnc

 

————————————————–

 

安裝xrdp

 

這裡還是要再三描述觀念

xrdp是基於vnc服務的服務,所以vnc的架設和設定不能省略

架設方法在上文

 

xrdp安裝一樣直接下yum指令安裝

[[email protected] ~]# yum install xrdp -y

 

安裝完畢後就可啟動服務

[[email protected] ~]# /etc/init.d/xrdp start

 

防火牆對應做修改,打開3389的port

[[email protected] ~]# vi /etc/sysconfig/iptables

加一行文字,打開3389的port

-A INPUT -m state –state NEW -m tcp -p tcp –dport 3389  -j ACCEPT

 

然後記得重啟防火牆,讓他套用新設定

[[email protected] ~]# /etc/init.d/iptables restart

 

 

————————————————–

我們需要修改startwm.sh修改啟動X Window的的順序

因為Fedora來說預設只有裝gnome

所以我們需要把它改到優先(橘色為修改)

[[email protected] ~]# vi /etc/xrdp/startwm.sh

#!/bin/sh -l

# change the order in line below to run to run whatever window manager you
# want, default to kde

SESSIONS=”gnome-session startkde startxfce4 xterm”

# change PATH to be what your environment needs usually what is in
# /etc/environment
#PATH=”/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games”
#export PATH=$PATH

# for PATH and LANG from /etc/environment
# pam will auto process the environment file if /etc/pam.d/xrdp-sesman
# includes
# auth       required     pam_env.so readenv=1
#. /etc/environment
#export PATH=$PATH
#export LANG=$LANG

# for bash profile
#. ~/.bash_profile
#. /etc/profile

for WindowManager in $SESSIONS
do
  which $WindowManager
  if test $? -eq 0
  then
    echo “Starting $WindowManager”
    $WindowManager
    exit 0
  fi
done

exit 1

————————————————–

接下來,在實際測試的時候會出現一個很奇怪的現象

就是xrdp之後,滑鼠正常,但鍵盤就是無法使用

無法打入帳號密碼

後來發現是因為是鍵盤配置檔出問題

因為

在繁體中文的環境下,xrdp會抓不到對應的鍵盤配置檔

 

所以我們必須修正這個問題

以我的為例,xrdp的設定檔有這些

[[email protected] ~]# ls /etc/xrdp/

km-0004.ini  km-0409.ini  km-0419.ini  sesman.ini   xrdp.sh      
km-0404.ini  km-040c.ini  km-041d.ini  startwm.sh   
km-0407.ini  km-0410.ini  rsakeys.ini  xrdp.ini     

請注意這些km-xxxx.ini這些就是鍵盤配置檔

km-0409.ini 這個是英文的鍵盤配置

以下列出一些常看到的語系代碼,如果沒有的話請到以下網址去參考

http://xrdp.sourceforge.net/documents/keymap/rfc1766.html

 

“0004”=”zh;Chinese”
“0404”=”zh-tw;Chinese (Taiwan)”
“0804”=”zh-cn;Chinese (China)”
“0C04″=”zh-hk;Chinese (Hong Kong SAR)”
“1004”=”zh-sg;Chinese (Singapore)”

“0409”=”en-us;English (United States)”
“0809”=”en-gb;English (United Kingdom)”
“0C09″=”en-au;English (Australia)”
“1009”=”en-ca;English (Canada)”
“1409”=”en-nz;English (New Zealand)”
“1809”=”en-ie;English (Ireland)”
“1C09″=”en-za;English (South Africa)”
“2009”=”en-jm;English (Jamaica)”
“2809”=”en-bz;English (Belize)”
“2C09″=”en-tt;English (Trinidad)”

 

以繁體中文0404為例,因為我們的鍵盤配置跟英文一樣

所以只要打上這個指令就行了

[[email protected] ~]# cp /etc/xrdp/km-0409.ini /etc/xrdp/km-0004.ini

[[email protected] ~]# cp /etc/xrdp/km-0409.ini /etc/xrdp/km-0404.ini

其他鍵盤方面沒講到的地方都在這:

http://xrdp.sourceforge.net/documents/keymap/newkeymap.html

 

————————————————–

最後,測試成功後,就可以將它設定為開機自動啟動

[[email protected] ~]# chkconfig xrdp on

[[email protected] ~]# chkconfig vncserver on

————————————————–

參考資料

http://hpclab.cs.pu.edu.tw/wiki/index.php/Xrdp#.E9.8D.B5.E7.9B.A4.E9.8C.AF.E4.BA.82

http://chip.twbbs.org/2009/06/xrdpubuntu-904.html

[Fedora14]重灌筆記

這篇算是之前的文章的整理,有些東西可能就要煩請參考之前的文章摟

 

設定FireFox

http://gfx.tw/j796160836

關閉離線介面

http://j796160836.pixnet.net/blog/post/26241754

設定PPPOE連線,中文

http://j796160836.pixnet.net/blog/post/25444345

調整文字顯示模式

http://j796160836.pixnet.net/blog/post/26196073

解決在XP時間不同步的問題

http://j796160836.pixnet.net/blog/post/26041820

安裝相關的GUI介面

#yum install -y system-config-bind system-config-samba system-config-services system-config-boot system-config-network system-config-rootpassword policycoreutils-gui

[Fedora12]Linux的GRUB修復,安裝GRUB

大家在製作多重開機時都會遇到這個問題
就是不管是XP先安裝或是Linux先安裝

都會有開機資訊被覆蓋的情況

先講重要概念

————————————————————————–

重要概念

1. MBR為Master Boot Record每顆硬碟只有一個,寫在硬碟的第0軌上

2. 每切出的分割,除了裡面有檔案系統的資訊外,還有一個開機資訊(boot sector)

3. 大致的開機流程是,當BIOS控制權轉交到一顆硬碟上,會先讀取該硬碟的MBR
再由MBR裡寫的資訊(如果沒有則為active的分割區),載入該分割區的(boot sector),再經由該資訊,找到系統重要檔案,載入作業系統

4. 而多重開機則大多為在MBR裡寫入開機管理程式,顯示介面讓使用者選擇到開機的分割區或是其他資訊
(也有些開機管理程式程式太大,MBR的空間塞不進去,會從MBR中導到某個分割區的boot sector,再從該資訊載入開機管理程式)

5. 而Linux比較特別,可以直接從GRUB直接載入核心,載入作業系統 

解決辦法如下:

————————————————————————–

winXP下的開機資訊修復

放入XP安裝光碟,用它開機

按R進入Recovery Console下打fixmbr修復

或是使用spfdisk的修復MBR功能

A:\>spfdisk /mbr

————————————————————————–

Linux下的開機選單(GRUB)修復

放入你使用的Linux版本的LiveCD,用它開機
在登入到桌面之後,打開命令列

以Fedora 12為例 (GRUB 1版的做法)

(註:以下這段ubuntu就不適用,因為它使用GRUB 2版。做法為另一種)
(該做法不限定在Fedora,Redhat系列的都可以用,像是RHEL,Cent OS … 等等)

先打入fdisk -l查看磁碟分割的狀況

[[email protected] ~]#fdisk -l

Disk /dev/sda: 320.1 GB, 320072933376 bytes
255 heads, 63 sectors/track, 38913 cylinders, total 625142448 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0x129dfc88

   Device Boot      Start         End      Blocks   Id  System
/dev/sda1   *          63    18844244     9422091    7  HPFS/NTFS
/dev/sda2        18844245   625137344   303146550    f  W95 Ext’d (LBA)
/dev/sda5        18860310    52516484    16828087+   7  HPFS/NTFS
/dev/sda6        52516548    60918479     4200966   83  Linux
/dev/sda7        60918543    62990864     1036161   82  Linux swap / Solaris
/dev/sda8        62990928    96454259    16731666    7  HPFS/NTFS
/dev/sda9        96454323   625137344   264341511    7  HPFS/NTFS

 

找到Fedora安裝的分割區(ext3或ext4分割,該目錄含有GRUB的資訊)
我的電腦為/dev/sda6

打入grub進入頁面

[[email protected]~]#grub

切換根目錄為Fedora安裝的目錄

grub> root (hd0,5)
root (hd0,5)
 Filesystem type is ext2fs, partition type 0x83

這個時候可能要嘗試一下,大約是在前面查到的sda6的上一號或下一號
出現ext2fs字樣就可以繼續

 

範例1:

寫入開機資訊到該硬碟的MBR

grub> setup (hd0)
setup (hd0)
Checking if “/boot/grub/stage1” exists… no
Checking if “/grub/stage1” exists… yes
Checking if “/grub/stage2” exists… yes
Checking if “/grub/e2fs_stage1_5” exists… yes
Running “embed /grub/e2fs_stage1_5 (hd0)”…  15 sectors are embedded.
succeeded
Running “install /grub/stage1 (hd0) (hd0)1+15 p (hd0,5)/grub/stage2
/grub/grub.conf”… succeeded
Done.

出現類似succeeded字樣就成功了

 

範例2:

寫入開機資訊到Fedora的該分割區的開機磁軌
(我的是sda6,也就是這裡的(hd0,5)每台電腦環境不同,請以你的為主)

grub> setup (hd0,5)
setup (hd0,5)
 Checking if “/boot/grub/stage1” exists… yes
 Checking if “/boot/grub/stage2” exists… yes
 Checking if “/boot/grub/e2fs_stage1_5” exists… yes
 Running “embed /boot/grub/e2fs_stage1_5 (hd0,5)”… failed (this is not fatal)
 Running “embed /boot/grub/e2fs_stage1_5 (hd0,5)”… failed (this is not fatal)
 Running “install /boot/grub/stage1 (hd0,5) /boot/grub/stage2 p /boot/grub/grub.conf “… succeeded
Done.

出現類似succeeded字樣就成功了

————————————————————————–

這篇很簡略的寫出操作的重點

詳細請看

http://linux.vbird.org/linux_basic/0510osloader.php#grub_install

http://bentai.wordpress.com/2006/08/16/%E5%9C%A8windows-xp-sp2%E4%B8%8B%E4%BF%AE%E5%BE%A9mbr/

[MySQL]更改預設資料庫的編碼

引用:http://www.twvbb.com/vbb/thread/104/9420/

這是MySQL安裝的時候預設的狀況
使用xampp或是linux底下的lampp

 

在phpmyadmin底下的variables可以看到
預設新增的資料庫的編碼會是latin1
但我們通常都會新增utf8的資料庫

請修改MySQL的設定檔my.cnf

(Linux底下)

/etc/my.cnf
或是
/opt/lampp/etc/my.cnf

(XP底下)

 

找到以下標籤並加上紅字部份

[mysqld]
character-set-server=utf8
collation-server=utf8_general_ci
init-connect=’SET NAMES utf8′

[client]
default-character-set=utf8

 

資料庫轉換的步驟請參考引用原文
我看完消化過在補

[Fedora 12]關閉FireFox的離線模式(Offline mode)

摘錄自原文

Find “browser.offline-apps.notify” in the “about:config” method and set it to false.

toolkit.networkmanager.disable to “true”

————————————–

在用Linux時,是否會被那離線模式(Offline mode)給弄煩了呢?
無網路連線時會顯示離線模式,而當有網路連線時卻還是會留在離線模式

 

可照以下作法:

在FireFox上的網址列打入

about:config

會出現一個 You might void your warranty 的警告訊息
,按 I’ll be careful I promise! 繼續

在 Filter: 裡搜尋

browser.offline-apps.notify

雙點該項目,值從True -> False

相同的方法搜尋

toolkit.networkmanager.disable

雙點該項目,值從False -> True

完成

[Ubuntu10.04] 關於Ubuntu的一些雜記

切換root

sudo su –

修改root密碼

sudo passwd root

 使用vi

apt-get vim;alias vi=’vim’

vi ~/.vimrc

引用:http://linux.vbird.org/linux_basic/0310vi.php#vim_set

:set nu
:set nonu
就是設定與取消行號啊!
:syntax on
:syntax off
是否依據程式相關語法顯示不同顏色? 舉例來說,在編輯一個純文字檔時,如果開頭是以 # 開始,那麼該行就會變成藍色。 如果你懂得寫程式,那麼這個 :syntax on 還會主動的幫你除錯呢!但是, 如果你僅是編寫純文字檔案,要避免顏色對你的螢幕產生的干擾,則可以取消這個設定 。
:set bg=dark
:set bg=light
可用以顯示不同的顏色色調,預設是『 light 』。如果你常常發現註解的字體深藍色實在很不容易看, 那麼這裡可以設定為 dark 喔!試看看,會有不同的樣式呢!

 

關於GRUB2

引用:http://wiki.ubuntu-tw.org/index.php?title=GRUB_2_%E4%B8%AD%E6%96%87%E6%8C%87%E5%8D%97#.E5.A2.9E.E5.8A.A0.E5.8A.9F.E8.83.BD

  • 沒有 /boot/grub/menu.lst。已被 /boot/grub/grub.cfg 取代。
  • 在 grub 提示符號下沒有「/find boot/grub/stage1」。Stage 1.5 被淘汰了。
  • 主要選單檔,/boot/grub/grub.cfg,不應再被手動編輯,即使是由「root」身份。
  • grub.cfg 會在任何有更新、核心被加入/移除或是使用者執行 update-grub 的時候被覆寫。
  • 主要用來改變顯示設定的設定檔是 /etc/default/grub
  •  其他參見說明

     

    [Ubuntu10.04] Apt-get指令用法和yum對照

    我是Fedora派的,不管是Cent OS或Fedora都好好用
    但我又被ubuntu的強大視窗特效和親合力很高的圖型介面所吸引
    不過ubuntu是用debian系列的,指令介面用起來還是有點卡卡的,試試看也不錯。

    我紀錄一下這指令用法,和做一些對照,YUM比較常用

    引用:http://wiki.debian.org.hk/w/Install_software_with_APT

    更新最新的軟件資料 (apt-get update)

    YUM指令對照:yum update

    在系統管理員帳戶(即root)下打「apt-get update」更新最新的軟件資料:

    # apt-get update
    下載:1 ftp://ftp.hk.debian.org stable/main Packages [3577kB]
    已有 http://deb.opera.com stable/non-free Packages
    略過 http://deb.opera.com stable/non-free Release
    下載:2 ftp://ftp.hk.debian.org stable/main Release [82B]
    下載:3 ftp://ftp.hk.debian.org stable/main Sources [1415kB]
    讀取 4992kB 用了 11s (159kB/s)
    讀取套件清單中... 完成
    

    搜尋軟件 (apt-cache search)

    YUM指令對照:yum search 關鍵字

    先用 “apt-cache search 關鍵字 ...” 搜尋軟件:

    $ apt-cache search image manipulate
    cinepaint - motion picture image painting and retouching tool
    fujiplay - Interface for Fuji digital cameras
    gnubik - 3D Rubik's cube game
    gtkmorph - Digital image warp and morph (gtk)
    gtkmorph-example - digital image warp and morph, examples
    imagemagick - Image manipulation programs
    jhead - manipulate the non-image part of Exif compliant JPEG files
    jpegpixi - Remove hot spots from JPEG images with minimal quality loss
    

    安裝軟件 (apt-get install)

    YUM指令對照:yum install  套件名稱

    apt-get install 套件名稱

    # apt-get install imagemagick
    Reading Package Lists... Done
    Building Dependency Tree... Done
    Suggested packages:
    html2ps lpr
    The following NEW packages will be installed:
    imagemagick
    0 upgraded, 1 newly installed, 0 to remove and 0 not upgraded.
    Need to get 0B/1466kB of archives.
    After unpacking 5325kB of additional disk space will be used.
    Selecting previously deselected package imagemagick.
    (Reading database ... 60636 files and directories currently installed.)
    Unpacking imagemagick (from .../imagemagick_6%3a6.0.6.2-2.4_i386.deb) ...
    Setting up imagemagick (6.0.6.2-2.4) ...
    

    移除軟件 (apt-get remove)

    要移除套件,可以在系統管理員帳戶(即root)下打「apt-get remove 套件名稱」,APT就會把所指定的套件和相依的套件一併移除。不過apt-get remove不會移除套件所屬的設定檔,要把設定檔也一併移除,就要加入選項「--purge」。

    YUM指令對照:yum erase 套件名稱

    # apt-get --purge remove imagemagick
    Reading Package Lists... Done
    Building Dependency Tree... Done
    The following packages will be REMOVED:
    imagemagick*
    0 upgraded, 0 newly installed, 1 to remove and 0 not upgraded.
    Need to get 0B of archives.
    After unpacking 5325kB disk space will be freed.
    Do you want to continue? [Y/n]
    (Reading database ... 60867 files and directories currently installed.)
    Removing imagemagick ...
    Purging configuration files for imagemagick ...
    

    顯示個別軟件詳細資訊 (apt-cache show) (很少用)

    YUM指令對照:yum list 套件名稱

    如果想知道個別套件詳細資訊,可以打 "apt-cache show 套件名稱":

    $ apt-cache show imagemagick
    Package: imagemagick
    Priority: optional
    Section: graphics
    Installed-Size: 5200
    Maintainer: Ryuichi Arafune <[email protected]>
    Architecture: i386
    Version: 6:6.0.6.2-2.4
    Replaces: imagemagick-doc, geomview (<= 1.8.0)
    Depends: libmagick6 (= 6:6.0.6.2-2.4)
    Suggests: gs, html2ps, lpr
    Conflicts: imagemagick-doc
    Filename: pool/main/i/imagemagick/imagemagick_6.0.6.2-2.4_i386.deb
    Size: 1465598
    MD5sum: 4b9eb6cda5f5fe0c20040c9647ee2b6f
    Description: Image manipulation programs
    Imagemagick is a set of programs to manipulate various image formats
    (JPEG, TIFF, PhotoCD, PBM, XPM, etc...). All manipulations can
    be achieved through shell commands as well as through a X11 graphical
    interface (display).
    .
    Possible effects: colormap manipulation, channel operations, thumbnail
    creation, image annotation, limited drawing, image distortion, etc...
    .
    This package suggests a postscript interpreter (gs) to read postscript
    files. It will however function happily without it (as long as you don't
    want to read postscript).
    

    [Fedora12] 開機失敗

    最近遇到選完GRUB選單,然後Fedora開機卡住的問題

    螢幕只剩下一個小點點 (或底線 _ ) 在那邊閃呀閃

     

     

    硬體是HP dx2000mt的電腦      Intel 865GV晶片組

    引用:http://lkml.indiana.edu/hypermail/linux/kernel/0308.1/1105.html
    https://bugzilla.redhat.com/show_bug.cgi?id=521423

     

    查到是說,是ACPI(進階電源管理)的問題

    關於ACPI,這裡有他的很棒的說明

    http://www.delightpress.com.tw/article_c.aspx?article_id=8

    簡單說就是控制電腦在休眠待命和關機的一些電源控制
    作業系統需要偵測硬體和與BIOS做溝通

    如果你也是遇到這種問題,先把核心參數

    rhgb quiet

    這二個拿掉,才能顯示詳細的內容

     

    然後嘗試加上

    acpi=ht

    這是針對核心有HT技術的硬體架構所開發 (Intel ICH5 APIC)
    可以略過一些硬體偵測,又可以打開Hyper-threading技術

    如果嘗試這個不行

    只好使用這個相容性最高的參數

    acpi=off

    當然,在關機時不能自動軟關機

     

    如果不行的話可以依序試試

    acpi=noirq

    pci=routeirq

    pci=noacpi

    acpi=noirq

    pci=nomsi

     

    ——————————————————————————————————-

    引用:http://www.cyberciti.biz/howto/question/static/linux-kernel-parameters.php

    其他開機核心參數

            acpi=           [HW,ACPI] Advanced Configuration and Power Interface
                            Format: { force | off | ht | strict | noirq }
                            force — enable ACPI if default was off
                            off — disable ACPI if default was on
                            noirq — do not use ACPI for IRQ routing
                            ht — run only enough ACPI to enable Hyper Threading
                            strict — Be less tolerant of platforms that are not
                                    strictly ACPI specification compliant.

     

            pci=option[,option…]  [PCI] various PCI subsystem options:
                    off             [IA-32] don’t probe for the PCI bus
                    bios            [IA-32] force use of PCI BIOS, don’t access
                                    the hardware directly. Use this if your machine
                                    has a non-standard PCI host bridge.
                    nobios          [IA-32] disallow use of PCI BIOS, only direct
                                    hardware access methods are allowed. Use this
                                    if you experience crashes upon bootup and you
                                    suspect they are caused by the BIOS.
                    conf1           [IA-32] Force use of PCI Configuration
                                    Mechanism 1.
                    conf2           [IA-32] Force use of PCI Configuration
                                    Mechanism 2.
                    nosort          [IA-32] Don’t sort PCI devices according to
                                    order given by the PCI BIOS. This sorting is
                                    done to get a device order compatible with
                                    older kernels.
                    biosirq         [IA-32] Use PCI BIOS calls to get the interrupt
                                    routing table. These calls are known to be buggy
                                    on several machines and they hang the machine
                                    when used, but on other computers it’s the only
                                    way to get the interrupt routing table. Try
                                    this option if the kernel is unable to allocate
                                    IRQs or discover secondary PCI buses on your
                                    motherboard.
                    rom             [IA-32] Assign address space to expansion ROMs.
                                    Use with caution as certain devices share
                                    address decoders between ROMs and other
                                    resources.
                    irqmask=0xMMMM  [IA-32] Set a bit mask of IRQs allowed to be
                                    assigned automatically to PCI devices. You can
                                    make the kernel exclude IRQs of your ISA cards
                                    this way.
                    pirqaddr=0xAAAAA        [IA-32] Specify the physical address
                                    of the PIRQ table (normally generated
                                    by the BIOS) if it is outside the
                                    F0000h-100000h range.
                    lastbus=N       [IA-32] Scan all bus
    es thru bus #N. Can be
                                    useful if the kernel is unable to find your
                                    secondary buses and you want to tell it
                                    explicitly which ones they are.
                    assign-busses   [IA-32] Always assign all PCI bus
                                    numbers ourselves, overriding
                                    whatever the firmware may have done.
                    usepirqmask     [IA-32] Honor the possible IRQ mask stored
                                    in the BIOS $PIR table. This is needed on
                                    some systems with broken BIOSes, notably
                                    some HP Pavilion N5400 and Omnibook XE3
                                    notebooks. This will have no effect if ACPI
                                    IRQ routing is enabled.
                    noacpi          [IA-32] Do not use ACPI for IRQ routing
                                    or for PCI scanning.
                    routeirq        Do IRQ routing for all PCI devices.
                                    This is normally done in pci_enable_device(),
                                    so this option is a temporary workaround
                                    for broken drivers that don’t call it.
                    firmware        [ARM] Do not re-enumerate the bus but instead
                                    just use the configuration from the
                                    bootloader. This is currently used on
                                    IXP2000 systems where the bus has to be
                                    configured a certain way for adjunct CPUs.