tag:blogger.com,1999:blog-66160685167235464482024-03-05T17:20:32.367+08:00Jerry'codejarodlau.blogspot.com
https://github.com/jarodlau
jarodlau.sytes.netAnonymoushttp://www.blogger.com/profile/15470207574707724400noreply@blogger.comBlogger225125tag:blogger.com,1999:blog-6616068516723546448.post-17421777419725529282015-11-07T02:47:00.000+08:002015-11-07T03:04:10.309+08:00利用arch配置一个pxe server,网络安装各种版本linux系统,各种版本windows系统!想了半天也没有找到合适的板块发这个,最后还是发这里把!<br />
<br />
最近折腾了两个小主机,华硕EeeBox B202,atom n270的u,1g的内存,80g的硬盘,机器挺小巧,就是单核u,功能实在鸡肋,索性一个做了个播放机,这个就做了一个pxe server!<br />
<br />
利用wol的功能,网络装系统,至于pxe的原理,如下:<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="http://www.ytyzx.net/images/0/0a/PXE.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" src="http://www.ytyzx.net/images/0/0a/PXE.png" /></a></div>
<br />
<br />
以下是摘自syslinux官网关于pxelinux的介绍,懒得翻译了,大家自己看,应该不难理解.<br />
The basic configuration is the same for all Syslinux variants. This document explains only some of the differences specifically applicable to PXELINUX.<br />
On the TFTP server, create the directory "/tftpboot", and copy "pxelinux.0" (from the Syslinux distribution) and any kernel or initrd images that you want to boot.<br />
[5.00+] Also copy "ldlinux.c32" from the Syslinux distribution to the "/tftpboot" directory on the TFTP server.<br />
Finally, create the directory "/tftpboot/pxelinux.cfg". The configuration file (equivalent of syslinux.cfg -- see the SYSLINUX FAQ for the options here) will live in this<br />
<br />
directory.<br />
Because more than one system may be booted from the same server, the configuration file name depends on the IP address of the booting machine.<br />
Before a generic explanation, let's see first an example. When:<br />
the bootloader file name is "/mybootdir/pxelinux.0"; and,<br />
the client UUID is "b8945908-d6a6-41a9-611d-74a6ab80b83d"; and,<br />
the Ethernet MAC address is "88:99:AA:BB:CC:DD"; and,<br />
the IP address is "192.168.2.91", or in uppercase hexadecimal, "C0A8025B";<br />
then PXELINUX will try the following configuration files (in this order):<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>/mybootdir/pxelinux.cfg/b8945908-d6a6-41a9-611d-74a6ab80b83d<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>/mybootdir/pxelinux.cfg/01-88-99-aa-bb-cc-dd<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>/mybootdir/pxelinux.cfg/C0A8025B<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>/mybootdir/pxelinux.cfg/C0A8025<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>/mybootdir/pxelinux.cfg/C0A802<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>/mybootdir/pxelinux.cfg/C0A80<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>/mybootdir/pxelinux.cfg/C0A8<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>/mybootdir/pxelinux.cfg/C0A<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>/mybootdir/pxelinux.cfg/C0<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>/mybootdir/pxelinux.cfg/C<br />
<span class="Apple-tab-span" style="white-space: pre;"> </span>/mybootdir/pxelinux.cfg/default<br />
Let's see now what exactly the above example represents.<br />
After attempting the file as specified in the DHCP or hardcoded options, PXELINUX will probe the following paths, prefixed with "pxelinux.cfg/", under the initial Working<br />
<br />
Directory.<br />
The client UUID, if provided by the PXE stack.<br />
Note that some BIOSes do not have a valid UUID, and it might end up reporting something like all 1's.<br />
This value is represented in the standard UUID format using lowercase hexadecimal digits, e.g. "b8945908-d6a6-41a9-611d-74a6ab80b83d".<br />
The hardware type (using its ARP type code) and address, all in lowercase hexadecimal with dash separators.<br />
For example, for an Ethernet (ARP type "1") with address "88:99:AA:BB:CC:DD", it would search for the filename "01-88-99-aa-bb-cc-dd".<br />
The client's own IPv4 address in uppercase hexadecimal, followed by removing hex characters, one at a time, from the end. For example, "192.168.2.91" → "C0A8025B".<br />
The included program, "gethostip", can be used to compute the hexadecimal IP address for any host.<br />
Lowercase "default".<br />
<br />
<br />
1:首先,需要的工具包有 dnsmasq,samba, nfs-utils,openssh,syslinux<br />
<br />
dnsmasq = 充当dhcp和tftpserver<br />
samba = 安装windows使用,另外也为了方便windows机器管理<br />
nfs-utils = 加载linux镜像用<br />
openssh = 管理用,ssh登录很方便,毕竟这台机器是个小的服务器吧<br />
syslinux = 启动pxelinux以及各种启动程序<br />
<br />
arch下很简单,一条命令<br />
<br />
pacman -S dnsmasq samba nfs-utils openssh syslinux<br />
<br />
2:然后就是配置dhcp和tftp server,以及nfs 和 ssh server了<br />
<br />
<br />
直接贴配置文件比较省事<br />
dnsmasq为了配置方便,我在/etc/dnsmasq.d/重建了一个pxe.conf的配置文件,配置如下<br />
<br />
记住要把/etc/dnsmasq.conf里面下面这句话取消注释<br />
<br />
<br />
# Include another lot of configuration options.<br />
#conf-file=/etc/dnsmasq.more.conf<br />
conf-dir=/etc/dnsmasq.d<br />
<br />
<br />
# function as a tftp server 启动tftpserver<br />
enable-tftp<br />
# root directory for files available via ftp. ftp的root环境<br />
tftp-root=/tftpboot<br />
# the boot filename<br />
#pxe-service=X86PC,"PXE Boot Menu",pxelinux 启动文件<br />
dhcp-boot=/tftpboot/pxelinux.0<br />
# kill multicast<br />
#dhcp-option=vendor:PXEClient,6,2b<br />
# disable reuse of the dhcp servername and filename fields as extra.<br />
# option space. to avoid confusing some old or broken dhcp clients.<br />
dhcp-no-override<br />
# This range(s) is for the public interface, where dnsmasq functions<br />
# as a proxy DHCP server providing boot information but no IP leases.<br />
# Any ip in the subnet will do, so you may just put your server NIC ip here.<br />
# I used my router ip address<br />
#dhcp-range=192.168.2.1,proxy,255.255.255.0<br />
<br />
#dhcp-range=192.168.2.100,proxy<br />
# do not give IPs that are in pool of DSL routers DHCP 我避开了家里路由器的dhcp缺省池<br />
dhcp-range=192.168.2.151,192.168.2.200,12h<br />
# router/gateway ip address<br />
dhcp-option=3,192.168.2.1<br />
# dns server ip address<br />
dhcp-option=6,192.168.2.1<br />
# enable logging<br />
log-dhcp<br />
log-queries<br />
<br />
<br />
samba的配置文件smb.conf<br />
在windows下直接在文件浏览器中打入\\192.168.2.19,就可以打开tftpboot文件夹,直接管理里面的文件<br />
<br />
<br />
# This is the main Samba configuration file. You should read the<br />
# smb.conf(5) manual page in order to understand the options listed<br />
# here. Samba has a huge number of configurable options (perhaps too<br />
# many!) most of which are not shown in this example<br />
#<br />
# Any line which starts with a ; (semi-colon) or a # (hash)<br />
# is a comment and is ignored. In this example we will use a #<br />
# for commentry and a ; for parts of the config file that you<br />
# may wish to enable<br />
#<br />
# NOTE: Whenever you modify this file you should run the command "testparm"<br />
# to check that you have not made any basic syntactic errors.<br />
#<br />
#======================= Global Settings =====================================<br />
[global]<br />
<br />
# workgroup = NT-Domain-Name or Workgroup-Name<br />
workgroup = Workgroup<br />
<br />
# server string is the equivalent of the NT Description field<br />
server string = Samba Server<br />
<br />
# This option is important for security. It allows you to restrict<br />
# connections to machines which are on your local network. The<br />
# following example restricts access to two C class networks and<br />
# the "loopback" interface. For more examples of the syntax see<br />
# the smb.conf man page<br />
; hosts allow = 192.168.1. 192.168.2. 127.<br />
<br />
# if you want to automatically load your printer list rather<br />
# than setting them up individually then you'll need this<br />
printcap name = /etc/printcap<br />
load printers = yes<br />
<br />
# It should not be necessary to spell out the print system type unless<br />
# yours is non-standard. Currently supported print systems include:<br />
# bsd, sysv, plp, lprng, aix, hpux, qnx<br />
; printing = bsd<br />
<br />
# Uncomment this if you want a guest account, you must add this to /etc/passwd<br />
# otherwise the user "nobody" is used<br />
; guest account = pcguest<br />
<br />
# this tells Samba to use a separate log file for each machine<br />
# that connects<br />
log file = /var/log/samba/%m.log<br />
<br />
# Put a capping on the size of the log files (in Kb).<br />
max log size = 50<br />
<br />
# Security mode. Most people will want user level security. See<br />
# security_level.txt for details.<br />
security = user<br />
# security = share<br />
# Use password server option only with security = server<br />
; password server = <nt-server-name></nt-server-name><br />
<br />
# Password Level allows matching of _n_ characters of the password for<br />
# all combinations of upper and lower case.<br />
; username level = 8<br />
<br />
# You may wish to use password encryption. Please read<br />
# ENCRYPTION.txt, Win95.txt and WinNT.txt in the Samba documentation.<br />
# Do not enable this option unless you have read those documents<br />
; encrypt passwords = yes<br />
; smb passwd file = /etc/samba/smbpasswd<br />
<br />
# The following are needed to allow password changing from Windows to<br />
# update the Linux sytsem password also.<br />
# NOTE: Use these with 'encrypt passwords' and 'smb passwd file' above.<br />
# NOTE2: You do NOT need these to allow workstations to change only<br />
# the encrypted SMB passwords. They allow the Unix password<br />
# to be kept in sync with the SMB password.<br />
; unix password sync = Yes<br />
; passwd program = /usr/bin/passwd %u<br />
; passwd chat = *New*UNIX*password* %n\n *ReType*new*UNIX*password* %n\n *passwd:*all*authentication*tokens*updated*successfully*<br />
<br />
# Unix users can map to different SMB User names<br />
; username map = /etc/samba/smbusers<br />
# 开启 windows guest登录<br />
map to guest = Bad User<br />
<br />
# Using the following line enables you to customise your configuration<br />
# on a per machine basis. The %m gets replaced with the netbios name<br />
# of the machine that is connecting<br />
; include = /etc/samba/smb.conf.%m<br />
<br />
# Configure Samba to use multiple interfaces<br />
# If you have multiple network interfaces then you must list them<br />
# here. See the man page for details.<br />
; interfaces = 192.168.12.2/24 192.168.13.2/24<br />
<br />
# Configure remote browse list synchronisation here<br />
# request announcement to, or browse list sync from:<br />
#<span class="Apple-tab-span" style="white-space: pre;"> </span>a specific host or from / to a whole subnet (see below)<br />
; remote browse sync = 192.168.3.25 192.168.5.255<br />
# Cause this host to announce itself to local subnets here<br />
; remote announce = 192.168.1.255 192.168.2.44<br />
<br />
# Browser Control Options:<br />
# set local master to no if you don't want Samba to become a master<br />
# browser on your network. Otherwise the normal election rules apply<br />
; local master = no<br />
<br />
# OS Level determines the precedence of this server in master browser<br />
# elections. The default value should be reasonable<br />
; os level = 33<br />
<br />
# Domain Master specifies Samba to be the Domain Master Browser. This<br />
# allows Samba to collate browse lists between subnets. Don't use this<br />
# if you already have a Windows NT domain controller doing this job<br />
; domain master = yes<br />
domain master = auto<br />
<br />
# Preferred Master causes Samba to force a local browser election on startup<br />
# and gives it a slightly higher chance of winning the election<br />
; preferred master = yes<br />
<br />
# Use only if you have an NT server on your network that has been<br />
# configured at install time to be a primary domain controller.<br />
; domain controller = <nt-domain-controller-smbname></nt-domain-controller-smbname><br />
<br />
# Enable this if you want Samba to be a domain logon server for<br />
# Windows95 workstations.<br />
; domain logons = yes<br />
<br />
# if you enable domain logons then you may want a per-machine or<br />
# per user logon script<br />
# run a specific logon batch file per workstation (machine)<br />
; logon script = %m.bat<br />
# run a specific logon batch file per username<br />
; logon script = %U.bat<br />
<br />
# Where to store roving profiles (only for Win95 and WinNT)<br />
# %L substitutes for this servers netbios name, %U is username<br />
# You must uncomment the [Profiles] share below<br />
; logon path = \\%L\Profiles\%U<br />
<br />
# All NetBIOS names must be resolved to IP Addresses<br />
# 'Name Resolve Order' allows the named resolution mechanism to be specified<br />
# the default order is "host lmhosts wins bcast". "host" means use the unix<br />
# system gethostbyname() function call that will use either /etc/hosts OR<br />
# DNS or NIS depending on the settings of /etc/host.config, /etc/nsswitch.conf<br />
# and the /etc/resolv.conf file. "host" therefore is system configuration<br />
# dependant. This parameter is most often of use to prevent DNS lookups<br />
# in order to resolve NetBIOS names to IP Addresses. Use with care!<br />
# The example below excludes use of name resolution for machines that are NOT<br />
# on the local network segment<br />
# - OR - are not deliberately to be known via lmhosts or via WINS.<br />
; name resolve order = wins lmhosts bcast<br />
<br />
# Windows Internet Name Serving Support Section:<br />
# WINS Support - Tells the NMBD component of Samba to enable it's WINS Server<br />
; wins support = yes<br />
<br />
# WINS Server - Tells the NMBD components of Samba to be a WINS Client<br />
#<span class="Apple-tab-span" style="white-space: pre;"> </span>Note: Samba can be either a WINS Server, or a WINS Client, but NOT both<br />
; wins server = w.x.y.z<br />
<br />
# WINS Proxy - Tells Samba to answer name resolution queries on<br />
# behalf of a non WINS capable client, for this to work there must be<br />
# at least one<span class="Apple-tab-span" style="white-space: pre;"> </span>WINS Server on the network. The default is NO.<br />
; wins proxy = yes<br />
<br />
# DNS Proxy - tells Samba whether or not to try to resolve NetBIOS names<br />
# via DNS nslookups. The built-in default for versions 1.9.17 is yes,<br />
# this has been changed in version 1.9.18 to no.<br />
dns proxy = no<br />
<br />
# Case Preservation can be handy - system default is _no_<br />
# NOTE: These can be set on a per share basis<br />
; preserve case = no<br />
; short preserve case = no<br />
# Default case is normally upper case for all DOS files<br />
; default case = lower<br />
# Be very careful with case sensitivity - it can break things!<br />
; case sensitive = no<br />
<br />
#============================ Share Definitions ==============================<br />
[homes]<br />
comment = Home Directories<br />
browseable = no<br />
writable = yes<br />
<br />
# Un-comment the following and create the netlogon directory for Domain Logons<br />
; [netlogon]<br />
; comment = Network Logon Service<br />
; path = /home/netlogon<br />
; guest ok = yes<br />
; writable = no<br />
; share modes = no<br />
<br />
<br />
# Un-comment the following to provide a specific roving profile share<br />
# the default is to use the user's home directory<br />
;[Profiles]<br />
; path = /home/profiles<br />
; browseable = no<br />
; guest ok = yes<br />
<br />
<br />
# NOTE: If you have a BSD-style print system there is no need to<br />
# specifically define each individual printer<br />
[printers]<br />
comment = All Printers<br />
path = /var/spool/samba<br />
browseable = no<br />
# Set public = yes to allow user 'guest account' to print<br />
guest ok = no<br />
writable = no<br />
printable = yes<br />
<br />
# This one is useful for people to share files<br />
;[tmp]<br />
; comment = Temporary file space<br />
; path = /tmp<br />
; read only = no<br />
; public = yes<br />
<br />
# A publicly accessible directory, but read only, except for people in<br />
# the "staff" group<br />
;[public]<br />
; comment = Public Stuff<br />
; path = /home/samba<br />
; public = yes<br />
; read only = yes<br />
; write list = @staff<br />
<br />
# Other examples.<br />
#<br />
# A private printer, usable only by fred. Spool data will be placed in fred's<br />
# home directory. Note that fred must have write access to the spool directory,<br />
# wherever it is.<br />
;[fredsprn]<br />
; comment = Fred's Printer<br />
; valid users = fred<br />
; path = /homes/fred<br />
; printer = freds_printer<br />
; public = no<br />
; writable = no<br />
; printable = yes<br />
<br />
# A private directory, usable only by fred. Note that fred requires write<br />
# access to the directory.<br />
;[fredsdir]<br />
; comment = Fred's Service<br />
; path = /usr/somewhere/private<br />
; valid users = fred<br />
; public = no<br />
; writable = yes<br />
; printable = no<br />
<br />
# a service which has a different directory for each machine that connects<br />
# this allows you to tailor configurations to incoming machines. You could<br />
# also use the %u option to tailor it by user name.<br />
# The %m gets replaced with the machine name that is connecting.<br />
;[pchome]<br />
; comment = PC Directories<br />
; path = /usr/pc/%m<br />
; public = no<br />
; writable = yes<br />
<br />
# A publicly accessible directory, read/write to all users. Note that all files<br />
# created in the directory by users will be owned by the default user, so<br />
# any user with access can delete any other user's files. Obviously this<br />
# directory must be writable by the default user. Another user could of course<br />
# be specified, in which case all files would be owned by that user instead.<br />
;[public]<br />
; path = /usr/somewhere/else/public<br />
; public = yes<br />
; only guest = yes<br />
; writable = yes<br />
; printable = no<br />
<br />
# The following two entries demonstrate how to share a directory so that two<br />
# users can place files there that will be owned by the specific users. In this<br />
# setup, the directory should be writable by both users and should have the<br />
# sticky bit set on it to prevent abuse. Obviously this could be extended to<br />
# as many users as required.<br />
;[myshare]<br />
; comment = Mary's and Fred's stuff<br />
; path = /usr/somewhere/shared<br />
; valid users = mary fred<br />
; public = no<br />
; writable = yes<br />
; printable = no<br />
; create mask = 0765<br />
<br />
[tftpboot]<br />
comment = TFTP + PXE<br />
path = /tftpboot/<br />
public = yes<br />
only guest = yes<br />
browseable = yes<br />
read only = no<br />
writable = yes<br />
create mask = 0644<br />
directory mask = 0755<br />
# force create mask = 0644<br />
# force directory mask = 0755<br />
force user = root<br />
force group = root<br />
<br />
<br />
<br />
<br />
<br />
nfs的配置文件 exports<br />
<br />
<br />
# /etc/exports - exports(5) - directories exported to NFS clients<br />
#<br />
# Example for NFSv2 and NFSv3:<br />
# /srv/home hostname1(rw,sync) hostname2(ro,sync)<br />
# Example for NFSv4:<br />
# /srv/nfs4<span class="Apple-tab-span" style="white-space: pre;"> </span> hostname1(rw,sync,fsid=0)<br />
# /srv/nfs4/home hostname1(rw,sync,nohide)<br />
# Using Kerberos and integrity checking:<br />
# /srv/nfs4 *(rw,sync,sec=krb5i,fsid=0)<br />
# /srv/nfs4/home *(rw,sync,sec=krb5i,nohide)<br />
#<br />
# Use `exportfs -arv` to reload.<br />
#/tftpboot/images/ARCH_201510/ 192.168.2.0/24(ro,no_subtree_check)<br />
/tftpboot/images/ARCH_201510/ *(ro,no_subtree_check,async,no_root_squash)<br />
/tftpboot/images/kali2/ *(ro,no_subtree_check,async,no_root_squash)<br />
<br />
<br />
3:接着配置tftpboot主目录<br />
<br />
makdir /tftpboot/{images,iso,syslinux,pxelinux.cfg}<br />
<br />
其中images文件夹是挂载的linux安装镜像和windows安装镜像<br />
<br />
iso文件夹里是我各种安装iso文件的收集地点<br />
<br />
syslinux文件夹里是syslinux各种模块的收藏地点<br />
<br />
pxelinux.cfg目录里存放着pxelinux的启动配置文件,也就是目录文件<br />
<br />
然后把各种pxelinux启动相关的文件,拷贝入tftpboot目录,和syslinux目录<br />
<br />
<br />
cp /usr/lib/syslinux/bios/pxelinux.0 /tftpboot/<br />
cp /usr/lib/syslinux/bios/{chain.c32,hdt.c32,ldlinux.c32,libcom32.c32,libgpl.c32,libmenu.c32,libutil.c32,poweroff.c32,reboot.c32,vesamenu.c32} /tftpboot/syslinux/<br />
<br />
其中<br />
pxelinux.0是启动文件,hdt是用来显示机器的各种配置的,chain.c32是用来启动本地硬盘的,lib文件都是各种库,poweroff和reboot大家都懂的.<br />
<br />
最后就是/tftpboot/pxelinux.cfg/default配置文件的内容了,这个内容是根据我的机器挂载的镜像修改的<br />
<br />
<br />
<br />
UI syslinux/vesamenu.c32<br />
TIMEOUT 600<br />
ONTIMEOUT Boot Local<br />
PROMPT 0<br />
NOESCAPE 1<br />
ALLOWOPTIONS 1<br />
<br />
menu hshift 5<br />
menu width 59<br />
<br />
menu title pxe boot menu<br />
<br />
menu color title * #ffffffff *<br />
menu color border * #00000000 #00000000 none<br />
menu color sel * #ffffffff #76a1d0ff *<br />
menu color hotsel 1;7;37;40 #ffffffff #76a1d0ff *<br />
menu color tabmsg * #ffffffff #00000000 *<br />
menu color help 37;40 #ffdddd00 #00000000 none<br />
menu vshift 2<br />
menu rows 20<br />
menu helpmsgrow 25<br />
# the command line must be at least one line from the bottom.<br />
menu cmdlinerow 26<br />
menu timeoutrow 26<br />
menu tabmsgrow 28<br />
menu tabmsg press enter to boot or tab to edit a menu entry<br />
<br />
<br />
label boot local<br />
COM32 syslinux\chain.c32<br />
APPEND hd0<br />
text help<br />
boot to local hard disk<br />
endtext<br />
<br />
label winpe3 32 (cn)<br />
kernel syslinux/memdisk<br />
append iso raw<br />
initrd iso/winpe_x86.iso<br />
text help<br />
boot to windows pe 3 32bit iso (~184mb)<br />
endtext<br />
<br />
label winpe3 64 (cn)<br />
MENU LABEL Autoinstall win10-amd64<br />
kernel syslinux/memdisk<br />
append iso raw<br />
initrd iso/winpe_amd64.iso<br />
text help<br />
boot to windows pe 3 64bit iso (~207mb)<br />
autoinstall win10 64<br />
endtext<br />
<br />
LABEL Arch32_(NFS)<br />
TEXT HELP<br />
Boot the Arch Linux (i686) live medium (Using NFS).<br />
It allows you to install Arch Linux or perform system maintenance.<br />
ENDTEXT<br />
MENU LABEL Install Arch Linux (i686) (NFS)<br />
LINUX images/ARCH_201510/arch/boot/i686/vmlinuz<br />
INITRD images/ARCH_201510/arch/boot/intel_ucode.img,images/ARCH_201510/arch/boot/i686/archiso.img<br />
APPEND archisobasedir=arch archiso_nfs_srv=192.168.2.19:/tftpboot/images/ARCH_201510 ip=:::::eth0:dhcp<br />
<br />
LABEL Arch64 (NFS)<br />
TEXT HELP<br />
Boot the Arch Linux (x86_64) live medium (Using NFS).<br />
It allows you to install Arch Linux or perform system maintenance.<br />
ENDTEXT<br />
MENU LABEL Install Arch Linux (x86_64) (NFS)<br />
LINUX images/ARCH_201510/arch/boot/x86_64/vmlinuz<br />
INITRD images/ARCH_201510/arch/boot/intel_ucode.img,images/ARCH_201510/arch/boot/x86_64/archiso.img<br />
APPEND archisobasedir=arch archiso_nfs_srv=192.168.2.19:/tftpboot/images/ARCH_201510 ip=:::::eth0:dhcp<br />
<br />
LABEL kali2 live(amd64)<br />
TEXT HELP<br />
Boot to Kali 2.0 (sana) amd64 Live<br />
ENDTEXT<br />
MENU LABEL Kali 2.0 Live(amd64)<br />
KERNEL images/kali2/live/vmlinuz<br />
INITRD images/kali2/live/initrd.img<br />
APPEND netboot=nfs nfsroot=192.168.2.19:/tftpboot/images/kali2 boot=live username=root hostname=kali<br />
<br />
# http://www.memtest.org/<br />
LABEL memtest<br />
MENU LABEL Run Memtest86+ (RAM test)<br />
LINUX memtest<br />
<br />
# http://hdt-project.org/<br />
LABEL hdt<br />
MENU LABEL Hardware Information (HDT)<br />
COM32 syslinux/hdt.c32<br />
APPEND modules_alias=syslinux/hdt/modalias.gz pciids=syslinux/hdt/pciids.gz<br />
<br />
LABEL reboot<br />
MENU LABEL Reboot<br />
COM32 syslinux/reboot.c32<br />
<br />
LABEL poweroff<br />
MENU LABEL Power Off<br />
COM32 syslinux/poweroff.c32<br />
<br />
<br />
期间还自己学会了自制winpe,我做了2个版本的winpe,一个32位,一个64位.<br />
<br />
<br />
最后,只要把要安装的机器修改为网卡启动,就可以进入我配置的pxe server了<br />
<br />
如下图<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgjKMfMO79RnkEkKBk20cyVx24-x_6Uqquk1CcK2brVtxA0ujuFpYhJAoVIe8JJV1pR2e7B3-eaRzbhWuvHoBEh1tEjEFqY609IoDv9FtVO34f0O8gBInaaokvZo-0BovjivC1iz_QS4ryj/s1600/pxe.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="177" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEgjKMfMO79RnkEkKBk20cyVx24-x_6Uqquk1CcK2brVtxA0ujuFpYhJAoVIe8JJV1pR2e7B3-eaRzbhWuvHoBEh1tEjEFqY609IoDv9FtVO34f0O8gBInaaokvZo-0BovjivC1iz_QS4ryj/s320/pxe.png" width="320" /></a></div>
<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhkuy22b-7Zf07FQsgIC4W2JH6ZRQyt1pEFdLjIWjlaHP0XyGOsoWTNAAY3oQ9CAMXwHhKpxiNXNmuqk9n6B4t-yln0WAFqw2dC46LKpbaKc7s02eeI9RQ74i67b52GDw7DFFfZHD5nGtdx/s1600/pxeserver.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="240" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhkuy22b-7Zf07FQsgIC4W2JH6ZRQyt1pEFdLjIWjlaHP0XyGOsoWTNAAY3oQ9CAMXwHhKpxiNXNmuqk9n6B4t-yln0WAFqw2dC46LKpbaKc7s02eeI9RQ74i67b52GDw7DFFfZHD5nGtdx/s320/pxeserver.png" width="320" /></a></div>
<br />Anonymoushttp://www.blogger.com/profile/15470207574707724400noreply@blogger.com0中国山西省阳泉市37.856972 113.5805189999999837.856972 113.58051899999998 37.856972 113.58051899999998tag:blogger.com,1999:blog-6616068516723546448.post-37321494911710500222011-11-13T12:32:00.001+08:002011-11-13T12:33:57.993+08:00让你提升命令行效率的 Bash 快捷键 [完整版]<a href="http://linuxtoy.org/archives/bash-shortcuts.html">让你提升命令行效率的 Bash 快捷键 [完整版]</a>: <p><a href="http://feedads.g.doubleclick.net/~a/4wCzrwhkeQwlrmBlpZgIxylUS40/0/da"><img src="http://feedads.g.doubleclick.net/~a/4wCzrwhkeQwlrmBlpZgIxylUS40/0/di" border="0" ismap></a><br><br /><a href="http://feedads.g.doubleclick.net/~a/4wCzrwhkeQwlrmBlpZgIxylUS40/1/da"><img src="http://feedads.g.doubleclick.net/~a/4wCzrwhkeQwlrmBlpZgIxylUS40/1/di" border="0" ismap></a></p><p>生活在 Bash shell<br />中,熟记以下快捷键,将极大的提高你的命令行操作效率。<span></span> </p><br /><br /><h3>编辑命令</h3><br /><br /><ul><br /><li>Ctrl + a :移到命令行首</li><br /><li>Ctrl + e :移到命令行尾</li><br /><li>Ctrl + f :按字符前移(右向)</li><br /><li>Ctrl + b :按字符后移(左向)</li><br /><li>Alt + f :按单词前移(右向)</li><br /><li>Alt + b :按单词后移(左向)</li><br /><li>Ctrl + xx:在命令行首和光标之间移动</li><br /><li>Ctrl + u :从光标处删除至命令行首</li><br /><li>Ctrl + k :从光标处删除至命令行尾</li><br /><li>Ctrl + w :从光标处删除至字首</li><br /><li>Alt + d :从光标处删除至字尾</li><br /><li>Ctrl + d :删除光标处的字符</li><br /><li>Ctrl + h :删除光标前的字符</li><br /><li>Ctrl + y :粘贴至光标后</li><br /><li>Alt + c :从光标处更改为首字母大写的单词</li><br /><li>Alt + u :从光标处更改为全部大写的单词</li><br /><li>Alt + l :从光标处更改为全部小写的单词</li><br /><li>Ctrl + t :交换光标处和之前的字符</li><br /><li>Alt + t :交换光标处和之前的单词</li><br /><li>Alt + Backspace:与 Ctrl + w 相同</li><br /></ul><br /><br /><h3>重新执行命令</h3><br /><br /><ul><br /><li>Ctrl + r:逆向搜索命令历史</li><br /><li>Ctrl + g:从历史搜索模式退出</li><br /><li>Ctrl + p:历史中的上一条命令</li><br /><li>Ctrl + n:历史中的下一条命令</li><br /><li>Alt + .:使用上一条命令的最后一个参数</li><br /></ul><br /><br /><h3>控制命令</h3><br /><br /><ul><br /><li>Ctrl + l:清屏</li><br /><li>Ctrl + o:执行当前命令,并选择上一条命令</li><br /><li>Ctrl + s:阻止屏幕输出</li><br /><li>Ctrl + q:允许屏幕输出</li><br /><li>Ctrl + c:终止命令</li><br /><li>Ctrl + z:挂起命令</li><br /></ul><br /><br /><h3>Bang (!) 命令</h3><br /><br /><ul><br /><li>!!:执行上一条命令</li><br /><li>!blah:执行最近的以 blah 开头的命令,如 !ls</li><br /><li>!blah:p:仅打印输出,而不执行</li><br /><li>!$:上一条命令的最后一个参数,与 Alt + . 相同</li><br /><li>!$:p:打印输出 !$ 的内容</li><br /><li>!*:上一条命令的所有参数</li><br /><li>!*:p:打印输出 !* 的内容</li><br /><li>^blah:删除上一条命令中的 blah</li><br /><li>^blah^foo:将上一条命令中的 blah 替换为 foo</li><br /><li>^blah^foo^:将上一条命令中所有的 blah 都替换为 foo</li><br /></ul><br /><br /><p><em>友情提示</em>:</p><br /><br /><ol><br /><li>以上介绍的大多数 Bash 快捷键仅当在 emacs 编辑模式时有效,若你将 Bash<br />配置为 vi 编辑模式,那将遵循 vi 的按键绑定。Bash 默认为 emacs<br />编辑模式。如果你的 Bash 不在 emacs 编辑模式,可通过 <code>set -o emacs</code> 设置。</li><br /><li>^S、^Q、^C、^Z 是由终端设备处理的,可用 <code>stty</code> 命令设置。</li><br /></ol>Anonymoushttp://www.blogger.com/profile/15470207574707724400noreply@blogger.com0tag:blogger.com,1999:blog-6616068516723546448.post-13373253979517420192011-11-07T18:25:00.001+08:002011-11-07T19:52:23.752+08:00linux中查看系统资源占用情况的命令<div class="cnt" id="blog_text">
<span style="font-size: medium;"><span style="font-size: 18px;">top:</span></span><br />
主要参数<br />
d:指定更新的间隔,以秒计算。<br />
q:没有任何延迟的更新。如果使用者有超级用户,则top命令将会以最高的优先序执行。<br />
c:显示进程完整的路径与名称。<br />
S:累积模式,会将己完成或消失的子行程的CPU时间累积起来。<br />
s:安全模式。<br />
i:不显示任何闲置(Idle)或无用(Zombie)的行程。<br />
n:显示更新的次数,完成后将会退出to<br />
显示参数:<br />
PID(Process ID):进程标示号。<br />
USER:进程所有者的用户名。<br />
PR:进程的优先级别。<br />
NI:进程的优先级别数值。<br />
VIRT:进程占用的虚拟内存值。<br />
RES:进程占用的物理内存值。<br />
SHR:进程使用的共享内存值。<br />
S:进程的状态,其中S表示休眠,R表示正在运行,Z表示僵死状态,N表示该进程优先值是负数。<br />
%CPU:该进程占用的CPU使用率。<br />
%MEM:该进程占用的物理内存和总内存的百分比。<br />
TIME+:该进程启动后占用的总的CPU时间。<br />
Command:进程启动的启动命令名称,如果这一行显示不下,进程会有一个完整的命令行。<br />
top命令使用过程中,还可以使用一些交互的命令来完成其它参数的功能。这些命令是通过快捷键启动的。<br />
<空格>:立刻刷新。<br />
P:根据CPU使用大小进行排序。<br />
T:根据时间、累计时间排序。<br />
q:退出top命令。<br />
m:切换显示内存信息。<br />
t:切换显示进程和CPU状态信息。<br />
c:切换显示命令名称和完整命令行。<br />
M:根据使用内存大小进行排序。<br />
W:将当前设置写入~/.toprc文件中。这是写top配置文件的推荐方法。<br />
<br />
<span style="font-size: medium;"><span style="font-size: 18px;">free</span></span><br />
1.作用<br />
free命令用来显示内存的使用情况,使用权限是所有用户。<br />
<br />
2.格式<br />
free [-b-k-m] [-o] [-s delay] [-t] [-V]<br />
<br />
3.主要参数<br />
-b -k -m:分别以字节(KB、MB)为单位显示内存使用情况。<br />
-s delay:显示每隔多少秒数来显示一次内存使用情况。<br />
-t:显示内存总和列。<br />
-o:不显示缓冲区调节列。<br />
<br />
<span style="font-size: medium;"><span style="font-size: 18px;">uptime</span></span><br />
18:59:15 up 25 min, 2 users, load average: 1.23, 1.32, 1.21<br />
现在的时间<br />
系统开机运转到现在经过的时间<br />
连线的使用者数量<br />
最近一分钟,五分钟和十五分钟的系统负载<br />
参数: -V 显示版本资讯。<br />
<br />
<span style="font-size: medium;"><span style="font-size: 18px;">vmstat</span></span><br />
procs -----------memory---------- ---swap-- -----io---- --system-- ----cpu----<br />
r b swpd free buff cache si so bi bo in cs us sy id wa<br />
0 1 24980 10792 8296 47316 5 19 205 52 1161 698 26 3 1 70<br />
1 观察磁盘活动情况<br />
磁盘活动情况主要从以下几个指标了解:<br />
bi:表示从磁盘每秒读取的块数(blocks/s)。数字越大,表示读磁盘的活动越多。<br />
bo:表示每秒写到磁盘的块数(blocks/s)。数字越大,表示写磁盘的活动越多。<br />
wa:cpu等待磁盘I/O(未决的磁盘IO)的时间比例。数字越大,表示文件系统活动阻碍cpu的情况越严重,因为cpu在等待慢速的磁盘系统提供数据。wa为0是最理想的。如果wa经常大于10,可能文件系统就需要进行性能调整了。<br />
2 观察cpu活动情况<br />
vmstat比top更能反映出cpu的使用情况:<br />
us:用户程序使用cpu的时间比例。这个数字越大,表示用户进程越繁忙。<br />
sy:
系统调用使用cpu的时间比例。注意,NFS由于是在内核里面运行的,所以NFS活动所占用的cpu时间反映在sy里面。这个数字经常很大的话,就需要注
意是否某个内核进程,比如NFS任务比较繁重。如果us和sy同时都比较大的话,就需要考虑将某些用户程序分离到另外的服务器上面,以免互相影响。<br />
id:cpu空闲的时间比例。<br />
wa:cpu等待未决的磁盘IO的时间比例。<br />
<br />
<span style="font-size: medium;"><span style="font-size: 18px;">iostat</span></span><br />
用于统计CPU的使用情况及tty设备、硬盘和CD-ROM的I/0量<br />
参数:<br />
-c 只显示CPU行<br />
-d 显示磁盘行<br />
-k 以千字节为单位显示磁盘输出<br />
-t 在输出中包括时间戳<br />
-x 在输出中包括扩展的磁盘指标<br />
<br />
avg-cpu: %user %nice %sys %iowait %idle<br />
20.25 0.18 2.61 76.39 0.57<br />
%iowait 等待本地I/O时CPU空闲时间的百分比<br />
%idle 未等待本地I/O时CPU空闲时间的百分比<br />
<br />
Device: tps Blk_read/s Blk_wrtn/s Blk_read Blk_wrtn<br />
hda 9.86 284.34 84.48 685407 2036<br />
每秒传输数(tps)、每秒512字节块读取数(Blk_read/s)、每秒512字节块写入数(Blk_wrtn/s)和512字节块读取(Blk_read)和写入(Blk_wrtn)的总数量。<br />
<br />
<b>一、如何查看服务器的CPU</b><br />
今天安装了9台Linux服务器,型号完全不一样(有DELL、HP和IBM服务器),又懒得去对清单,如何在Linux下cpu的个数和核数呢?
另外,nginx的cpu工作模式也需要确切的知道linux服务器到底有多少个逻辑cpu,不过现在服务器那是相当的彪悍,直接上
worker_processes 8吧。<br />
判断依据:<br />
1.具有相同core id的cpu是同一个core的超线程。(Physical id and core id are not
necessarily consecutive but they are unique. Any cpu with the same core
id are hyperthreads in the same core.)<br />
2.具有相同physical id的cpu是同一颗cpu封装的线程或者cores。(Any cpu with the same physical id are threads or cores in the same physical socket.)<br />
以自己的惠普DL380G6为例说明:<br />
①物理cpu个数:<br />
[root@localhost ~]# cat /proc/cpuinfo | grep "physical id" | sort | uniq | wc -l<br />
②每个物理cpu中core的个数(即核数)<br />
[root@localhost ~]# cat /proc/cpuinfo | grep "cpu cores" | uniq<br />
cpu cores : 4<br />
这样可以推算出自己服务器的逻辑CPU为物理个数*核数,如果你的服务器是server2003,你可以在你的资源管理器里以图形化方式看到你的逻辑CPU个数。<br />
<br />
<b>二、查看服务器的内存情况</b><br />
有时候,你运行了许多大的进程,比如你开启了300个fast-cgi。这时候你感觉系统很慢,便需要查看服务器的内存情况:<br />
[root@server ~]# free -m<br />
total used free shared buffers cached<br />
Mem: 249 163 86 0 10 94<br />
-/+ buffers/cache: 58 191<br />
Swap: 511 0 511<br />
参数解释:<br />
total 内存总数<br />
used 已经使用的内存数<br />
free 空闲的内存数<br />
shared 多个进程共享的内存总额<br />
buffers Buffer
Cache和cached Page Cache 磁盘缓存的大小<br />
-buffers/cache (已用)的内存数:used - buffers -
cached<br />
+buffers/cache(可用)的内存数:free + buffers + cached<br />
可用的memory=free
memory+buffers+cached<br />
上面的数值是一台我公司内网供PHP开发人员使用的DELL PE2850,内存为2G的服务器,其可使用内存为=217+515+826。记住,Linux的内存使用管理机制是有多少就用多少(特别是在频繁存取文件后),即Linux内存不是拿来看的,是拿来用的。<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiNWY_iAjig0bpx05eXveAbiCwHRelsk7idxyB89MHPQVlU56T0ULK0f9qNxM62OFC1goWCThiwK-7VUK4J5zINNs8rrQrqlg9Us-iNMsKiLuKXuX2XcAyGaL4GjfacyR-UOQN3ovwi2OqN/s1600/f3826e0ee05b12b037d122a9.jpg" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiNWY_iAjig0bpx05eXveAbiCwHRelsk7idxyB89MHPQVlU56T0ULK0f9qNxM62OFC1goWCThiwK-7VUK4J5zINNs8rrQrqlg9Us-iNMsKiLuKXuX2XcAyGaL4GjfacyR-UOQN3ovwi2OqN/s1600/f3826e0ee05b12b037d122a9.jpg" /></a></div>
<br />
<br />
编辑推荐:<u style="color: orange;"><a href="http://os.51cto.com/art/201004/193160.htm" style="text-decoration: none;"><span style="color: orange;">Linux系统内存监控全面讲解:free命令</span></a></u><br />
<br />
<b>三、服务器磁盘使用情况</b><br />
有时感觉硬盘反映很慢,或需要查看日志所在分区时,下列命令可以查看磁盘的使用情况,很有用:<br />
①查看硬盘分区情况<br />
fdisk -l<br />
②查看当前硬盘使用情况<br />
df -h<br />
③查看硬盘性能<br />
# iostat -x 1 10<br />
Linux 2.6.18-92.el5xen 03/01/2010<br />
<br />
avg-cpu: %user
%nice %system %iowait %steal %idle<br />
1.10 0.00 4.82 39.54 0.07 54.46<br />
<br />
Device: rrqm/s wrqm/s r/s w/s rsec/s wsec/s avgrq-sz avgqu-sz await
svctm %util<br />
<br />
sda 0.00 3.50 0.40 2.50 5.60 48.00 18.48 0.00 0.97
0.97 0.28<br />
sdb 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00<br />
sdc 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00<br />
sdd 0.00 0.00
0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00<br />
sde 0.00 0.10 0.30 0.20
2.40 2.40 9.60 0.00 1.60 1.60 0.08<br />
sdf 17.40 0.50 102.00 0.20 12095.20
5.60 118.40 0.70 6.81 2.09 21.36<br />
sdg 232.40 1.90 379.70 0.50
76451.20 19.20 201.13 4.94 13.78 2.45 93.16<br />
像我们公司,开发人员占多数。有时为了节约成本,会同时采购一些性价比比较高的二手服务器;这时一般将服务器的硬件的工作模式设置为RAID1,同
时对几种型号的服务器作相同文件的写操作,然后各自执行iostat –d,作对比性测试。这样服务器的硬盘性能孰优孰劣,一下子就能对比出来。<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiy8RI7gEcUuiJmabshe7d38dV2yDA0Kfpno6UIgsgsGHW8T_MSbLCVRTRORcnpknUvtCHCGFMIjWzzs6cTJvu1vonKnFQ6BQx7e69o_i9KMaxnEioW5NUh2H0gEWHZc20VYk2f0pfaIqt-/s1600/2.jpg" imageanchor="1" style="clear: left; float: left; margin-bottom: 1em; margin-right: 1em;"><img border="0" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiy8RI7gEcUuiJmabshe7d38dV2yDA0Kfpno6UIgsgsGHW8T_MSbLCVRTRORcnpknUvtCHCGFMIjWzzs6cTJvu1vonKnFQ6BQx7e69o_i9KMaxnEioW5NUh2H0gEWHZc20VYk2f0pfaIqt-/s1600/2.jpg" /></a></div>
<br />
<br />
图解:<br />
Tps 该设备每秒I/O传输的次数(每秒的I/O请求)<br />
Blk_read/s 表求从该设备每秒读的数据块数量<br />
Blk_wrth/s 表示从该设备每秒写的数据块数量<br />
编辑推荐:<u><a href="http://os.51cto.com/art/201006/207694.htm" style="color: orange; text-decoration: none;">Linux系统监控之磁盘I/O篇</a></u><br />
<br />
<br />
<b>四、查看系统内核</b><br />
查看系统内核主要为了掌握其版本号,为安装LVS等软件做准备。<br />
uname –a<br />
有关查看内核信息的更多指令,可参考<u style="color: orange;"><a href="http://os.51cto.com/art/201005/202448.htm" style="text-decoration: none;"><span style="color: orange;">Linux查看版本信息及CPU内核、型号等</span></a></u>一文。有关Linux的内核优化,则可参考<u><a href="http://os.51cto.com/art/201003/190616.htm" style="color: orange; text-decoration: none;">Linux 2.6.31内核优化指南</a></u>一文。<br />
<br />
<b>五、查看服务器使用的Linux发行版的名称、版本号及描述信息等</b><br />
lsb_release -a<br />
这是我的某台用于SVN实验的vmware机器情况:<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhUu3AMJxjl4OTKUWEWT-3K3aR3TJqfexTyyen8ghTVEho_4Tt1Fs85qDcBFz7snyROzv6pkBhtkVrvkVEGy-Wohyk0Blp9D-Cb5c2jiumisAWIS2em2wqAem0hUjry4KVCaZ-9-rPiKqX7/s1600/3.jpg" imageanchor="1" style="clear: left; float: left; margin-bottom: 1em; margin-right: 1em;"><img border="0" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhUu3AMJxjl4OTKUWEWT-3K3aR3TJqfexTyyen8ghTVEho_4Tt1Fs85qDcBFz7snyROzv6pkBhtkVrvkVEGy-Wohyk0Blp9D-Cb5c2jiumisAWIS2em2wqAem0hUjry4KVCaZ-9-rPiKqX7/s1600/3.jpg" /></a></div>
<br />
<br />
<br />
<br />
<br />
<br />
<br />
<b>六、查看服务器的平均负载</b><br />
感觉到系统压力较大时用可top或uptime查看下服务器的平均负载。uptime的另一个用法是查看你的Linux服务器已经稳定运行多少天没有重启了,我这边的机器最高记录是360多天。<br />
<br />
<b>七、查看系统整体性能情况</b><br />
如果感觉系统比较繁忙,可以用vmstat查看系统整体性能情况。vmstat不仅仅适应于linux系统,它一样适用于FreeBSD等unix系统。<br />
vmstat 1 2<br />
如果 r经常大于 4 ,且id经常少于40,表示cpu的负荷很重。<br />
如果pi,po 长期不等于0,表示内存不足。<br />
如果disk 经常不等于0, 且在 b中的队列 大于3, 表示 io性能不好。<br />
编辑推荐:<u><a href="http://os.51cto.com/art/201005/200672.htm" style="color: orange; text-decoration: none;">Linux系统监控工具之vmstat详解</a></u><br />
<br />
<b>八、查看系统已载入的相关模块</b><br />
Linux操作系统的核心具有模块化的特性,应此在编译核心时,务须把全部的功能都放入核心。你可以将这些功能编译成一个个单独的模块,待需要时再分别载入。比如说在安装LVS+Keepalived,下列用法被经常用到:<br />
#检查内核模块,看一下ip_vs是否被加载 lsmod |grep ip_vsip_vs 77313 0<br />
如果要查看当前系统的已加载模块,直接lsmod。<br />
<br />
<b>九、Linux下查找PCI设置</b><br />
有时需要在Linux下查找PCI设置,可用lspci命令,它可以列出机器中的PCI 设备,比如声卡、显卡、Modem、网卡等,主板集成设备也能列出来。lspci 读取的是hwdata 数据库。有的小伙可能和我一样,最关心的还是网卡型号:<br />
[root@mail ~]# lspci | grep Ethernet<br />
03:00.0 Ethernet controller:
Broadcom Corporation NetXtreme II BCM5708 Gigabit Ethernet (rev 12)<br />
07:00.0 Ethernet controller: Broadcom Corporation NetXtreme II BCM5708
Gigabit Ethernet (rev 12)<br />
<br />
推荐阅读:<u style="color: orange;"><a href="http://os.51cto.com/art/201004/196757.htm" style="text-decoration: none;"><span style="color: orange;">七大实用命令行工具</span> <span style="color: orange;">玩转Linux网络配置</span></a></u>。至于网络流量的监控,建议用centos自带的工具iptraf,其用法可参考<u><a href="http://os.51cto.com/art/201006/206250.htm" style="color: orange; text-decoration: none;">这篇文章</a></u>。<br />
<br />
掌握上面这九条,你对你的Linux服务器的硬件信息基本就可以随时掌控了。</div>Anonymoushttp://www.blogger.com/profile/15470207574707724400noreply@blogger.com0tag:blogger.com,1999:blog-6616068516723546448.post-77679225622303525552011-11-07T17:54:00.000+08:002011-11-07T18:08:10.696+08:00freebsd 查看带宽占用情况,CPU,硬盘IO 虚拟内存等命令systat 能实时查看各种信息<br />
systat -pigs 默认值<u><b>CPU</b></u><br />
systat -iostat 硬盘IO<br />
systat -swap 交换分区<br />
systat -mbufs 网络缓冲区<br />
systat -vmstat 虚拟<u><b>内存</b></u><br />
systat -netstat 网络<br />
systat -icmp ICMP协议<br />
systat -ip IP协议<br />
systat -tcp TCP协议<br />
systat -ifstat 网卡<br />
<br />
<span id="more-11776"></span><br />
显示PCI总线设备信息<br />
pciconf -lv<br />
显示<u><b>内核</b></u>加载的模块<br />
kldstat -v<br />
显示指定模块<br />
kldstat -m ipfilter<br />
即插即用设备<br />
pnpinfo<br />
<br />
显示设备占用的IRQ和内存地址<br />
devinfo -u<br />
cpu<br />
<u><b>sysctl</b></u> -a|grep cpu<br />
sysctl -a|grep sched 查看使用的调度器,我编译的是ULE<br />
<br />
<br />
虚拟内存<br />
vmstat<br />
硬盘<br />
gstat<br />
systat -iostat<br />
iostat<br />
网卡<br />
ifconfig<br />
systat -ifstat<br />
网络<br />
netstat<br />
sockstat<br />
tcpdump<br />
trafshow<br />
systat -mbufs<br />
systat -icmp<br />
systat -ip<br />
systat -tcp<br />
只是看流量的话,用systat -netstatAnonymoushttp://www.blogger.com/profile/15470207574707724400noreply@blogger.com1tag:blogger.com,1999:blog-6616068516723546448.post-18491239305256972862011-11-07T12:46:00.003+08:002011-11-07T13:18:17.144+08:00freebsd 路由问题使用virtualbox安装的freebsd配置的nginx+php-fpm+mysql安装的wordpress无法使用no-ip的动态域名访问, 可是同样配置的arch上的wordpress却可以从外网无障碍访问?<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhT9BLmhOE9EnLATI25X_24jvszpYTR_TOTaLWay7F0pkmqdHPHHigUEJddOerSEPb7LRRxu2ggq4XuucBPShuFqMUFXA3MBuuyeiX3uNVvcXwSsdEfGMamSC16tznYusQhPudqioSxdUVJ/s1600/screenshot-2011-11-07-12-47-17.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="400" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhT9BLmhOE9EnLATI25X_24jvszpYTR_TOTaLWay7F0pkmqdHPHHigUEJddOerSEPb7LRRxu2ggq4XuucBPShuFqMUFXA3MBuuyeiX3uNVvcXwSsdEfGMamSC16tznYusQhPudqioSxdUVJ/s400/screenshot-2011-11-07-12-47-17.png" width="400" /></a></div>
<br />
<br />
使用路由的端口映射,把外网的80端口转给内网的虚拟机上,就是使用的<a href="http://en.wikipedia.org/wiki/Network_address_translation">NAT(network address translation)(网络地址转换) </a><br />
<br />
<br />
仔细研究了研究,2机的不同点只有ip,freebsd的ip为192.168.1.110,arch的ip为192.168.111<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEid3toCOaApHsMMU25E2LdCIm7D1k4K1PHm-DRXq1sg1a7ON6u8olrUTWBiJlhVmlwwO6r8vA2iT41Gp7Jro4IFnlPL-1N3OpEV8T695mZ0gB-ohjHUm73IvhgrzbAWJpMIGfFRQe72ECJs/s1600/screenshot-2011-11-07-12-33-48.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="400" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEid3toCOaApHsMMU25E2LdCIm7D1k4K1PHm-DRXq1sg1a7ON6u8olrUTWBiJlhVmlwwO6r8vA2iT41Gp7Jro4IFnlPL-1N3OpEV8T695mZ0gB-ohjHUm73IvhgrzbAWJpMIGfFRQe72ECJs/s400/screenshot-2011-11-07-12-33-48.png" width="368" /></a></div>
<div class="separator" style="clear: both; text-align: center;">
</div>
<br />
然后就想到是不是路由设置的问题?<br />
<br />
2台guest机为了和主机通信,都是使用的2个网卡,一个使用的NAT自动获取地址;1个使用的bridged 桥接网络来实现和 host机的链接.<br />
<br />
使用netstat -s 来察看<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEg7Vz1YVsPXXh0m2qjiSnrQZutgvY8erB_P3ZmyPVazHiFAc-QugP9tJ3MCoAKnFxXYlNNa51v3VT6yG3TY4-CXcFJw5u6_eIP3LBs-H3SrO8VSyoyBh2ONua62B3BptNxc_lbAE4wywDDb/s1600/screenshot-2011-11-07-12-22-54.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="341" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEg7Vz1YVsPXXh0m2qjiSnrQZutgvY8erB_P3ZmyPVazHiFAc-QugP9tJ3MCoAKnFxXYlNNa51v3VT6yG3TY4-CXcFJw5u6_eIP3LBs-H3SrO8VSyoyBh2ONua62B3BptNxc_lbAE4wywDDb/s400/screenshot-2011-11-07-12-22-54.png" width="400" /></a></div>
<br />
发现freebsd的设定为192.168.1.110的2号网卡em0没有设置网关....难道就是这个问题?<br />
<br />
最后,每个路由的不同属性可以在 <tt class="LITERAL">Flags</tt>
列中看到。下边是个关于这些标志和它们的含义的一个简表:
<a href="http://www.blogger.com/blogger.g?blogID=6616068516723546448" id="AEN39520" name="AEN39520"></a>
<br />
<table border="0" class="CALSTABLE" frame="void"><colgroup><col width="20%"></col>
<col width="80%"></col>
</colgroup><tbody>
<tr>
<td>U</td>
<td>Up: 路由处于活动状态。</td>
</tr>
<tr>
<td>H</td>
<td>Host: 路由目标是单个主机。</td>
</tr>
<tr>
<td>G</td>
<td>Gateway: 所有发到目的地的网络传到这一远程系统上, 并由它决定最后发到哪里。</td>
</tr>
<tr>
<td>S</td>
<td>Static: 这个路由是手工配置的,不是由系统自动生成的。</td>
</tr>
<tr>
<td>C</td>
<td>Clone: 生成一个新的路由, 通过这个路由我们可以连接上这些机子。
这种类型的路由通常用于本地网络。</td>
</tr>
<tr>
<td>W</td>
<td>WasCloned: 指明一个路由——它是基于本地区域网络 (克隆) 路由自动配置的。</td>
</tr>
<tr>
<td>L</td>
<td>Link: 路由涉及到了以太网硬件。</td></tr>
</tbody></table>
<br />
通过修改/etc/rc.conf 文件,给em0网卡添加路由<br />
<br />
<div class="separator" style="clear: both; text-align: center;">
</div>
在/etc/rc.conf中,添加<br />
defaultrouter="192.168.1.1"<br />
<br />
然后重启网络服务<br />
# /etc/rc.d/netif restart <br />
注意: 如果在 /etc/rc.conf 中配置了默认网关, 还需要运行下面的命令:<br />
# /etc/rc.d/routing restart<br />
<br />
<br />
然后,使用noip注册的域名来访问,OK啦!<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi9HCP-u9Z2LTCF-7WJilQ54Jq1QMyPzPutLNJbTRCPecEP2NdsxmbzI6gONNIBpb8Vu1gbw-KfpXq5VinXSYafPGBkuX35VSej_POb72_brCrZhtj4YcNR8oDJ2snjtchoZhO6DwMwaEPg/s1600/screenshot-2011-11-07-13-16-21.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="398" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi9HCP-u9Z2LTCF-7WJilQ54Jq1QMyPzPutLNJbTRCPecEP2NdsxmbzI6gONNIBpb8Vu1gbw-KfpXq5VinXSYafPGBkuX35VSej_POb72_brCrZhtj4YcNR8oDJ2snjtchoZhO6DwMwaEPg/s400/screenshot-2011-11-07-13-16-21.png" width="400" /></a></div>
<br />
<br />
参考 : <a href="http://www.freebsd.org/doc/zh_CN/books/handbook/config-network-setup.html">设置网卡</a><br />
<a href="http://www.freebsd.org/doc/zh_CN/books/handbook/network-routing.html">网关和路由</a><br />
<br />
<div class="NOTE">
<blockquote class="NOTE">
</blockquote>
</div>Anonymoushttp://www.blogger.com/profile/15470207574707724400noreply@blogger.com0tag:blogger.com,1999:blog-6616068516723546448.post-73472429547047801512011-11-07T07:11:00.001+08:002011-11-07T07:11:17.299+08:00用pkg_cutleaves来管理软件包作者:于江生(北京大学计算机系)<br />
声明:允许未经作者的同意进行非商业目的的转载,但必须保持原文的完整性。<br />
<hr />
FreeBSD对包的管理极为严格,
<pre class="example"># make deinstall clean
</pre>
可以轻而易举地将一个软件包卸载干净。如果由于某些特殊原因系统不能干净地删除某个目录,它会明白地提示用户哪个目录或哪个文件未清除,待用户进一步查明。与GNU/Linux相比,FreeBSD对port tree的维护和管理要更学院派一些。我喜欢用
<pre class="example"># make install clean
</pre>
来编译源码安装,有时也随意地pkg_add。按照运行依存(run
dependency),工具软件之间的关系复杂,呈现网状结构,动一处则牵动甚多。FreeBSD下安装软件简单至极,系统能自动按照依存关系递归地安
装所需要的ports。卸载软件也不难,但如果用户有“洁癖”,不想多保留任何“无用的东西”,则就需要pkg_cutleaves来帮忙管理这些软件包
了。
<hr />
<strong>内容摘要</strong>
<div class="contents">
<dl>
<dt>
<a href="http://www.icl.pku.edu.cn/member/yujs/BSDFiles/html/pkg_cutleaves.html#sec1">问题的由来</a>
</dt>
<dt>
<a href="http://www.icl.pku.edu.cn/member/yujs/BSDFiles/html/pkg_cutleaves.html#sec2">显示所有叶子结点信息</a>
</dt>
<dt>
<a href="http://www.icl.pku.edu.cn/member/yujs/BSDFiles/html/pkg_cutleaves.html#sec3">卸载我们不需要的叶子结点</a>
</dt>
</dl>
</div>
<h2>
<a href="" id="sec1" name="sec1"></a>
问题的由来</h2>
<div class="first">
我们在使用FreeBSD的时候,经常安装软件包。在安装的过程中,有一些build时依存的包会先被安装,而往往它
们不是我们所需要的。例如在安装xvidcap时先安装gawk,安装后也不卸载gawk。如果我们不需要gawk,就不得已在安装成功xvidcap后
把gawk手动卸载。</div>
问题是,包之间的复杂的依存关系让我们手动卸载时经常出错。这时,我们需要工具来梳理已经安装的软件包之间的关系,按照它们之间的依存关系整理出一
个有向非循环图(DAG),我们不妨称之为依存图,以此约束我们每一次的卸载都是从叶子结点开始。幸运的是,我们有pkg_cutleaves这样好用的
管理工具,可以帮助我们递归地卸载某些我们不需要的叶子结点。下面给出一个简短的介绍,假设命令都是root下达的。<br />
<h2>
<a href="" id="sec2" name="sec2"></a>
显示所有叶子结点信息</h2>
<div class="first">
首先,我们通过</div>
<pre class="example"># pkg_cutleaves -lc > ~/installed
</pre>
来生成所有的叶子结点,大致样子如下:
<pre class="example">ImageMagick-6.4.3.6 - Image processing tools
R-2.7.1 - A language for statistical computing and graphics
WordNet-3.0 - Dictionaries and thesauri with devel. libraries (C, TCL) and browsers
ardour-2.4.1 - Ardour - a digital audio workstation
auctex-emacs22-11.85 - Integrated environment for writing LaTeX using GNU Emacs
bibtool-2.48_1 - Command line manipulation of BibTeX files
</pre>
<h2>
<a href="" id="sec3" name="sec3"></a>
卸载我们不需要的叶子结点</h2>
<div class="first">
我们通过</div>
<pre class="example"># pkg_cutleaves -lxg
</pre>
来生成一个文件:/usr/local/etc/pkg_leaves.exclude,这个文件记录了所有叶子结点的文件名,不包含版本信息。我们可以
编辑修改这个文件,去掉我们不需要的叶子结点。接着,我们可以放心地清除我们不需要的build依存包,一个简单的命令就搞定:
<pre class="example"># pkg_cutleaves -Rxg
</pre>
系统会交互地询问我们是否删除某某某,保证文件/usr/local/etc/pkg_leaves.exclude所记录的就是软件依存图的所有叶子结点。概括而言,pkg_cutleaves清除软件包安装过程中产生的冗余的包,为我们的系统瘦身。Anonymoushttp://www.blogger.com/profile/15470207574707724400noreply@blogger.com0tag:blogger.com,1999:blog-6616068516723546448.post-78931612733174057072011-11-06T15:10:00.000+08:002011-11-07T11:44:13.720+08:00FNMP freebsd8.2 安装配置 nginx+mysql 51+php-fpm 53<span style="font-size: large;"><b>FNMP</b><b> (F</b>cgi, <b>N</b>ginx, <b>M</b>ysql and <b>P</b>hp)</span><br />
<br />
freebsd8.2 下ports 安装配置 nginx+mysql+php-fpm<br />
<br />
因为php需要mysql支持,所以,我一般按照mysql+php+nginx的步奏来安装.<br />
<br />
<span style="font-size: large;"><b>1 安装 mysql 5.1版本 </b></span><br />
(mysql55版本老编译不过去,还是采用稳妥的51来安装) <br />
<br />
cd /usr/ports/databases/mysql51-server<br />
make WITH_CHARSET=utf8 WITH_XCHARSET=all WITH_COLLATION=utf8_general_ci install clean<br />
<br />
<br />
<u>启动 </u><br />
添加以下内容到/etc/rc.conf中<br />
<br />
<div class="wp_syntax">
<div class="code">
mysql_enable="YES"<br />
<pre class="bash" style="font-family: monospace;"><span style="color: red;"> </span></pre>
</div>
</div>
<u>配置</u><br />
<br />
/usr/local/etc/rc.d/mysql-server start<br />
给root帐号添加密码 <br />
mysqladmin -u root password 'MyPassword'<br />
<br />
service mysql-server restart <span style="color: red;">*mysql重新启动</span><br />
mysql -u root -p<br />
show variables like 'char%'; <span style="color: red;">*设定编码察看</span><br />
<u>配置文件</u><br />
挑选下面的配置拷贝到/etc目录<br />
比如# cp /usr/local/share/mysql/my-medium.cnf /etc/my.cnf<br />
<pre class="bash" style="font-family: monospace;"><span style="color: black; font-weight: bold;"> </span></pre>
/usr/local/share/mysql/my-huge.cnf<br />
/usr/local/share/mysql/my-innodb-heavy-4g.cnf<br />
/usr/local/share/mysql/my-large.cnf<br />
/usr/local/share/mysql/my-medium.cnf<br />
/usr/local/share/mysql/my-small.cnf<br />
<br />
<span style="font-size: large;"><b>2 安装php53+php-fpm</b></span><br />
<br />
<pre></pre>
<u>安装 </u><br />
cd /usr/ports/lang/php5<br />
make install clean<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjNbPctudDLqF_pK43UYz4E4gUYhoHbh8SMeWaRUfTPeZaqCNijMQoMmVGM5FC5hcRh0NrZZM49jdINyIS-Q0MIi0JG3vermMfTqmtE0uj_18lWN6dWD7MaJlQFl1F-Xh9-iJnQPc59WkdI/s1600/screenshot-2011-11-06-15-31-12.png" style="margin-left: 1em; margin-right: 1em;"><img border="0" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjNbPctudDLqF_pK43UYz4E4gUYhoHbh8SMeWaRUfTPeZaqCNijMQoMmVGM5FC5hcRh0NrZZM49jdINyIS-Q0MIi0JG3vermMfTqmtE0uj_18lWN6dWD7MaJlQFl1F-Xh9-iJnQPc59WkdI/s1600/screenshot-2011-11-06-15-31-12.png" /></a></div>
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiymfjoQFDTx9UYAlq8BwOld4P1sou_IntkWntbD8DYNI1UFdFg0CW7jJrPSMfr__D04r9Wv_VlyrG-9H0E_73MSKmxYa-9pk90nw7D8vkxIYNQd86n9g98npmsto9ikYXBZV-vBFxQ5RBL/s1600/screenshot-2011-11-06-15-47-23.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiymfjoQFDTx9UYAlq8BwOld4P1sou_IntkWntbD8DYNI1UFdFg0CW7jJrPSMfr__D04r9Wv_VlyrG-9H0E_73MSKmxYa-9pk90nw7D8vkxIYNQd86n9g98npmsto9ikYXBZV-vBFxQ5RBL/s1600/screenshot-2011-11-06-15-47-23.png" /></a></div>
<br />
<pre> </pre>
cd /usr/ports/lang/php5-extension<br />
make install clean<br />
<br />
我这里主要选择了以下几个<br />
[X] BCMATH bc style precision math functions<br />
[X] BZ2 bzip2 library support<br />
[X] CURL CURL support[X] FTP FTP support <br />
[X] GD GD library support<br />
[X] ICONV iconv support[X] MCRYPT Encryption support<br />
[X] MHASH Crypto-hashing support<br />
[X] MYSQL MySQL database support <span style="color: red;">*重要mysql支持</span><br />
[X] MYSQLI MySQLi database support <span style="color: red;"> *重要mysql支持</span><br />
[X] OPENSSL OpenSSL support[X] PCRE Perl Compatible Regular Expression support<br />
[X] XML XML support[X] XMLREADER XMLReader support<br />
[X] XMLWRITER XMLWriter support<br />
[X] ZLIB ZLIB support
<br />
<br />
<u>配置</u><br />
1 php<br />
在freebsd默认安装的是没有配置文件的,需要你自己拷贝一个<br />
<br />
cp /usr/local/etc/php.ini-production /usr/local/etc/php.ini<br />
<br />
php.ini-development 开发测试版本 php.ini-production 生产适用版本<br />
<br />
<br />
2 php_fpm<br />
配置文件 /usr/local/etc/php-fpm.conf<br />
<br />
<u>启动 </u><br />
在 /etc/rc.conf 中添加<br />
php_fpm_enable="YES"<br />
启动php-fpm<br />
# /usr/local/etc/rc.d/php-fpm start<br />
<br />
<br />
<span style="font-size: large;"><b>3 安装nginx</b></span><br />
<br />
<br />
cd /usr/ports/www/nginx<br />
make install clean<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEic6JbwV1pJOBYGwlEIM3vKglxKMY9fURfePWA1iSEbas1-63TXV5y7AvRfusmlSYdEhHRAWcPeUnO5xhe_QzThKaImlTcjlZ9mUvK-gqVgUNLb42NV77WPdZPuQsewq5EPVnkaBJvJLgfb/s1600/screenshot-2011-11-06-17-00-54.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEic6JbwV1pJOBYGwlEIM3vKglxKMY9fURfePWA1iSEbas1-63TXV5y7AvRfusmlSYdEhHRAWcPeUnO5xhe_QzThKaImlTcjlZ9mUvK-gqVgUNLb42NV77WPdZPuQsewq5EPVnkaBJvJLgfb/s1600/screenshot-2011-11-06-17-00-54.png" /></a></div>
<br />
<div class="separator" style="clear: both; text-align: center;">
</div>
这里除了默认主要添加了ssl支持这个选项,其他就选择默认就可以了 <br />
[X] HTTP_SSL_MODULE Enable http_ssl module<br />
[X] HTTP_STATUS_MODULE Enable http_stub_status module<br />
[X] WWW Enable html sample files<br />
<br />
编译完成后,启动 nginx<br />
<div class="hl-surround">
<ol class="hl-main ln-show" title="Double click to hide line number.">
<li class="hl-firstline"># echo nginx_enable="YES" >> /etc/rc.conf</li>
</ol>
</div>
这里先不急着 start nginx,因为现在还没有对 PHP 的支持。<br />
<div class="hl-surround">
<ol class="hl-main ln-show" title="Double click to hide line number.">
<li class="hl-firstline"># vi /usr/local/etc/nginx/nginx.conf</li>
</ol>
</div>
将如下段落前的 “#” 删除,并且将 html 更改为 /usr/local/www/nginx<br />
<blockquote>
location ~ \.php$ {<br />
root /usr/local/www/nginx;<br />
fastcgi_pass 127.0.0.1:9000;<br />
fastcgi_index index.php;<br />
fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;<br />
include fastcgi_params;<br />
}</blockquote>
结束后,编辑 /usr/local/etc/nginx/fastcgi_params,加入<br />
<div class="hl-surround">
<ol class="hl-main ln-show" title="Double click to hide line number.">
<li class="hl-firstline">fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;</li>
</ol>
</div>
启动 nginx,看看是否已经对 PHP 了<br />
<div class="hl-surround">
<ol class="hl-main ln-show" title="Double click to hide line number.">
<li class="hl-firstline"># /usr/local/etc/rc.d/nginx start</li>
<li># echo "" > /usr/local/www/nginx/info.php</li>
</ol>
</div>
<div class="quote">
<div class="quote-title">
<br /></div>
<blockquote class="tr_bq">
<div class="quote-content">
vi /usr/local/www/nginx/info.php<br />
在文件中输入以下内容<br />
phpinfo();<br />
?></div>
</blockquote>
</div>
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjNNBi4NZA0DYMQj-4N7vXQwc1D2NWglq5pp7vO6NAtZk2PbG2U4jpOPKeOa9v3miEWaPLE6LgjemE_RxhhX9ZRzVKXRYX3cdC2KX3FooKefAohwlclkT1JCITCMgpvbVVQE7GpJHWRZpKv/s1600/screenshot-2011-11-06-17-47-59.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjNNBi4NZA0DYMQj-4N7vXQwc1D2NWglq5pp7vO6NAtZk2PbG2U4jpOPKeOa9v3miEWaPLE6LgjemE_RxhhX9ZRzVKXRYX3cdC2KX3FooKefAohwlclkT1JCITCMgpvbVVQE7GpJHWRZpKv/s1600/screenshot-2011-11-06-17-47-59.png" /></a></div>
<br />
访问 http://yourdomain/info.php,看到 phpinfo 的页面则证明无误。<br />
<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhikEbuCIwQx2oPEUbxqp5YutmN1X7Z-nEciGgnpRA4q3im3BU0febHjdc0Es1o1W9DJtIdY8urMfUFWM3eJb7mIIOWHQxEp3U5sTWBuXqbOMlspHEqfqsCmiie-6w8TCiK0KqQaeGYpQEW/s1600/screenshot-2011-11-06-17-45-12.png" imageanchor="1" style="clear: left; float: left; margin-bottom: 1em; margin-right: 1em;"><img border="0" height="584" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhikEbuCIwQx2oPEUbxqp5YutmN1X7Z-nEciGgnpRA4q3im3BU0febHjdc0Es1o1W9DJtIdY8urMfUFWM3eJb7mIIOWHQxEp3U5sTWBuXqbOMlspHEqfqsCmiie-6w8TCiK0KqQaeGYpQEW/s640/screenshot-2011-11-06-17-45-12.png" width="640" /></a></div>
<br />
参考 : <a href="http://www.codernotes.com/2011/261/nginx-php-fpm-mysql-on-freebsd-8-2/">Nginx + PHP-FPM + MySQL On FreeBSD 8.2</a><br />
<a href="http://anylinux.net/post/2394.html">nginx + PHP-FPM + MySQL + eAccelerator FreeBSD 8.0 安装笔记</a><br />
<a href="http://blog.jiqila.com/post/223/">FreeBSD上搭建nginx 0.8.x + PHP 5.3.x(FastCGI) + MySQL 5.1.x</a><br />
<br />Anonymoushttp://www.blogger.com/profile/15470207574707724400noreply@blogger.com0tag:blogger.com,1999:blog-6616068516723546448.post-88991537480921098762011-11-05T22:31:00.002+08:002011-11-06T04:51:55.489+08:00freebsd8.2 安装mysql55后修改默认编码utf8根据160630的patch状态回帖.可以编辑my.conf来更改默认的新建数据库编码<br />
<br />
<table cellspacing="1" class="auditblock"><tbody>
<tr><th class="info" colspan="2">State Changed</th></tr>
<tr><td class="key">From-To:</td> <td>open->closed</td></tr>
<tr><td class="key">By:</td> <td>ale</td></tr>
<tr><td class="key">When:</td> <td>Tue Sep 13 14:56:05 UTC 2011</td></tr>
<tr><td class="key">Why:</td> <td>You should use my.cnf for this config params.</td></tr>
</tbody></table>
<br />
具体参考 : <a href="http://jarodlau.blogspot.com/2011/11/freebsd-mysql51-mysql55.html">freebsd mysql5.1 与mysql5.5的参数变更</a><br />
<br />
<strike>使用如下patch给/usr/ports/datebase/mysql55-server/Makeconfig就可以了</strike><br />
<br />
<br />
<pre class="attachwin">diff -urN mysql55-server-old/Makefile mysql55-server/Makefile
<span class="patch_minusline">--- mysql55-server-old/Makefile 2011-09-10 14:38:44.000000000 +0000</span>
<span class="patch_plusline">+++ mysql55-server/Makefile 2011-09-10 15:16:00.000000000 +0000</span>
<span class="patch_hunkinfo">@@ -53,6 +53,12 @@</span>
.if defined(WITH_FASTMTX)
CMAKE_ARGS+= -DWITH_FAST_MUTEXES=1
.endif
<span class="patch_plusline">+.if defined(WITH_CHARSET) && ${WITH_CHARSET} != ""</span>
<span class="patch_plusline">+CMAKE_ARGS+= -DDEFAULT_CHARSET=${WITH_CHARSET}</span>
<span class="patch_plusline">+.endif</span>
<span class="patch_plusline">+.if defined(WITH_COLLATION) && ${WITH_COLLATION} != ""</span>
<span class="patch_plusline">+CMAKE_ARGS+= -DDEFAULT_COLLATION=${WITH_COLLATION}</span>
<span class="patch_plusline">+.endif</span>
# MySQL-Server part
.if !defined(CLIENT_ONLY)</pre>
<br />
<strike>然后编译的时候,使用</strike><br />
<strike>make WITH_CHARSET="utf8" WITH_COLLATION="utf8_unicode_ci" install clean</strike><br />
<br />
参考 : <a href="http://www.freebsd.org/cgi/query-pr.cgi?pr=160630">ports/160630: [PATCH] databases/mysql55-server Add WITH_COLLATION and WITH_CHARSET</a><br />
<br />
以往在freebsd中安装databases/mysql55-{server,client}时,需要如下的参数 :<br />
<br />
<br />
<pre class="text" style="font-family: monospace;">make WITH_CHARSET=utf8 WITH_COLLATION=utf8_general_ci WITH_XCHARSET=complex install</pre>
<strike><br /></strike><br />
<strike>不过因为在 MySQL 5.5.8 以后的 build system 改成了 CMake,导致 ports maintainer 必须重新设计 Makefile。</strike><br />
<strike>而目前的 Makefile 尚未设计完善,所以想把这些 options 传递給 CMake 的话,只能直接改 Makefile 解決:</strike><br />
<br />
<br />
<pre class="diff" style="font-family: monospace;"><span style="color: #888822;">--- mysql55-server/Makefile.orig 2011-03-19 21:13:47.000000000 +0800</span>
<span style="color: #888822;">+++ mysql55-server/Makefile 2011-04-08 14:31:05.815962791 +0800</span>
<span style="color: #440088;">@@ -39,7 +39,10 @@</span>
-DINSTALL_SQLBENCHDIR="share/mysql" \
-DINSTALL_SUPPORTFILESDIR="share/mysql" \
-DWITH_LIBEDIT=0 \
<span style="color: #991111;">- -DWITH_LIBWRAP=1</span>
<span style="color: #00b000;">+ -DWITH_LIBWRAP=1 \</span>
<span style="color: #00b000;">+ -DDEFAULT_CHARSET="utf8" \</span>
<span style="color: #00b000;">+ -DDEFAULT_COLLATION="utf8_general_ci" \</span>
<span style="color: #00b000;">+ -DWITH_EXTRA_CHARSETS="complex"</span>
.ifdef USE_MYSQL
.error You have `USE_MYSQL' variable defined either in environment or in make(1) arguments. Please undefine and try again.</pre>
<br />
<strike>如果在做这修改前不小心把沒设好的 MySQL 整套装起來的话,请记得把 mysql55-client 也砍掉一起重裝。</strike><br />
<strike>特別是对那些真正需要用到 WITH_EXTRA_CHARSET="complex" 的人,有一边沒弄好的話,网页上就准备出现一大堆「???????」了。</strike><br />
<strike>至於是否能像以前那样直接用 make 送參數,就只能慢慢等 maintainer,看他何時會重新把所有 options 對應上去了。</strike><br />
<br />
<br />
<div class="cnt" id="blog_text">
通过使用port来安装<br />
1.该ports 做得不是太好,不支持 make config 修改选项,只能在命令行用 <br />
make WITH_CHARSET=gbk WITH_XCHARSET=all 追加参数,或者直接修改 Makefile文件。 <br />
<br />
2.WITH_CHARSET=gbk 是将mysql的服务及数据库的默认字符集由latin1改为gbk;WITH_XCHARSET=all 是将mysql软件包所带的字符集(包括gbk 和 gb2132)都释放出来。 <br />
mysql 不是真的不支持中文,只是采用了utf8字符集而已。
所以不建议你改变默认字符集,应由程序(如PHP)在连接数据库时选定合适的字符集。如,在config.inc.php之类连接参数文件中设定
mysql_query("set names
gbk");改变默认字符集可能导致有些外国编的软件如VBulletin3.60运行错误。建议你在mysql5编译时只增加
WITH_XCHARSET=all 即可。 <br />
<br />
3.应用 make clean 清除配置(假设你以前编译过) <br />
然后 make WITH_XCHARSET=all <br />
最后 make install 安装编译好的软件包(如你以前以前安装过,最好用make reinstall) <br />
<br />
4.如你用phpmyadmin导入以前的数据(gb2132 或gbk格式),在创建数据库时务必将默认参数“整理”改为gbk_chinese_ci<br />
5.可以尝试修改my.cnf文件来改变服务器以及客服端的字符编码<br />
[client]<br />
...<br />
character-set-server=utf8<br />
<br />
collation-server=utf8_general_ci<br />
<br />
default-character-set=utf8<br />
[mysqld]<br />
...<br />
character-set-server=utf8<br />
<br />
collation-server=utf8_general_ci<br />
<br />
default-character-set=utf8<br />
[mysql]<br />
.......<br />
default-character-set=utf8</div>Anonymoushttp://www.blogger.com/profile/15470207574707724400noreply@blogger.com0tag:blogger.com,1999:blog-6616068516723546448.post-87205121644943723652011-11-05T20:34:00.001+08:002011-11-05T20:34:27.695+08:00freebsd mysql5.1 与mysql5.5的参数变更<h4>
<a class="keyword" href="http://d.hatena.ne.jp/keyword/MySQL">MySQL</a> 5.1 </h4>
<pre class="syntax-highlight">[mysql]
default-character-set=utf8
[mysqld]
default-character-set=utf8
</pre>
<h4>
<a class="keyword" href="http://d.hatena.ne.jp/keyword/MySQL">MySQL</a> 5.5 </h4>
<pre class="syntax-highlight">[mysql]
default-character-set=utf8
[mysqld]
character-set-server=utf8</pre>
<br />
察看支持的编码 使用 <br />
<pre class="syntax-highlight">mysql<span class="synStatement">></span> SHOW VARIABLES LIKE <span class="synConstant">'char%'</span><span class="synStatement">;</span>
+--------------------------+----------------------------------+
<span class="synStatement">|</span> Variable_name <span class="synStatement">|</span> Value <span class="synStatement">|</span>
+--------------------------+----------------------------------+
<span class="synStatement">|</span> character_set_client <span class="synStatement">|</span> utf8 <span class="synStatement">|</span>
<span class="synStatement">|</span> character_set_connection <span class="synStatement">|</span> utf8 <span class="synStatement">|</span>
<span class="synStatement">|</span> character_set_database <span class="synStatement">|</span> latin1 <span class="synStatement">|</span>
<span class="synStatement">|</span> character_set_filesystem <span class="synStatement">|</span> binary <span class="synStatement">|</span>
<span class="synStatement">|</span> character_set_results <span class="synStatement">|</span> utf8 <span class="synStatement">|</span>
<span class="synStatement">|</span> character_set_server <span class="synStatement">|</span> latin1 <span class="synStatement">|</span>
<span class="synStatement">|</span> character_set_system <span class="synStatement">|</span> utf8 <span class="synStatement">|</span>
<span class="synStatement">|</span> character_sets_dir <span class="synStatement">|</span> /usr/<span class="synStatement">local</span>/share/mysql/charsets/ <span class="synStatement">|</span>
+--------------------------+----------------------------------+
<span class="synConstant">8</span> rows <span class="synStatement">in</span> <span class="synStatement">set</span> <span class="synStatement">(</span><span class="synConstant">0</span>.<span class="synConstant">00</span> sec<span class="synStatement">)</span></pre>
<br />
<br />
参考 <a href="http://d.hatena.ne.jp/littlebuddha/20110524/1306208820">mysql5.1与mysql5.5的参数变更</a>Anonymoushttp://www.blogger.com/profile/15470207574707724400noreply@blogger.com0tag:blogger.com,1999:blog-6616068516723546448.post-3185717801654705952011-11-02T20:19:00.002+08:002011-11-02T20:19:20.217+08:00firefox的dns缓存功能本地使用virtualbox安装了一个arch server假设了一个wordpress博客,发现当ip换掉以后,ff老无法更新新ip,原来firefox有dns缓存功能.<br />
<br />
可以手动修改同时按下Ctrl + Shift + Delete,点details,只选中cache,然后点clear,删了。<br />
<br />
about:config<br />
<br />
<b>network.dnsCacheExpiration</b> 把原来的60改成
10000(表示缓存10000秒)<br />
<b>network.dnsCacheEntries </b> 把默认的20改成1000(表示缓存1000条).如果没
有上面两个项目,新建即可。 <br />
<br />
但是dns缓存太久了也会出问题,比如有的网站ip换了,就无法访问了。针对这样的问题,可以安装一
个 firefox 插件来开启或者关闭dns cache功能,https://addons.mozilla.org/zh-CN/firefox
/addon/5914<br />
<br />
参考 : <a href="http://tech.gaeatimes.com/index.php/archive/simple-firefox-hacks-to-boost-performance/">Simple Firefox DNS Hacks To Boost Performance</a>Anonymoushttp://www.blogger.com/profile/15470207574707724400noreply@blogger.com0tag:blogger.com,1999:blog-6616068516723546448.post-45546926157256854612011-11-02T19:06:00.000+08:002011-11-02T19:07:39.057+08:00修改fstab让ntfs分区挂载文件读写权限,文件夹读写执行权限一直使用的ntfs-3g来读写win下的分区,没有怎么注意权限的问题,可是看到挂载的分区文件都是可执行权限,对安全性以及读写都有问题,因为使用awesome所以一般很少开文件管理器,最多使用mc来批量复制拷贝文件,看到一片绿色可执行,头大.<br />
<br />
察看fstab的参数原来可以制定挂载的时候,对文件以及文件夹采用不同的权限.<br />
<br />
比如下面这段挂载的参数:<br />
<br />
/dev/<ntfs-part> /mnt/windows ntfs-3g gid=users,fmask=113,dmask=002 0 0 </ntfs-part><br />
<br />
<ntfs-part>以群组users,文件权限664,文件夹权限774来挂载.</ntfs-part><br />
<ntfs-part> </ntfs-part><br />
<ntfs-part>fmask,dmask,以及umask的意思就是扣除相应的权限,777-$(*mask)= 来定义挂载的权限.</ntfs-part><br />
<br />
<ntfs-part>umask代表user的mask,fmask代表文件file的mask,当然dmask就代表文件夹的mask了.</ntfs-part><br />
<ntfs-part><br /></ntfs-part><br />
<blockquote class="tr_bq">
一.022表示默认创建新文件权限为755 也就是 rxwr-xr-x(所有者全部权限,属组读写,其它人读写) <br />
二.027表示默认创建新文件权限为750 也就是rxwr-x---(所有者全部权限,属组读写,其它人无)<br />
<br />
下表列出了一些umask值及它们所对应的目录和文件权限<br />
常用的umask值及对应的文件和目录权限<br />
umask值 目录 文件<br />
022 755 644<br />
027 750 640<br />
002 775 664<br />
006 771 660<br />
007 770 660</blockquote>
我现在的fstab配置文件如下<br />
<title>/etc/fstab.html</title>
<style type="text/css">
<!--
pre { white-space: pre-wrap; font-family: monospace; color: #ffffff; background-color: #000000; }
body { font-family: monospace; color: #ffffff; background-color: #000000; }
.Constant { color: #af5f00; }
.Statement { color: #804000; }
.Type { color: #008000; }
.Identifier { color: #008080; font-weight: bold; }
.Comment { color: #008080; }
-->
</style>
<br />
<pre><span class="Comment"># </span>
<span class="Comment"># /etc/fstab: static file system information</span>
<span class="Comment">#</span>
<span class="Comment"># <file system> <dir> <type> <options> <dump> <pass></span>
<span class="Identifier">tmpfs</span> /tmp <span class="Type">tmpfs</span> <span class="Type">nodev</span><span class="Statement">,</span><span class="Type">nosuid</span> <span class="Constant">0 0</span>
<span class="Identifier">UUID</span><span class="Statement">=</span><span class="Constant">b2b3abc1-d666-4948-9c17-a5e12c637d63</span> /boot <span class="Type">reiserfs</span> <span class="Type">defaults</span> <span class="Constant">0 1</span>
<span class="Identifier">UUID</span><span class="Statement">=</span><span class="Constant">afd39ba2-f3f3-4bac-bbc8-dc5307ba4e89</span> / <span class="Type">ext4</span> <span class="Type">defaults</span> <span class="Constant">0 1</span>
<span class="Identifier">UUID</span><span class="Statement">=</span><span class="Constant">26f23578-3dc8-4394-bcba-7320a4aaff7d</span> <span class="Statement">swap</span> <span class="Type">swap</span> <span class="Type">defaults</span> <span class="Constant">0 0</span>
<span class="Identifier">UUID</span><span class="Statement">=</span><span class="Constant">90ab4280-c642-47c0-91e4-d3be7d254d1a</span> /home <span class="Type">ext4</span> <span class="Type">defaults</span><span class="Statement">,</span><span class="Statement">user_xattr</span> <span class="Constant">0 1</span>
<span class="Identifier">UUID</span><span class="Statement">=</span><span class="Constant">"4D9E019F07B2E598"</span> /media/wine <span class="Type">ntfs</span>-3g <span class="Statement">gid=</span><span class="Type">users</span><span class="Statement">,</span><span class="Statement">fmask=</span><span class="Constant">113</span><span class="Statement">,</span><span class="Statement">dmask=</span><span class="Constant">002</span><span class="Statement">,</span>nls<span class="Statement">=</span><span class="Statement">utf8</span> <span class="Constant">0 2</span>
</pre>Anonymoushttp://www.blogger.com/profile/15470207574707724400noreply@blogger.com0tag:blogger.com,1999:blog-6616068516723546448.post-82623015140603339342011-11-01T12:09:00.000+08:002011-11-01T12:29:00.900+08:00mpd 启动错误 Address family not supported by protocol这2天arch启动的时候tty1老提示 Error : Socked : Address family not supported by protocol <br />
<br />
<br />
放google搜索,找到<a href="https://github.com/mopidy/mopidy/issues/75">Address family not supported by protocol - IPv6 issue on machines with disabled v6</a><br />
<br />
This happens on a machine that has <code>socket.has_ipv6</code> set to true as the linux system supports IPv6, but jason has disabled IPv6 by following <a href="https://wiki.archlinux.org/index.php/IPv6_-_Disabling_the_Module">https://wiki.archlinux.org/index.php/IPv6_-_Disabling_the_Module</a><br />
<br />
手动启动的时候提示如下错误:<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjdkQxQOTPKBenGeUh1aVwyM9KgpkgLJyLPtAABb3e2L2mL8kNziNRA9bfbXxGLgVphfpOOzTul3NiwzGRLH0eS-C1D4kAPg9D1FhLl-gbrPY_B5PMwsXRgRQzE7Gbjk9jrzwN1tLcFbymZ/s1600/screenshot-2011-11-01-12-10-36.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjdkQxQOTPKBenGeUh1aVwyM9KgpkgLJyLPtAABb3e2L2mL8kNziNRA9bfbXxGLgVphfpOOzTul3NiwzGRLH0eS-C1D4kAPg9D1FhLl-gbrPY_B5PMwsXRgRQzE7Gbjk9jrzwN1tLcFbymZ/s1600/screenshot-2011-11-01-12-10-36.png" /></a></div>
<br />
listen: bind to '[::1]:6600' failed: Failed to create socket: Address family not supported by protocol (continuing anyway, because binding to '127.0.0.1:6600' succeeded)<br />
playlist directory is not a directory: "/home/jarodlau/.mpd/playlists"<br />
<br />
原来是禁用ipv6的结果,另外我没有把播放列表的目录拼写正确,少了个s,应该是playlists,我的写成了playlist<br />
<br />
解决办法很简单 :<br />
<br />
编辑 /etc/hosts文件 ,把一些ipv6的地址注释掉就ok了,如下<br />
<br />
<title>/etc/hosts.html</title>
<style type="text/css">
<!--
pre { white-space: pre-wrap; font-family: monospace; color: #ffffff; background-color: #000000; }
body { font-family: monospace; color: #ffffff; background-color: #000000; }
.Comment { color: #00ffff; }
-->
</style>
<br />
<pre><span class="Comment">#</span>
<span class="Comment"># /etc/hosts: static lookup table for host names</span>
<span class="Comment">#</span>
<span class="Comment">#<ip-address> <hostname.domain.org> <hostname></span>
127.0.0.1 localhost.localdomain localhost arch-laptop
<span class="Comment">#::1 localhost.localdomain localhost</span>
<span class="Comment"># End of file</span>
</pre>Anonymoushttp://www.blogger.com/profile/15470207574707724400noreply@blogger.com0tag:blogger.com,1999:blog-6616068516723546448.post-61801377906927448702011-10-31T22:36:00.000+08:002011-11-02T03:16:33.998+08:002个不错的dns因为电信的114问题,dns劫持严重,于是使用了<a href="https://wiki.archlinux.org/index.php/Pdnsd">pdnsd</a>来本地缓存dns信息,可是google和opendns的延迟很严重,所以一直在找其他不错的dns <br />
<br />
google的8.8.8.8和8.8.4.4以及opendns的208.67.222.222和208.67.220.220,用的人太多了,gfw重点照顾,所以不太好用了<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhguTVJov-UBYCOKc9XmMmKVkGa6uWCiO-UzosU2a-gCM-C3y9Xx__MfE38bHr5HsM_x6-9UBh1KqUm5yJDOFqv2G4AooEWcj4Lb4MyQdevKCAYyeQFBXguL-7zuOwkfLiBeC8BQyTRBwy6/s1600/screenshot-2011-10-31-22-26-36.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhguTVJov-UBYCOKc9XmMmKVkGa6uWCiO-UzosU2a-gCM-C3y9Xx__MfE38bHr5HsM_x6-9UBh1KqUm5yJDOFqv2G4AooEWcj4Lb4MyQdevKCAYyeQFBXguL-7zuOwkfLiBeC8BQyTRBwy6/s1600/screenshot-2011-10-31-22-26-36.png" /></a></div>
<br />
推荐个台湾中华电信<a href="http://www.cht.com.tw/index.php" title="dns">dns</a>:168.95.192.1 和 168.95.192.2<br />
<br />
编辑pdnsd的配置文件 sudo vim /etc/pdnsd.conf<br />
<br />
<br />
<title>~/pdnsd.conf.html</title>
<style type="text/css">
<!--
pre { white-space: pre-wrap; font-family: monospace; color: #ffffff; background-color: #000000; }
body { font-family: monospace; color: #ffffff; background-color: #000000; }
-->
</style>
<br />
<pre># The following section is most appropriate if you have a fixed connection to
# the Internet and an ISP which provides good DNS servers.
server {
label= "mydns";
ip = 168.95.192.1,168.95.192.2; # Put your ISP's DNS-server address(es) here.
# proxy_only=on; # Do not query any name servers beside your ISP's.
# This may be necessary if you are behind some
# kind of firewall and cannot receive replies
# from outside name servers.
timeout=4; # Server timeout; this may be much shorter
# that the global timeout option.
#uptest=if; # Test if the network interface is active.
#interface=eth0; # The name of the interface to check.
#uptest=ping;
# ping_timeout=100;
interval=10m; # Check every 10 minutes.
purge_cache=off; # Keep stale cache entries in case the ISP's
# DNS servers go offline.
} </pre>
然后重启就ok了 sudo rc.d restart pdnsdAnonymoushttp://www.blogger.com/profile/15470207574707724400noreply@blogger.com0tag:blogger.com,1999:blog-6616068516723546448.post-78915470529287952052011-10-29T11:14:00.001+08:002011-10-31T23:04:31.518+08:00“代码贴吧”网址收集若想在网上与人分享短小的源代码,推荐用以下网站:<br /><a href="http://pastie.caboo.se/paste/" target="_blank" title="http://pastie.caboo.se/paste/">http://pastie.caboo.se/paste/</a><br /><a href="http://pastie.textmate.org/paste/" target="_blank" title="http://pastie.textmate.org/paste/">http://pastie.textmate.org/paste/</a> (同上)<br /><a href="http://pastebin.com/" target="_blank" title="http://pastebin.com/">http://pastebin.com/</a><br /><a href="http://rafb.net/paste/" target="_blank" title="http://rafb.net/paste/">http://rafb.net/paste/</a>Anonymoushttp://www.blogger.com/profile/15470207574707724400noreply@blogger.com0tag:blogger.com,1999:blog-6616068516723546448.post-35167689021120316712011-10-29T11:07:00.003+08:002011-10-31T23:04:31.529+08:00三个免费BSD系统的比较在网上看到这样的评论:<br /><br /><span style="color: darkred;">FreeBSD = Popular all-rounder.<br />NetBSD = Portable (runs on a lot of platforms, including a toaster)<br />OpenBSD = Security above anything else.</span><br /><br />翻译过来就是:<br /><br /><span style="color: darkred;">FreeBSD = 流行的多面手<br />NetBSD = 可移植 (可在很多平台上运行, 包括一个烤面包机)<br />OpenBSD = 比其他任何东西都安全</span><br /><br />应该说,这样的评价,非常精到。用过这三个系统的人我想都会点头同意。Anonymoushttp://www.blogger.com/profile/15470207574707724400noreply@blogger.com0tag:blogger.com,1999:blog-6616068516723546448.post-29389685583492360572011-10-29T10:54:00.000+08:002011-10-29T10:54:11.021+08:00FREEBSD的一些小技巧<b>1、在 unix-like 中档案结构是满重要的,那么要如何去看相关档案目录结构的说明呢? </b><br /><br />难道是 cd 到每个目录下吗?其实有更好的方法.. <br /><br />那就是用好男人 man 来看: <br /><br /># man hier <br /><br /><b>2、在 console 下操作时,由于屏幕显示有限,有时需看前面显示的资料,这时你可: </b><br /><br />. 按一下 Pause or Scroll Lock键后,则可利用 PageUp PageDown Up Down Home End 等键来看前后显示的资料 <br /><br />. 再按一下 Pause or Scroll Lock则可回复等待输入画面. <br /><br /><b>3、 使用 pw 来管理你的帐号 </b><br /><br />在 FreeBSD 下使用 adduser 来新增帐号,有些时会满烦的,可用以下方式: <br /><br />pw useradd -n <username> -g <group> -m -s /bin/csh <br /><br />=> -m 代表建立使用者目录 <br /><br />●同时设密码 <br /><br />echo <password> | pw useradd -n <username> -g <group> -m -s /bin/csh -h 0 <br /><br />● 删除帐号 <br /><br />pw userdel -n <username> -r <br /><br />=> -r 代表同时删除其 home 目录等相关资料 <br /><br />● 修改帐号 <br /><br />pw usermod -g <group> -s /bin/csh <br /><br />PS:无法修改帐号名称 <br /><br />● lock 及 unlock 使用者帐号 <br /><br />pw lock <username> <br />pw unlock <username> <br /><br /><b>4、 激活你的 screensaver </b><br /><br />由于 FreeBSD 大多当为主机使用,都是常期不关机的,因此可将屏幕关掉,或使用 ScreenSaver 功能.. <br /><br />使用 ScreenSaver 请在 /etc/rc.conf 这个档加入以下两行: <br /><br />blanktime="900" <br /><br />=> 以秒数为单位,如以上为 15 分钟 <br /><br />saver="logo" <br /><br />=> logo 是 FreeBSD 的吉祥物(图型接口),另也可使用 "daemon",这是文字型式 <br /><br /><b>5、 检查你的某一个 ports 版本及更新 </b><br /><br />如果要更新所有的 port 只需在 /etc/ports/ 下执行以下指令: <br /><br /># make update <br /><br />有时我们可能要检查某一个 ports 的版本,在每个 ports 中的 Makefile 都有这一行 <br /><br />PORTVERSION= x.x.x <br /><br />如此就可看到这个 ports 的版本了,另外也可使用以下方式(用 grep),比如我们想看 mod_php4 的版本 <br /><br /># grep PORTVERSION= /usr/ports/www/mod_php4/Makefile <br />PORTVERSION= 1.4.1 -> 版本讯息 <br /><br />如果版本太旧了,则可利用以下方法来更新单一 ports <br /><br />a. 使用 portupgrade 或 portinstall,请用 man 查看用法 <br /><br />b. 到 FreeBSD 网站查询最新的 ports 信息,并抓 ports 回来更新 <br /><br />网址:<a href="http://www.freebsd.org/cgi/cvsweb.cgi/ports/" target="_blank" title="http://www.freebsd.org/cgi/cvsweb.cgi/ports/">http://www.freebsd.org/cgi/cvsweb.cgi/ports/</a> <br /><br />抓回来后在相关目录更新,例如我们抓回的是 mod_php4.tar.gz,存在 /usr/tmp/ 目录下,则解压缩的方式如下: <br /><br /># cd /usr/ports/www/mod_php4 <br /># tar xzvf /usr/tmp/mod_php4.tar.gz <br /><br />如此就 ok 了.. <br /><br /><b>6、 加速你的按键速度.. </b><br /><br />相信使用 FreeBSD 的人很多都是在 console 下操作吧,有些时,要重复某一按键速度实在很慢.. <br /><br />另一个问题就是 cusror 的位置有些时不太明显.. <br /><br />可用以下方法来改善: <br /><br />在 /etc/rc.conf 中加入以下资料.. <br /><br />keyrate="fast" <br />cursor="blink" 或 "destructive" <br /><br /><b>7、 设定开机画面 </b><br /><br />使用 windows 的人,都知道所谓的开机画面,在 FreeBSD 下是否也有此功能呢?答案是肯定的,而且设定更为简便,请照以下 steps: <br /><br />一. 首先制作一个图型文件,档案格式为 logo.pcx 或 logo.bmp,需注意的是 .bmp 的档案存盘时不用压缩,分辨率需为 640 X 480 以内(含),色阶为 256 色.. <br /><br />二. 将此档案 copy 到 /boot/ 这个目录下 <br /><br />三. 设定 /boot/loader.conf,加入以下资料 <br /><br />splash_bmp_load="YES" -> 如果使用 .bmp 格式,此项需设为 YES <br />splash_pcx_load="YES" -> 使用 .pcx,请将此项设为 YES <br />vera_load="YES" <br />bitmap_load="YES" <br />bitmap_name="/boot/logo.pcx" -> 请依你的档案格式更改 <br />bitmap_type="splash_image_data" <br /><br />四. 重新激活 <br />ps: 请检查你的 kernel 中是否有设定以下资料,一般在 4.x 中都是内定值..,至于 3.x 版,没用过..^.^ <br /><br />preudo-device splash <br /><br />如果没有,则需将此行加入并重新编绎核心. <br /><br /><br /><b>8、 一些 console 下使用的快速键.. </b><br /><br />相信大多使用 unix-like 的使用者,还是在 console 下执行你的日常维护工作吧,那有那些按键组合可帮我们提高效率呢.. <br /><br />以下按键皆适用于 tcsh 及 bash.. <br /><br />1. 快速移动光标 <br /><br />ctrl+a -> 到最前面 <br />ctrl+e -> 到最后面 <br /><br />2. 编辑方面 <br /><br />ctrl+d -> 删除光标所在字符 <br />ctrl+w -> 删除光标所在字前面的字符 <br />ctrl+u -> bash:将光标前所有的字及字符删掉,tcsh:删除所有字 <br />ctrl+k -> 将光标后所有字符删掉 <br />ctrl+b -> 下个字符 <br />ctrl+f -> 前一个字符 <br />ctrl+m -> 和按下 enter 的结果一样 <br />ctrl+h -> 和按下 del 或 backspace 键一样 <br />del 或 backspace -> 删除前一个字符 <br /><br />如果对按键有研究兴趣者,不彷参考 /usr/share/syscons/keymaps/ 这个目录,其中 us.iso.kbd 是一般我们使用的按键.. <br /><br /><b>9、 快速切换目录 </b><br /><br />在 FreeBSD 中常常需要切换目录,有时目录名称较长、或是有大小写、或是只记得前面几个字,怎么办.. <br /><br />其实只要输入部份字再加上 * 这个符号就可以了.. <br /><br />如我们要切换到 /usr/local/ 这个目录,只需输入 cd /usr/lo* 就可以了.. <br /><br />如果输入 cd /usr/l* 会如何呢?则会进到 /usr/lib/ 这个目录,这是因为 shell 找到第一个符合的条件便停止了.. <br /><br /><b>10、 有关时间及时区的调校 </b><br /><br />使用 FreeBSD 大多是拿来当做主机使用,那时间及时区的正确与否就非常重要了,以下介绍如何调整时间及时区 <br /><br />● 时间调整<br />1. 使用 date 指令 <br /><br />格式 date [yymmdd]HHMM <br />说明: <br />yy 年数,如 02 代表 2002 年 <br />mm 月份 01-12 <br />dd 日数 01-31 <br />HH 时数 01-59 <br />MM 分钟 01-59 <br /><br />yy mm dd 皆可省略 <br /><br />例: <br /><br />?#123;整日期为 2002-03-25 <br /># date 022325 <br /><br />?#123;整时间为 14:20 <br /># date 1420 <br /><br />2. 使用对时主机 <br /><br /># ntpdate clock.stdtime.gov.tw <br /><br />这项需能连上网络,其中 clock.stdtime.gov.tw 是一标准时间的主机 <br /><br />● 时区的设定 <br /><br />1. 使用 tzsetup <br /><br />2. 在 /etc/ 下有个档案 localtime,这个就是本机的时区设定档案,因此我们可用个取巧方式(不经由 tzsetup),如以下: <br /><br /># cp /usr/share/zoneinfo/Asia/Taipei /etc/localtime <br /><br />这样是不是比较快呢.. <br /><br /><b>11、 如何清空档案内容.. </b><br /><br />有时我们需将一个档案内容清空,但需保留这个档案.. <br /><br />一般常见的用法是用文字编辑器,如 vi 将这个档案叫出来,再将其内容全部删掉,再存盘.. <br /><br />这样是不是有些烦呢? <br /><br />有一个更好的方法,使用 true 指令.. <br /><br />如我们要将 /var/log/httpd-access.log 清空,则下以下指令.. <br /><br /># cd /var/log/ <br /># true > httpd-access.log <br /><br /><b>12、 显示目录及档案 => tree </b><br /><br />有时需显示某个目录下所有的目录及档案,虽使用 ls 可达到部份功能,但并不是很方便.. <br /><br />在 dos 中,有个 tree 指令,是不是满好用的.. <br /><br />其实在 FreeBSD 中也有类似的指令 => tree.. <br /><br />以下我们就透过 ports 来安装 tree <br /><br /># cd /usr/ports/sysutils ; make install <br /><br />如此会将 tree 这个指令安装在 /usr/local/bin/ 这个目录下.. <br /><br />使用例子: <br /><br />1. 显示 /usr/ 下的目录及档案 <br /><br /># tree /usr <br /><br />2. 只显示 /usr 下的目录 <br /><br /># tree -d /usr <br /><br />详细用法请参考 man tree <br /><br />PS:可透过管道 | 及 more 来显示 <br /><br />如 tree /usr | more.. <br /><br /><b>13、 如何检视档案类型 </b><br /><br />由于 FreeBSD 并没有像 dos 或 windows 般有扩展名的观念,因此要如何检查一个档案的类型呢? <br /><br />用 file 吧.. <br /><br />语法: file <file_name> <br /><br />详细用法请参考 man file <br /><br /><b>14、 重复使用先前使用过的指令 </b><br /><br />你可以使用以下的方法来重复使用先前使用过的指令: <br /><br />例如,我们先用 history 显示先前输入的指令: <br /><br /># history <br />. <br />.. <br />... <br />10 clear <br />11 cd /usr/local <br />12 ls <br />13 ls etc <br />14 cd ~ <br />15 clear <br /><br />1. 用 up down 可用上下一个指令,或是 ctrl+p ctrl+n 亦然 <br /><br />2. 配合 ! 的用法,例如以下(ps: 在<...>内代表要输入的东东) <br /><br />!! <br /># !! => 重复执行上个一个指令 <br /><br />!<编号> <br /># !11 => 执行 cd /usr/local <br /><br />!<指令> 可输入部份字,但前面部份需符合 <br /># !cl <br />执行 15 clear 指令 <br /><br />!<!--?指令?--> 输入部份字符,部份吻合 <br /># !?etc? <br />执行 13 ls etc <br /><br />以上指令在 tcsh 及 bash 下皆可使用,如此是不是可帮你省下许多时间.. <br /><br /><b>15、 如何将 man 的档案印出来.. </b><br /><br />man 是大家学习 FreeBSD 的最佳资料参考来源,但在显示器上看到底不是很方便,有没有方法转成一般的文件档案呢? <br /><br />使用 col 这个指令吧.. <br /><br />例我们要将 ssh2 转成 ssh2.txt,则使用以下语法: <br /><br /># man ssh2 | col -b > ssh2.txt <br /><br /><b>16、 为何查不到正确的 ports 资料.. </b><br /><br />在 /usr/ports/ 下有着几千个 ports 的安装资料,有时我们可使用以下方式来查相关的 ports.. <br /><br />以下都是在 /usr/ports/ 这个目录下执行.. <br /><br />1. 先将 ports 资料转换成一个文字文件,如 index.txt <br /><br /># make print-index > index.txt <br /><br />2. 使用 make search key="...." 来查 <br /><br />3. 将 ports 内容转换成 README.html <br /><br /># make readmes <br /><br />用以上方法,可很容易的查到相关的 ports 资料,但很奇怪的是,为何我更新一个 ports 的资料后(或 ports tree),为何会查不到,查到的仍然是旧的资料.. <br /><br />原来,在 /usr/ports/ 中有一个 INDEX 檔,以上的查询方式都是在这个 INDEX 档中查询,当你更新 ports 资料时,这个 INDEX 档并不会随之更新.. <br /><br />所以为了查询方便,我们需以手动的方式来做.. <br /><br /># make index <br /><br />做完后,再更新 index.txt 及 README.html.. <br /><br />不过更新 INDEX 档需要一些时间,大约 12-30 分钟..(视计算机等级而定). <br /><br /><b>17、 用 dig 及 host 来取代 nslookup </b><br /><br />一般我们用来检查网络是否有问题,大多是用以下三个指令.. <br /><br />nslookup <br />ping <br />traceroute <br /><br />其中 nsllokup 是用来检查 dns 的相关设定, ping 用来检查自己和对方网络是否通顺,而 traceroute 则是用来检查从自己的计算机到对方的计算机所经过的线路状况.. <br /><br />不过以 nslookup 而言,个人觉得不是很实用,有时我们只是想单纯的查一下某台主机或是 MX 记录,那使用 nslookup 就有点噜嗦了.. <br /><br />在此介绍二个好用的指令 host 及 dig,这二个指令很类似,不过效率较 nslookup 高 <br /><br /># host -a <主机名称> 或 <ip> <br /><br />=> 输入主机名称显示 dns 正向解析的部份,输入 ip 则是显示反向(ptr) <br /><br /># dig <主机名称或ip> <any a="" mx="" soa="" txt..="" 任选一项=""> <br /><br />如要显示 MX 记录 <br /><br /># dig 主机名称 mx <br /><br />个人是觉得比 nslookup 方便多了,你觉得呢.. ^.^ <br /><br />当然功能不只这些,详情请 man dig 或 host.. <br /><br /><b>18、 加快你的开机速度.. </b><br /><br />严格说起来,FreeBSD 的开机速度算满快的,不过中间会有个 10 秒的延迟时间(以便让你进入 boot 的 command prompt mode),如果你嫌这10秒还是太慢了,那你可将时间?#123;短一些.. <br /><br />FreeBSD
激活时会先去参考 /boot/defaults/loader.conf 档的设定,然后再参考
/boot/loader.conf,一般我们都不去?#123;整 /boot/defaults/loader.conf
这个档,而直接?#123;整 /boot/loader.conf.. <br /><br />只要在 /boot/loader.conf 中加上以下这一行即可 <br /><br />autoboot_delay="秒数" 即可,如 <br /><br />autoboot_delay="7" 代表7秒 <br /><br />这样开机是不是更快了.. <br /><br />另外建议,有时间可参考一下 /boot/defaults/loader.conf 这个档案的设定,其中有许多实用的设定哦.. <br /><br /><b>19、 忘了 root 密码 </b><br /><br />如果你忘了 root 的密码怎么办,这在 FreeBSD 中满好解决的,请照以下 steps 来处理.. <br /><br />1. 进入单人模式 <br /><br />开机后,当出现 <br /><br />Hit [Enter] to boot immediately, or any other key for command prompt. <br />Booting [kernel] in 10 seconds... <br /><br />按 space(或除了 enter 以外的键) 键则会进入 command prompt mode,同时出现一个 ok .. <br /><br />这时请输入 boot -s 以进入单人模式 <br /><br />2. 选择 sh <br /><br />进入单人模式后,系统会询问你要使用那个 sh,内定是 /bin/sh ,就使用这个吧,直接按 enter 跳过 <br /><br />3. 将所有的硬盘分割架起来 <br /><br /># mount -a <br /><br />4. 更改密码 <br /><br /># passwd <br /><br />长度要在 6 个以上,输入二次 <br /><br />5. 重新激活 <br /><br /># reboot <br /><br /><br /><b>20、 有关 kernel 的激活.. </b><br /><br />kernel 对 unix-like 系统来说,是非常重要的一环,如果 kernel 损坏或编译出了问题,可能会导致严重的后果.. <br /><br />FreeBSD 一向以安全著称,在这方面有什么防护的措施呢? <br /><br />FreeBSD 的 kernel 是放在 / 目录下,一般会有二个 <br /><br />kernel <br />kernel.GENERIC <br /><br />如果你有编译过核心(kernel)的话,则原先的 kernel 会转换成 kernel.old,新的核心会变成 kernel,也就是在 / 下的 kernel 档案如下: <br /><br />kernel => 新编译过的核心 <br />kernel.GENERIC <br />kernel.old => 原先的核心 <br /><br />那 kernel.GENERIC 是什么呢,这个是系统安装时所装好的,一般都不会变动,即使编译过核心亦然,这个档案可说是救命核心,最好不要乱动,理由如下所言.. <br /><br />FreeBSD 激活时,会使用 kernel 这个核心,如果这个档案不存在,则会抓 kernel.old 这个档案.. <br /><br />如果这二个档案不幸都不在,那怎么办..这时则会进入 command prompt mode,你必需自行输入 kernel 的名称,如 <br /><br />boot <kernel 名称=""> 如 <br /><br />boot kernel.GENERIC <br /><br />了解以上之后,在编译核心无法正常执行时,相信各位知道如何处理了.. <br /><br /><b>21、 FreeBSD 在那激活程序.. </b><br /><br />一般 FreeBSD 激活后会依序执行以下位置的程序.. <br /><br />1. /etc/rc.conf 这个档案内的程序,如 sendmail、sshd .. 都是在此执行,另外要注意的是,在执行这个档案之前,会先参考 /etc/defaults/rc.conf 的设定 <br /><br />2. /usr/local/etc/rc.d 下的一些 .sh 檔,这些档案的权限都是被设定成 x ,如 apache samba .. 都是在此设定 <br /><br />3. /etc/rc.local 这里也可设定,如我要把 postfix 设定在此,只需在这个档案内加一行,如下 <br /><br />/use/local/sbin/postfix start & <br /><br />加上 & ,就不会显示出讯息 <br /><br />4. 由 cron 所控制的一些档案,当时间到了,便会自动执行.. <br /><br />那心细的人可能会问, /etc/inetd.conf 内设定的呢?这些在第 1 项就执行了.. <br /><br />了解以上并时时注意是否有不明的程序在执行(可能是被人植入木马程序),也是日常检视系统的重要工作.. <br /><br /><b>22、 加快你的主机名称查询速度.. </b><br /><br />unix-like 系统,初期都是使用 hosts 这个设定文件来做主机的查询,因此有些程序在查主机名称时,都会参照这个设定档,像 sendmail 就是一个很好的例子.. <br /><br />系统内定第一个是会查 /etc/hosts 这个档案,因此如果里面设定有问题,则会影响到某些程序的执行.. <br /><br />典型的 hosts 档设定如下..以我本身的主机来说 <br /><br />127.0.0.1 localhost.cmlab.idv.tw localhost <br />61.219.230.5 cmlab.idv.tw cmlab <br />61.219.230.5 cmlab.idv.tw. <br /><br />其中第一及第二行最后一个项目是 aliases 名称(主机别名),比如我们在主机 <br /><br />ping cmlab.idv.tw <br /><br />和 <br /><br />ping cmlab <br /><br />是同样的结果.. <br /><br />你可把一些常用的主机加到这个项目内,如有一台 mail.cmlab.idv.tw ,假设 IP 为 61.219.230.8 <br /><br />则在这个 hosts 中加入以下 <br /><br />61.219.230.8 mail.cmlab.idv.tw mail <br />61.219.230.8 mail.cmlab.idv.tw. <br /><br />这样就行了.. <br /><br />另外如果有自行架设 dns server,请注意在 /etc/host.conf 这个档案,典型的档案如下: <br /><br /># $FreeBSD: src/etc/host.conf,v 1.6 1999/08/27 23:23:41 peter Exp $ <br /># First try the /etc/hosts file <br />hosts <br /># Now try the nameserver next. <br />bind <br /># If you have YP/NIS configured, uncomment the next line <br /># nis <br /><br />由以上可以看得出来,在查询主机名称时的顺序,是先查 hosts 再查 bind 也就是 dns,你可视你的需要修改其顺序.. <br /><br />另外要注意的就是 /etc/resolv.conf 文件,这个是有关 dns 主机 search 的顺序,如以我的设定如下: <br /><br />domain cmlab.idv.tw <br />nameserver 61.219.230.5 <br />nameserver 168.95.1.1 <br />nameserver 168.95.192.1 <br /><br />其中第一行是设定我的网域名称,第 2-4 行则是 dns 主机的设定,建议至少设二个以上,以免一个挂了,还有个备用的.. <br /><br />第2行是我的 dns 主机,3-4 行是 hinet 的 dns 主机.. <br /><br />了解以上并有正确的设定,是有助于主机的查询的及速度的提升.. <br /><br /><b>23、 我要如何分割硬盘.. </b><br /><br />档案目录对于 FreeBSD (或者是所有 unix-like 系统),都是相当重要的,如开始时,分割的不是很恰当,日后就会遇到一些麻烦,如空间不够..等问题.. <br /><br />那么,我们要如何分割比较恰当呢.. <br /><br />这就有关于你的用途及 FreeBSD 的目录架构了.. <br /><br />一般个人是建议你如此分割: <br /><br />1. / 根目录,一般在 250 ~ 500 MB 绝对够用,以我的根目录来说,使用一年多了,也才用了 66 MB 多。因为这个目录只是一些 kernel modules sbin bin etc .. 等目录 <br /><br />2. swap 档,一般人都不知道如何设较恰档,这也没一个标准,最主要是要看你的 ram 及硬盘而言,一般设成 1-2.5 倍(相对于你的 ram)。如你的 ram 在 256 mb 以上(含),设成一倍;如在 64 - 128 mb,则建议设成 2 倍 <br /><br />如要检查你的 swap 使用状况,可用以下指令来看.. <br /><br /># pstat -T <br />44/4044 files <br />0M/127M swap space <br /><br />由以上可看出目前使用的 swap 为 0 ,设定的大小为 128 M <br /><br />3. /var 目录 及 /usr 目录 <br /><br />这二个目录一般都会占比较大的空间,/var 的变动较小,以我个人来说,一年前设为 8 GB ,在目前只使用了不到 2GB。 <br /><br />但要注意的是一般的 mail 软件,都是将信件存在 /var/mail/ 中,如果你的信件很多或很大,这个部份不妨加大一些.. <br /><br />而 /usr 这个目录能大就给它大一点的空间,因为所安装的程序,或是 hone 都是在这个目录下(如果你没将 home 目录设成一个分割) .. <br /><br />那这两个要如何分配呢,我的建议是 usr 和 var 的比例为 3:1,或是 2:1 <br /><br />4. 有些主机使用者较多,如学校单位。如果你没将 home 设成一个 partition,则 FreeBSD 会将 home 安装在 /usr 目录下,如果为了管理及安全问题,则不妨将 home 分割为单一目录.. <br /><br />至于大小,我想应该 3-5 GB 左右,就绝对够用了 <br /><br />我们来举个实际例子,假设你有一颗 40 GB 的硬盘,使用内存为 128 MB RAM,那我建议你的硬盘如此分割.. <br /><br />1. / => 250 MB <br />2. swap => 取 2 倍,即 256 MB <br />3. /home 如要独立出来,给它 3-5 GB <br />4. 剩下来的以 3:1 或 2:1 的比例设给 /usr 及 /var <br /><br /><br />以上只是一般建议,最重要的是必需了解各目录的性质及实际使用情况而予以适当的分配,有关这方面的信息,不妨参考 man hier .. <br /><br /><b>25、 简单编辑你的文件档.. </b><br /><br />在 unix-like 中,标准的文字编辑器是 vi,不过 vi 对于初学者而言,并不是很容易上手.. <br /><br />而在 FreeBSD 中使用的是 ee ,这个文字编辑器,虽功能没 vi 这么强大,但使用简便..新手不妨初期时使用个编辑器.. <br /><br />其使用方式很简单,只要在 command line 下 ee 即可 <br /><br /># ee <要编辑的档案> <br />进入 ee 画面后,最上方是一些按键说明,如要取得相关的 ee 说明,可先按 ctrl+c 键,再输入 help,则会显示详细说明 <br /><br />有时可能只想在一个档案内加入一小部份的资料,那使用文字编辑器来处理,就显得没效率,其实我们可以利用 cat > [檔名]和 cat >> [檔名] 来做.. <br /><br />那这二个方式有何差异呢.. <br /><br />cat > [檔名] 时,如果档案不存在,则会自动产生一个档案;如档案存在则会将档案清空.. <br /><br />cat >> [檔名],档案不存在则自动建立此档,如存在则将所编辑的资料加在档案的最后.. <br /><br />举个例子,如我们要编辑 /etc/mail/access 这个是 sendmail 的 relay 设定档.. <br /><br />想在这个档案中加入 192.168.88.5 relay <br /><br />则可用此方法(假设 access 档案已存在,故使用 cat >> .. 的方法) .. <br /><br /># cat >> /etc/mail/access <br />192.168.88.5 RELAY <br />按 ctrl+d 存盘 <br /><br />如此则可将 192.168.88.5 relay 加到 access 的最后一行.. <br /><br />不过,建议大家,unix-like 的共通文字编辑器是 vi,有时间不妨好好的学一下 vi.. <br /><br /><b>26、 FreeBSD 帐号及密码的注意事项 </b><br /><br />在架完 FreeBSD 后,再来就是新增人员(使用者)的资料了.. <br /><br />在设定帐号时,请注意以下事项: <br /><br />1.其长度需在 1-16 个字符 <br />2.使用英文小写字母、数字及 - _ 符号 <br /><br />在设定密码时,请注意以下事项 <br /><br />1. 密码可设可不设,但建议你一定要设 <br />2. 长度最好在 6 个字以上,你知道据安全专家的说法,破解一个长度6及长度4密码,至少要多花 10 倍的时间 <br />3. 请勿用你的生日、相关证照号码、电话..等资料,而使用大小写英文字母及混合特殊符号,如 ct!Home-12 就是一个相当不容易破解的密码 <br />4. 长度最长我曾设到 16 位数(最大长度多少,有兴趣者可自行试试) <br /><br /><b>27、 有关系统的一些激活问题.. </b><br /><br />有时,会修改 FreeBSD 的一些设定,如一些网络参数、软件的 .conf 设定,或是 /etc/r.conf 檔,那么如何让设定值生效,是否一定要重新开机呢? <br /><br />这可分为三方面来说.. <br /><br />1. 网络相关设定,如网络适配卡、hostname .. 等,只要执行以下指令就可以重新加载你的网络设定.. <br /><br /># sh /etc/netstart <br /><br />netstart 是一个 script 档案,执行时会去参考 /etc/rc.network。因此只要执行这个指令就能够重新激活网络设定.. <br /><br />有兴趣者可参考一下 netstart 及 rc.network 这二个档的内容,研究看看到底做了些什么东东.. <br /><br />2. 修改了 rc.conf 中其它的设定 <br /><br />可参考以下三个 step 来做.. <br /><br />. 进入单人模式 <br /># shutdown now <br /><br />. 选择 sh,造内定值即可,即 /bin/sh <br /><br />. 离开单人模式 <br /># exit <br /><br />这样就会重新激活系统了.. <br /><br />3. 软件的设定,如一些 *.conf 檔,像是修正了 apache sendmail .. 等 <br /><br />通常在 /etc/local/rc.d/ 这个目录中会有相关的 .sh 檔,直接执行就可以了,注意的是一般要加上参数,一般的参数有以下(视软件而定会有不同).. <br /><br />start 激活 <br />stop 停止 <br />reload 或 restart 重新激活 <br /><br />第二种方法就是直接使用 killall,如我们要重新激活 inetd,可用以下方法: <br /><br /># killall -1 inetd <br /><br />或是 <br /><br /># killall -HUP inetd <br /><br />这样就可以重新激活这个 daemon 了 <br /><br /><b>28、 保护你的档案 </b><br />在系统中,有许多档案或一些设定档是非常重要的,加上 FreeBSD (或是一般 unix-like)系统都没有类似 ms 的垃圾回收桶的功能,万一不幸删掉(或修改)某个重要的档案,可能会造成不小的困扰.. <br /><br />虽然,FreeBSD 对于档案的权限设定的非常严密,但有些时候,我们以 root 身份工作,仍会有此风险.. <br /><br />那要如何避免这种情形发生或是保护某些重要的档案呢? <br /><br />我们可以用 chflags 来达成这个目的,顾名思义, chflags 是由二个字所组成,即 change 和 flags(档案的旗标).. <br /><br />例如我们要保护 /etc/inetd.conf 这个档案,以免误删或被修改,则指令如下: <br /><br /># chflags schg /etc/inetd.conf <br /><br />这样就可以保护这些档案,如要显示这些档案的旗标(flag),可用 ls 来看.. <br /><br /># ls -lo /etc/inetd.conf => l 是小写的 L <br /><br />-rw------- 1 root wheel schg 47 Mar 28 21:29 inetd.conf <br /><br />要解除旗标设定,可用 unschg,也就是在 schg 前加 un ,如: <br /><br /># chflags unschg /etc/inetd.conf <br /><br />大部份我们进入主机都是以 root 身份执行,因此稍不小心,可能就..因此建议将一些重要的档案及设定档设定为 schg flags,以保护档案.. <br /><br />如 /bin、 /sbin、 /etc/.conf、 /usr/lcaol/etc/*.conf .. 这些档案最好都是定成 schg 旗标.. <br /><br />chflags 详细用法请参考 man chflags.. <br /><br /><b>29、 谈谈软件的安装路径.. </b><br /><br />FreeBSD 对于档案目录的观念非常重,什么样的档案要放在那个目录都有规定,这也是有别于其它 unix-like 系统.. <br /><br />一般我们将软件安装分成二个部份,在这里来探讨一下软件到底都安装到那去了.. <br /><br />在安装软件时,通常会安装诸如 执行档、设定档、man file、doc 文件.. <br /><br />1. 安装系统时所安装的软件 <br /><br />执行档通常装在 /bin、/sbin、/usr/bin、/usr/sbin、/usr/libexec 下 <br />设定文件通在在 /etc 目录下 <br />man file 通常在 /usr/man 或 /usr/share/man <br />doc 文件通常在 /usr/share/doc 下 <br /><br />2. 经由 package 或 port 安装的软件 <br /><br />执行档通常装在 /usr/local/bin、/usr/local/sbin、/usr/local/libexec 下 <br />设定文件通在在 /use/local/etc 目录下 <br />man file 通常在 /usr/local/man .. <br />doc 文件通常在 /usr/share/doc 下 <br /><br />以上并不是绝对的(所以我用通常..^.^),因为有些特殊情况需视软件而定.. <br /><br />如此有时可能会造成些许困扰,因为如 ssh 、 bind .. 大多是在系统安统时就安装的,那如果升级新版时怎么办.. <br /><br />由
于 FreeBSD 找寻执行档时会依照 $PATH 这个环境变量找寻,因为 /bin、/sbin、/usr/bin、/usr/sbin 比
/usr/local/bin 或 /usr/local/sbin 先,所以会先执行..也就是先抓到旧版的执行档.. <br /><br />因此在更新时要注意这种情况,以免更新了还是执行旧的程序.. <br /><br />那么如何看安时程序时的相关档案的安装路径呢?通常有以下方法 <br /><br />1. 看 port 的 pkg-plist 檔 <br />2. 有时用 man [执行档名称] 可看到一些重要档案的位置 <br />3. 看说明文件,通常在 /usr/local/share/doc 目录下 <br /><br /><b>30、 如何在 FreeBSD 同一片网硌卡加一个 ip 地址 </b><br /><br />有的时候,需要在同一片网络卡上加 ip 以达到一些特殊的要求.. <br /><br />在 FreeBSD 这是非常简单的,假设原先网络卡的 ip 是 211.211.211.211,想加一个 211.211.211.212,使用的是 rl0 这片网络卡,则做法如下.. <br /><br />1. 在 /etc/rc.conf 加上这一行 <br /><br />ifconfig_rl0_alias0="inet 211.211.211.212 netmask 255.255.255.255" <br /><br />其中的 alias0 就是加装的第一个 ip,如要设定多个可在此修正,如 alias1、alias2.. aliasN <br /><br />2. 重新激活网络卡,执行 /etc/netstart <br /><br /># /etc/netstart <br /><br /><b>31、 简单的加密你的资料 </b><br />在实务上我们常需要将某些敏感的资料加密,一般我们可使用 pgp 或在这里所介绍的 crypt 来达到这个功能.. <br /><br />crypt 是透过 | 这个管道转换功能及密码设定来达成加密的功能,也就是说将你所设的密码当做加密产生的种子随机数.. <br /><br />先说明一下 crypt 的使用方法: <br /><br />crypt [-s] [-k] [password] <br /><br />一般 -s 及 -k 参数可不予理会,password 是加密或解密的密码 <br /><br />在这里假设我们先产生一个 test.txt 档,内容为 test,然后用 1234 这个密码加密 <br /><br /># cat > test.txt <br />test <br />按 ctrl+d 存盘 <br /><br />先看看 test.txt 内容 <br /><br /># more test.txt <br />test <br /><br />将 test.txt 这个档案用 1234 这个密码加密,需配合管道 | 及转向符号使用,加密后的文件名称为 test2.txt <br /><br /># cat test.txt | crypt 1234 > test2.txt <br /><br />如此则会产生一个加密后的档案 test2.txt,另外密码可先不输入,按 enter 键后会显示 enter key: 让你输入密码 <br /><br />我们来看看加密后的档案内容,原先是 test 结果变成了: <br /><br /># more test2.txt <br />e<a8>&<a7>h => 已经不是原来的 test <br /><br />接着来将 test2.txt 解开,如下,假设解开后的档名为 test3.txt: <br /><br /># cyrpt 1234 < test2.txt > test3.txt <br /><br />以上的意思是 <br /><br />1234 加密时的密码 <br />< test2.txt 将加密的档案转给 crypt 处理 <br />> test3.txt 解密后的资料转向到 test3.txt <br /><br />再显示 test3.txt 的内容是否和原来一样,即 test <br /><br /># more test3.txt <br />test <br /><br /><br />PS: <br /><br />1. 加密或解密时档名如和源文件一样,则会将原来的档案取代 <br />2. 另有一个指令 enigma 和 crypt 用法完全一样 <br /><br />参考资料 man crypt <br /><br /><b>32、用 telnet 简测你的服务器(Server)有无在跑 </b><br /><br />有时你可以用 telnet 测试你的 Server 有无正常的 run <br />例如:我要查看 ftpd 有无在跑 <br />可下指令:# telnet localhost 21 <br />若跑出类似以下的讯息, 表示有在跑 <br />-------------------------------- <br />Trying 127.0.0.1... <br />Connected to localhost.ahkun. <br />Escape character is '^]'. <br />220-=(<*> )=-.:. (( Welcome to PureFTPd 1.0.11 )) .:.-=(<*> )=- <br />220-You are user number 1 of 50 allowed <br />220-Local time is now 18:52 and the load is 0.06. Server port: 21. <br />220 You will be disconnected after 15 minutes of inactivity. <br /><br />若跑出以下的讯息, 表示没在跑 <br />------------------------------------------------ <br />Trying 127.0.0.1... <br />telnet: connect to address 127.0.0.1: Connection refused <br />telnet: Unable to connect to remote host <br /><br />同理你也可以用: <br />telnet localhost 25 测 stmpd <br />telnet localhost 110 测 pop3d <br /><br />结论: <br />正确来讲是用 telnet 测 port 啦~ <br /><br /><b>33、 如何防止别人登录到你的计算机 </b><br /><br />有时,我们并不想让别人直接登入到我们的主机或是只想限定某些人可使用,如 telnet、ssh.. <br /><br />或者是开放了些服务,如 ftp、smtpd ..等,由于这些都必需在主机端建有帐号,因此防止不相干的人登入到你的主机是非常重要的,也是一个安全上的考量.. <br /><br />但一般限定的方式都是使用 ip 或是 domain 的方式,那么有无方法可解决这个问题呢? <br /><br />答案是可从 /etc/login.access 来着手,这个档案就是限定 login 的.. <br /><br />一个典型的设定如下,例如我们想限定只有 root 及 使用者 john 可登入到主机(含local 及 remote): <br /><br />-:ALL EXCEPT root john:ALL <br /><br />可分为三个项目,每个项目间以 : 分隔,说明如下: <br /><br />1. + 或 - 代表允许或禁止 <br />2. 设定的使用者或群组,可用 ALL EXCEPT 来强化限定的范围 <br /><br />3. 限定的来源,如 ALL 代表全部、61.219.230. 、LOCAL、console、.bad.com ..等 <br /><br />适当的设定,可让你的系统更加的安全.. <br /><br />详细用法可 man login.access.. <br /><br /><br /><b>34、 一个 ./ 的技巧 </b><br /><br />众所周知,在 nix-like 中执行目前目录中的可执行文件时,必需加上 ./ 这二个符号,很多 unix-like 的初学者都会感觉较不习惯,因为在 dos 或 windows 的 dos 窗口中并不是如此.. <br /><br />其实在 unix-like 中如此设定是有其安全考量的,在使用指令或执行文件时,一般是建议使用完整的目录,例如要使用 ls,则如下: <br /><br /># /bin/ls <br /><br />当然,你直接输入 ls 亦可正确的执行,这是因为你所使用的 shell 中环境变量 $PATH 的因素.. <br /><br />你可键入 echo $PATH,来看目前 $PATH 的设定,当我们执行一个指令时,系统会依照这个环境变量来搜寻这个执行档并加以执行.. <br /><br />内定 shell 不会将目前目录 . 加到 $PATH 中,因此如果你想在目前目录执行这个目录下的执行文件而不想加上 ./ 时,可在你的 shell 中将 . 加入.. <br /><br />如一般在 FreeBSD 都是使用 tcsh,你可编辑个人 home 目录下的 .cshrc 檔 set path = ( ........ ,在此加入 . 即可.. <br /><br />记得重新退出 shell 再登录,以便让你的新设定生效. <br /><br /><b>35、在提示列秀出 [使用者]目前工作目录 (可以少打很多次pwd) </b><br /><br /># cd /root <br />编辑 .cshrc <br /><br /># set prompt="'hostname -s'# " ### 找到这一行并 mark 起来 <br />set prompt = "[%n]%/# " ### 新增此行并存盘离开 <br /><br /># logout <br /><br />login: root ....重新登入 <br /><br />ps.其它user id 是否可照办? 我还没试过哩..刚装freebsd而已 <br /><br /><b>36、rm 是 DEL 一个档案</b><br />rm -r 是 DEL 整个目录 <br /><br /><b>37、介绍一些一些有用的参数(注意大小写).. </b><br /><br />%B 代表高亮度 <br />%n 代表用者名称 <br />%m 主机名称 <br />%/ 目前的目录 <br /><br />一般我们可能比较在意以上几点,如我要管理好几台 FreeBSD 主机,那么以上几个参数就很重要了.. <br /><br />举个实例来说,如我想把我的 prompt 改成这样,而且要高亮度显示: <br /><br />使用者名称@主机名称[目录名称]> <br /><br />则 prompt 的设定应该是这样的.. <br /><br />set prompt = "%B%n@%m[%/]> " <br /><br />注
意 = 左右都要有一个空白,否则会出错,导致无法登入,另外如果要统一所有使用者的 prompt 的话,除了更改 /home/使用者/.cshrc
外,最好也在 /etc/csh.cshrc 中设定这一行,另外如要新增新用者也用这种提示,则请在
/usr/share/skel/dot.cshrc 中也加上(或改成)这一行,这是因为: <br /><br />tcsh 在使用时会先参考
/etc/csh.cshrc 这个档案,再依 user 去抓其 home 目录下的 .cshrc,而设定
/usr/share/skel/dot.cshrc 是让你新使用者时,自动将其 prompt 设定成 set prompt =
"%B%n@%m[%/]> " <br /><br />这种设法,当你在管理多台主机及切换目录时,就不易搞错而发生一些惨剧
</a7></a8></kernel></any></ip></file_name></username></username></group></username></group></username></password></group></username>Anonymoushttp://www.blogger.com/profile/15470207574707724400noreply@blogger.com0tag:blogger.com,1999:blog-6616068516723546448.post-87226012285918223772011-10-27T16:14:00.000+08:002011-10-27T17:01:35.184+08:00blogspot 用 google prettify code 实现 代码高亮wordpress有很多代码高亮的插件,blogger可以使用 <a href="http://code.google.com/p/google-code-prettify/" target="_blank">google prettify code</a> 为 <a href="http://www.blogger.com/" target="_blank">Blogspot</a> 来实现.<br />
<br />
<br />
<a href="http://code.google.com/p/google-code-prettify/" target="_blank">google prettify code</a>是一个轻量级的Javascript模块通过CSS文件对代码进行上色处理,支持C、Java、PHP、Python、HTMLl和Javascript等十几种语言。让我们动手吧。<br />
<br />
1.进入<a href="http://www.blogger.com/" target="_blank">Blogspot</a>控制台 –>布局 –>修改HTML<br />
在head区调用<a href="http://code.google.com/p/google-code-prettify/" target="_blank">google prettify code</a>的Javascript和CSS文件:<br />
<pre><span class="pun"><</span><span class="tag">link</span><span class="pln"> </span><span class="atn">href</span><span class="pun">=</span><span class="atv">"http://google-code-prettify.googlecode.com/svn/trunk/src/prettify.css"</span><span class="pln"> </span><span class="atn">rel</span><span class="pun">=</span><span class="atv">"stylesheet"</span><span class="pln"> </span><span class="atn">type</span><span class="pun">=</span><span class="atv">"text/css"</span><span class="pun">/></span><span class="pln">
</span><span class="pun"><</span><span class="tag">script</span><span class="pln"> </span><span class="atn">src</span><span class="pun">=</span><span class="atv">"http://google-code-prettify.googlecode.com/svn/trunk/src/prettify.js"</span><span class="pln"> </span><span class="atn">type</span><span class="pun">=</span><span class="atv">"text/javascript"</span><span class="pun">/></span><span class="pln">
</span></pre>
2.将“”改成“”<br />
3.修改pre标签的CSS以适合您的使用。<br />
<pre><span class="pln">pre </span><span class="pun">{</span><span class="pln">
margin</span><span class="pun">:</span><span class="pln"> </span><span class="lit">5px</span><span class="pln"> </span><span class="lit">20px</span><span class="pun">;</span><span class="pln">
border</span><span class="pun">:</span><span class="pln"> </span><span class="lit">1px</span><span class="pln"> dashed </span><span class="com">#666;</span><span class="pln">
padding</span><span class="pun">:</span><span class="pln"> </span><span class="lit">5px</span><span class="pun">;</span><span class="pln">
background</span><span class="pun">:</span><span class="pln"> </span><span class="com">#f8f8f8;</span><span class="pln">
white</span><span class="pun">-</span><span class="pln">space</span><span class="pun">:</span><span class="pln"> pre</span><span class="pun">-</span><span class="pln">wrap</span><span class="pun">;</span><span class="pln"> </span><span class="com">/* css-3 */</span><span class="pln">
white</span><span class="pun">-</span><span class="pln">space</span><span class="pun">:</span><span class="pln"> </span><span class="pun">-</span><span class="pln">moz</span><span class="pun">-</span><span class="pln">pre</span><span class="pun">-</span><span class="pln">wrap</span><span class="pun">;</span><span class="pln"> </span><span class="com">/* Mozilla, since 1999 */</span><span class="pln">
white</span><span class="pun">-</span><span class="pln">space</span><span class="pun">:</span><span class="pln"> </span><span class="pun">-</span><span class="pln">pre</span><span class="pun">-</span><span class="pln">wrap</span><span class="pun">;</span><span class="pln"> </span><span class="com">/* Opera 4-6 */</span><span class="pln">
white</span><span class="pun">-</span><span class="pln">space</span><span class="pun">:</span><span class="pln"> </span><span class="pun">-</span><span class="pln">o</span><span class="pun">-</span><span class="pln">pre</span><span class="pun">-</span><span class="pln">wrap</span><span class="pun">;</span><span class="pln"> </span><span class="com">/* Opera 7 */</span><span class="pln">
word</span><span class="pun">-</span><span class="pln">wrap</span><span class="pun">:</span><span class="pln"> </span><span class="kwd">break</span><span class="pun">-</span><span class="pln">word</span><span class="pun">;</span><span class="pln"> </span><span class="com">/* Internet Explorer 5.5+ */</span><span class="pln">
</span><span class="pun">}</span><span class="pln">
</span></pre>
现在可以写一篇博客试一下了,将您的代码放在pre标签内,给pre加上class为“prettyprint”,即:<br />
<br />
<pre class="”prettyprint”">
your code
</pre>
<br />
<br />
参考 : <a href="http://edwin-chain.blogspot.com/2008/11/how-to-publish-source-code-in.html">How to publish source code in Blogger.com</a><br />
<a href="http://google-code-prettify.googlecode.com/svn/trunk/README.html">Javascript code prettifier</a><br />
<a href="http://antlite.com/blog/2008/07/google-prettify-code-syntax-highligting-in-blogspot/">用google prettify code给blogspot代码着色</a>Anonymoushttp://www.blogger.com/profile/15470207574707724400noreply@blogger.com0tag:blogger.com,1999:blog-6616068516723546448.post-4588038912320108792011-10-26T18:09:00.000+08:002011-10-31T23:04:17.970+08:00利用grub2直读iso镜像 制作多启动u盘U盘现在容量越来越大,4-8G的U盘只装一个启动系统太浪费了,这几天看了看利用grub2制作多启动U盘的内容,有点心得,这里大概说说.<br />
<br />
<span style="font-size: large;"><b>原理:</b></span><br />
<div style="color: red;">
<a href="http://michael-prokop.at/blog/2009/05/25/boot-an-iso-via-grub2/">Boot an ISO via Grub2</a></div>
利用grub2可以启动iso文件的方法,可以制作大量的多启动U盘,但是很大部分还不支持,比如常用的debian,centos,等等就不支持,不过我常用的systermrescuecd,archboot,freebsd都支持这种启动方式.<br />
<br />
<br />
<span style="font-size: large;"><b>操作过程:</b></span><br />
<br />
首先把U盘分区,我实验用的U盘有2G容量,为了通用性,我就格式化为fat32格式,这样windows和linux,以及bsd下都可以复制iso,修改grub.cfg文件.<br />
<br />
1)<b><u>分区就使用fdisk</u></b> <br />
<br />
首先你要把u盘的mbr清空,避免以前做的mbr影响将要安装的grub2启动<br />
<br />
(<span style="color: red;">X</span>代表你的<span style="color: orange;">U盘所在的盘符</span>,比如我的u盘就是/dev/sdb) <br />
<br />
$ <span style="color: lime;">sudo dd</span><span style="color: orange;"> </span><span style="background-color: black; color: orange;">if=/dev/zero of=/dev/sd<span style="color: red;">X</span> bs=512 count=1</span><br />
<br />
$ sudo fdisk -l<br />
$ <span style="color: lime;">sudo fdisk</span> <span style="background-color: black; color: orange;">/dev/sd<span style="color: red;">X</span></span><br />
<br />
d删除已有分区,p显示分区情况,m察看fdisk帮助,n新建分区,p为主分区,t转换分区格式,b转换为win95vfat格式,l显示可以转换的分区格式,a激活启动分区,w保存分区情况,q不保存关闭fdisk<br />
<br />
2) <b><u>安装grub2</u></b><br />
<br />
这里要注意,<span style="color: red;">安装的grub2最好是32位的</span>,比如systermrescuecd和ubuntu livecd都选用32位的,可以保持兼容性;我这里就走了很多弯路,使用机器arch本身的grub2,导致u盘无法启动的情况,应为我的arch是64位的.<br />
<br />
首先挂载你的u盘,如果你使用gnome3,或者其他自动挂载的桌面,你就需要找到你的u盘挂载的地方<br />
<br />
$ <span style="color: orange;">sudo mount</span> <span style="background-color: black;"><span style="background-color: black; color: red;">-t vfat</span> <span style="background-color: black; color: lime;">/dev/sdb1 /mnt</span></span><br />
<br />
$ <span style="color: orange;">sudo grub-install</span> <span style="background-color: black; color: lime;">--no-floppy --force --root-directory=/mnt /dev/sdb1</span><br />
<br />
<br />
3) 编辑grub.cfg文件,并添加iso文件<br />
<br />
$ <span style="color: orange;">sudo mkdir</span> <span style="background-color: black; color: lime;">/mnt/iso</span><br />
<br />
把你需要启动的iso镜像放到/mnt/iso目录中就可以了<br />
<br />
$ <span style="color: orange;">sudo vim</span> <span style="background-color: black; color: lime;">/mnt/boot/grub/grub.cfg</span><br />
<br />
下面是我的grub.cfg配置文件,你可以自己根据自己的情况修改<br />
<title>~/grub.cfg.html</title>
<style type="text/css">
<!--
pre { white-space: pre-wrap; font-family: monospace; color: #ffffff; background-color: #000000; }
body { font-family: monospace; color: #ffffff; background-color: #000000; }
.Constant { color: #af5f00; }
.Statement { color: #804000; }
-->
</style>
<br />
<pre><span class="Statement">set color_normal</span>=<span class="Constant">'light-blue/black'</span>
<span class="Statement">set color_highlight</span>=<span class="Constant">'light-cyan/blue'</span>
menuentry "System Rescue CD" {
loopback loop /iso/systemrescuecd-x86-2.3.1.iso
<span class="Statement"> linux (loop)/isolinux/rescuecd isoloop=/iso/systemrescuecd-x86-2.3.1.iso setkmap</span>=<span class="Constant">us docache dostartx</span>
initrd (loop)/isolinux/initram.igz
}
menuentry "Parted Magic Disk Utilities" {
loopback loop /iso/pmagic-6.2.iso
<span class="Statement"> linux (loop)/pmagic/bzImage iso_filename=/iso/pmagic-6.2.iso edd=off noapic load_ramdisk=1 prompt_ramdisk=0 rwnomce sleep=10 loglevel</span>=<span class="Constant">0</span>
initrd (loop)/pmagic/initramfs
}
menuentry "Ubuntu 11.04" {
loopback loop /iso/ubuntu-11.04-desktop-i386.iso
<span class="Statement"> linux (loop)/casper/vmlinuz boot=casper iso-scan/filename</span>=<span class="Constant">/iso/ubuntu-11.04-desktop-i386.iso noeject noprompt --</span>
initrd (loop)/casper/initrd.lz
}
menuentry "Arch Linux i686" {
loopback loop /iso/archlinux-2011.10-1-archboot.iso
<span class="Statement"> linux (loop)/boot/vmlinuz rootdelay</span>=<span class="Constant">10</span>
initrd (loop)/boot/initrd.img
}
menuentry "Arch Linux x86_64" {
loopback loop /iso/archlinux-2011.10-1-archboot.iso
<span class="Statement"> linux (loop)/boot/vm64 rootdelay</span>=<span class="Constant">10</span>
initrd (loop)/boot/initrd64.img
}
menuentry "FreeBSD 8.2 i386" {
<span class="Statement"> set isofile</span>=<span class="Constant">/iso/FreeBSD-8.2-RELEASE-i386-disc1.iso</span>
loopback loop $isofile
<span class="Statement"> kfreebsd (loop)/boot/kernel/kernel iso-scan/filename</span>=<span class="Constant">$isofile noeject noprompt splash --</span>
<span class="Statement"> kfreebsd_module (loop)/boot/mfsroot.gz type</span>=<span class="Constant">mfs_root</span>
}
menuentry "FreeBSD 8.2 x86_64" {
<span class="Statement"> set isofile</span>=<span class="Constant">/iso/FreeBSD-8.2-RELEASE-amd64-disc1.iso</span>
loopback loop $isofile
<span class="Statement"> kfreebsd (loop)/boot/kernel/kernel iso-scan/filename</span>=<span class="Constant">$isofile noeject noprompt splash --</span>
<span class="Statement"> kfreebsd_module (loop)/boot/mfsroot.gz type</span>=<span class="Constant">mfs_root</span>
}
</pre>
<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEivYtlNpcnBAp61bkbJ2AP1Ve9rO6ihIj_pXbJU9dQ5StQ7PLP5xcjJiPYGGrvmTOuXivjzOl6mIHSyvkAspB3Ao0k43y8f56INvPVdviJjxAod70OQNbUISMxUjSppiKa4Vr4o8G2V4-Rm/s1600/screenshot-2011-10-26-18-01-19.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="227" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEivYtlNpcnBAp61bkbJ2AP1Ve9rO6ihIj_pXbJU9dQ5StQ7PLP5xcjJiPYGGrvmTOuXivjzOl6mIHSyvkAspB3Ao0k43y8f56INvPVdviJjxAod70OQNbUISMxUjSppiKa4Vr4o8G2V4-Rm/s400/screenshot-2011-10-26-18-01-19.png" width="400" /></a></div>
<br />
参考 : <a href="https://wiki.archlinux.org/index.php/Archboot#Restore_Usbstick">Restore_Usbstick</a><br />
<a href="http://www.pendrivelinux.com/boot-multiple-iso-from-usb-via-grub2-using-linux/">Boot Multiple ISO from USB via Grub2 using Linux</a><br />
<a href="http://www.panticz.de/MultiBootUSB">MultiBootUSB shell</a><br />
<a href="http://unix.stackexchange.com/questions/665/installing-grub-2-on-a-usb-flash-drive">Installing Grub (2) on a USB flash drive</a><br />
<a href="http://www.pendrivelinux.com/install-grub2-on-usb-from-ubuntu-linux/">Install GRUB2 on USB from Ubuntu Linux</a>Anonymoushttp://www.blogger.com/profile/15470207574707724400noreply@blogger.com0tag:blogger.com,1999:blog-6616068516723546448.post-80219467320723168612011-10-26T15:22:00.001+08:002011-10-26T15:22:59.680+08:00qemu直接使用u盘启动一直使用virtualbox做虚拟机,今天想做个usb的多启动光盘,但是vbox使用u盘启动的方法太麻烦了.<br />
<br />
<br />
搜索发现qemu可以支持直接u盘启动,方法也很简单.<br />
<br />
首先 , 确保安装qemu <br />
<br />
$ sudo pacman -S qemu<br />
<br />
<br />
然后,找到你的u盘,可以使用fdisk,df,来察看,比如我的u盘就是/dev/sdb<br />
<br />
$ sudo fdisk -l <br />
<br />
最后,就可以使用qemu来启动你的u盘了<br />
<br />
$ sudo qemu -m 128 -hda /dev/sdb<br />
<br />
上面参数的含义是使用128M内存,以hda方式,把/dev/sdb作为启动盘引导<br />
<br />
<br />
当然,你也可以使用物理硬盘来引导,比如<br />
<br />
$ sudo qemu -m 128 -hda /dev/sda <br />
<br />
就可以把你本身的物理硬盘系统启动起来<br />
<br />
<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh2OMUoNe0vyiJljQqbcPFrHBkXf4zQ5wHkVP8TWLrwYmpy00HLcKIaqU1txHlivInSKmo8a5OUDaRNh8FOK0-P0w7NcBkO-sMrzJ5d2EmkQdJW6ELyXzri4QOH3gKRz9Deie7pEUsH5TRt/s1600/screenshot-2011-10-26-15-21-32.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEh2OMUoNe0vyiJljQqbcPFrHBkXf4zQ5wHkVP8TWLrwYmpy00HLcKIaqU1txHlivInSKmo8a5OUDaRNh8FOK0-P0w7NcBkO-sMrzJ5d2EmkQdJW6ELyXzri4QOH3gKRz9Deie7pEUsH5TRt/s1600/screenshot-2011-10-26-15-21-32.png" /></a></div>
<br />
<br />Anonymoushttp://www.blogger.com/profile/15470207574707724400noreply@blogger.com0tag:blogger.com,1999:blog-6616068516723546448.post-6347662657565301662011-10-26T15:12:00.003+08:002011-10-27T16:32:12.708+08:00使用最新的archboot制作启动u盘archboot 是arch脱离出来的使用最新arch源制作非官方的启动镜像,2011-10月版本作成了2合一盘,i686和X86_64位同一个iso,好东西,下面是<a href="https://wiki.archlinux.org/index.php/Archboot">archboot wiki</a>的介绍.<br />
<h2>
<span class="mw-headline" id="Archboot_Releases"></span><span class="mw-headline" id="Archboot_Releases">Archboot Releases</span></h2>
<ul>
<li> Those files are no official Arch Linux releases.
</li>
<li> Use them on your own risk.
</li>
<li> Hybrid image file and torrent is provided, which include i686 and x86_64 core repository.
</li>
<li> Please read the according Changelog files for RAM limitations.
</li>
<li> Please check md5sum before using it.
</li>
<li> <a class="external text" href="https://downloads.archlinux.de/iso/archboot/2011.10" rel="nofollow">Download 2011.10 „2k11-R6“</a> / <a class="external text" href="https://downloads.archlinux.de/iso/archboot/2011.10/boot" rel="nofollow">Download /boot (PXE/Rescue files)</a> / <a class="external text" href="ftp://ftp.archlinux.org/iso/archboot/Changelog-2011.10-1.txt" rel="nofollow">Changelog</a> / <a class="external text" href="https://bbs.archlinux.org/viewtopic.php?id=127923" rel="nofollow">Forum thread</a>
</li>
</ul>
下载下来以后, 直接 运行一下命令就可以<br />
<br />
<pre class="prettyprint">dd if=<imagefile> of=/dev/<yourdevice> bs=1M</yourdevice></imagefile></pre>Anonymoushttp://www.blogger.com/profile/15470207574707724400noreply@blogger.com0tag:blogger.com,1999:blog-6616068516723546448.post-79888702147407879302011-10-26T15:01:00.003+08:002011-10-27T16:00:32.101+08:00恢复u盘的默认状态<h2>
<span class="mw-headline" id="Restore_Usbstick">Restore Usbstick</span></h2>
Take care about which device actually is your USB stick. The next command will render all data on /dev/sdX inaccessible.
<br />
<ul>
<li> First, wipe the bootsector of the USB stick:
</li>
</ul>
<pre class="prettyprint">dd if=/dev/zero of=/dev/sd<span style="color: red;">X</span> bs=512 count=1
</pre>
<ul>
<li> Then, create a new FAT32 partition on the stick and write a FAT32 filesystem on it (vfat or type b in fdisk terminology):
</li>
</ul>
<pre class="prettyprint">fdisk /dev/sd<span style="color: red;">X</span>
n
p
1
t
b
w
mkdosfs -F32 /dev/sd<span style="color: red;">X</span>1 </pre>
<pre class="prettyprint">or (mkfs.vfat -F 32 -n mutilboot /dev/sd<span style="color: red;">X</span>1)</pre>Anonymoushttp://www.blogger.com/profile/15470207574707724400noreply@blogger.com0tag:blogger.com,1999:blog-6616068516723546448.post-7210152558484565622011-10-26T08:43:00.000+08:002011-10-26T09:01:00.174+08:00几个常用开源镜像源推荐平常经常装开源软件,从国外下载很慢,国内都有很不错的镜像,比如我常用的freebsd,centos,arch,ubuntu,这些镜像都有相应的源.<br />
<br />
首先就是国内大学类的镜像代表 BJTU 了,地址 http://mirror.bjtu.edu.cn/cn/<br />
<div class="separator" style="clear: both; text-align: center;">
</div>
<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiwv25jS59wLVUxHo_Y-jsveKJuQbdkb41fPmwzXmYCWggTCluJ1oH7ev2Lu10F4Xz3mK5CKnXlKSQHLBH531__4pnVBFuSPMAJ1JmWNxh9CjUKXSCCfIKKhSkw8WHxubbrigXTenbHSH5S/s1600/mirror.bjtu.edu.cn-2011-10-26-08-56-56.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="400" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiwv25jS59wLVUxHo_Y-jsveKJuQbdkb41fPmwzXmYCWggTCluJ1oH7ev2Lu10F4Xz3mK5CKnXlKSQHLBH531__4pnVBFuSPMAJ1JmWNxh9CjUKXSCCfIKKhSkw8WHxubbrigXTenbHSH5S/s400/mirror.bjtu.edu.cn-2011-10-26-08-56-56.png" width="395" /></a></div>
<br />
然后是国内比较流行的163网易镜像源,163还有不错的免费邮箱,是我邮箱的第二选择,当然第一选择是 gmail了 , 地址 http://mirrors.163.com/<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiJBG2OCVZ3I5d3I_dNv6idASOlPEjbtZP6iF1GTYLjCXg7Rc1oxMjbRwPgMN-F2N5jDdrj3R2cDzaMUuBqv7KIpnI_XoFgJCI1MZtaBWh64br3KxtJswThQ1IUXBKRAOq65zK2DRevXULC/s1600/mirrors.163.com-2011-10-26-08-57-11.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" height="400" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEiJBG2OCVZ3I5d3I_dNv6idASOlPEjbtZP6iF1GTYLjCXg7Rc1oxMjbRwPgMN-F2N5jDdrj3R2cDzaMUuBqv7KIpnI_XoFgJCI1MZtaBWh64br3KxtJswThQ1IUXBKRAOq65zK2DRevXULC/s400/mirrors.163.com-2011-10-26-08-57-11.png" width="395" /></a></div>
<br />
<div class="separator" style="clear: both; text-align: center;">
</div>Anonymoushttp://www.blogger.com/profile/15470207574707724400noreply@blogger.com0tag:blogger.com,1999:blog-6616068516723546448.post-64017197499615163212011-10-26T08:32:00.000+08:002011-10-26T08:32:26.364+08:00arch linux 重装win7后恢复grub2启动今天很郁闷,本来想尝试把u盘使用grub2作成多启动的,结果一不小心,把win7的c盘格式化了,只能进入arch,于是又重新安装了win7,结果又进不了arch,只能使用刚坐好的u盘恢复本机的arch了.<br />
<br />
<br />
情景:<br />
<br />
arch刚装好grub2(安装的grub2-bios),配置文件都还在;<br />
arch的安装镜像使用的是grub,所以需要有支持grub2安装的版本进行恢复,比如ubuntu的livecd,当然你也可以选择和我一样使用<a href="http://mirrors.163.com/archlinux/iso/archboot/2011.10/archlinux-2011.10-1-archboot.iso">archlinux-2011.10-1-archboot.iso</a>(支援i686和x86_64位安装).<br />
<br />
操作步奏:<br />
<br />
<br />首先使用livecd启动,打开一个终端<br />
<br />
$ su -<br />
<br />
把自己转为root,察看分区情况<br />
<br />
# fdisk -l<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhlijREG9wEdV1DYk1kCehCAhooye6JHwRzgobWAZlizY7MhshdkyuW0ihblNWck7seigMLY1Rua8hJ81_b3gz9LbUUnqMPLOfQmoWImvV6nPw9ZaN1SyRKB-67t3fV9zo0eqFexNcYOInP/s1600/screenshot-2011-10-26-08-13-19.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEhlijREG9wEdV1DYk1kCehCAhooye6JHwRzgobWAZlizY7MhshdkyuW0ihblNWck7seigMLY1Rua8hJ81_b3gz9LbUUnqMPLOfQmoWImvV6nPw9ZaN1SyRKB-67t3fV9zo0eqFexNcYOInP/s1600/screenshot-2011-10-26-08-13-19.png" /></a></div>
<br />
这里可以看到你的分区情况,比如我的/分区在/dev/sda10 ,/boot 分区在 /dev/sda8<br />
<br />
然后把分区挂载起来<br />
<br />
# mount /dev/sda10 /mnt<br />
<br />
# mount /dev/sda8 /mnt/boot<br />
<br />
接下来安装grub2 (grub2-bios)<br />
<br />
# grub_bios-install --root-directory=/mnt/ /dev/sda<br />
<br />
接下来重启就可以了<br />
<br />
参考:<br />
<a href="http://oppih.wordpress.com/2010/09/05/%e8%ae%b0%e5%bd%95%e4%b8%80%e4%b8%8b%e9%87%8d%e8%a3%85win%e5%90%8egrub2%e7%9a%84%e6%81%a2%e5%a4%8d%e6%96%b9%e6%b3%95/">记录一下重装Win后grub2的恢复方法</a><br />
<a href="https://wiki.archlinux.org/index.php/Archboot">arch wiki archboot 使用方法</a>Anonymoushttp://www.blogger.com/profile/15470207574707724400noreply@blogger.com0tag:blogger.com,1999:blog-6616068516723546448.post-32030303036615278492011-10-26T00:39:00.003+08:002011-10-26T00:39:59.983+08:00archlinux mkfs.vfat 和 mkfs.ntfs今天做个U盘的多启动盘,发现没有安装fat32的格式化工具,倒是有ntfs的格式化.<br />
<br />
原来需要mkfs支持vfat和ntfs格式化需要2个包<br />
<code> </code><br />
<code>dosfstools</code><br />
<code><br /></code><br />
<code>$ sudo pacman -S dosfstools </code><br />
<code> </code><br />
<code>这个包给你2个命令,mkfs.vfat,mkfs.msdos</code><br />
<br />
<code>如果你也想支持ntfs的格式化mkfs.ntfs就需要安装 </code><br />
<code><br /></code><br />
<code>$ sudo pacman -S </code><code>ntfsprogs</code><br />
<br />
<br />
<div class="separator" style="clear: both; text-align: center;">
<a href="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi_nIkKtbSK9e8RnwPFS-3QVxeXiEj-oC7K0imYTcktlROLQ6etcVKnIcoI0U4yKSNw-nTYt2h-KvxQJmFU40UhVrQ4ThPgxHWQ3GnknWyDCaUax1kpMfEyFAJOt4fG5jnGNzOEooq8Fdf5/s1600/screenshot-2011-10-26-00-38-49.png" imageanchor="1" style="margin-left: 1em; margin-right: 1em;"><img border="0" src="https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEi_nIkKtbSK9e8RnwPFS-3QVxeXiEj-oC7K0imYTcktlROLQ6etcVKnIcoI0U4yKSNw-nTYt2h-KvxQJmFU40UhVrQ4ThPgxHWQ3GnknWyDCaUax1kpMfEyFAJOt4fG5jnGNzOEooq8Fdf5/s1600/screenshot-2011-10-26-00-38-49.png" /></a></div>Anonymoushttp://www.blogger.com/profile/15470207574707724400noreply@blogger.com0tag:blogger.com,1999:blog-6616068516723546448.post-31697821336518439852011-10-25T22:21:00.000+08:002011-10-25T22:21:51.797+08:00Boot Multiple ISO from USB via Grub2 using Linux<em>Boot ISO Files directly from USB</em> using Grub2 from Linux.
Here is one way to create a Multiboot USB Flash Drive from a running
Ubuntu (I used the Live CD). You may eventually need a large Flash Drive
or USB Hard Drive in order to include every bootable ISO entry. I will
add more Bootable ISO files to the grub.cfg file as I find time to
test them. Contact me to submit working Bootable Linux ISO grub.cfg
entries for inclusion.<br />
<span id="more-5352"></span><br />
<strong>I. Format your USB Flash Drive to use a Single Partition</strong>:<br />
<ol>
<li>Open a terminal and type <code>sudo su</code></li>
<li>Type <code>fdisk -l</code> (and note which device is your USB Drive)</li>
<li>Type <code>fdisk /dev/sd<span style="color: red;">x</span></code> (replacing <strong><span style="color: red;">x</span></strong> with your actual usb device)</li>
<li>Type <code>d</code> (to delete the existing partition)</li>
<li>Type <code>n</code> (to create a new partition)</li>
<li>Type <code>p</code> (for primary partition)</li>
<li>Type <code>1</code> (to create the first partition)</li>
<li><code>Press Enter</code> (to use the first cylinder)</li>
<li><code>Press Enter</code> again (to use the default value as the last cylinder)</li>
<li>Type <code>a</code> (for active)</li>
<li>Type <code>1</code> (to mark the first partition active "bootable")</li>
<li>Type <code>w</code> (to write the changes and close fdisk)</li>
</ol>
<strong>II. Create a Fat32 Filesystem on the USB Flash Drive</strong>:<br />
<ol>
<li>Type <code>umount /dev/sd<span style="color: red;">x</span>1</code> (to unmount the mounted partition)</li>
<li>Type <code>mkfs.vfat -F 32 -n MULTIBOOT /dev/sd<span style="color: red;">x</span>1</code> (to format the partition as fat32)</li>
</ol>
<strong>III. Install Grub2 on the USB Flash Drive</strong>:<br />
<ol>
<li>Type <code>mkdir /media/MULTIBOOT</code> (to create a directory for the mountpoint)</li>
<li>Type <code>mount /dev/sd<span style="color: red;">x</span>1 /media/MULTIBOOT</code> (to mount the USB)</li>
<li>Type <code>grub-install --force --no-floppy --root-directory=/media/MULTIBOOT /dev/sd<span style="color: red;">x</span></code> (to install Grub2)</li>
<li>Type <code>cd /media/MULTIBOOT/boot/grub</code> (to change directory)</li>
<li>Type <code>wget pendrivelinux.com/downloads/multibootlinux/grub.cfg</code> (to get the grub.cfg file)</li>
</ol>
<strong>IV. Test to make sure your USB Device Boots into Grub2</strong>:<br />
Reboot your Computer, and enter your BIOS or Boot Menu. Set the Boot
Order to boot from the USB Device. Save your changes and Reboot. If all
goes well, you should be presented with a Grub2 Boot Menu.<br />
<strong>V. Adding the Bootable ISO files</strong>:<br />
<ol>
<li>Type <code>cd /media/MULTIBOOT</code> (assuming USB is still mounted here)</li>
<li>Follow the instructions for the ISO Distro you would like to add below. Simply click to expand the instructions.</li>
</ol>
http://www.pendrivelinux.com/boot-multiple-iso-from-usb-via-grub2-using-linux/<br />
http://www.pendrivelinux.com/install-grub2-on-usb-from-ubuntu-linux/<br />
http://inportb.com/2010/07/19/install-windows-7-from-usb-pen-drive-using-grub2-and-grub4dos/Anonymoushttp://www.blogger.com/profile/15470207574707724400noreply@blogger.com0