Archive for the ‘Linux’ Category
again杂记
星期二, 4月 17th, 20071.bind的配置文件里面#号是不能作为注释的,bind会无视#后面所有的内容
2.named-checkconf 和named-checkzone两个命令可以检查bind配置文件是否有问题
3.我的firefox不知道为什么打开之后就占去所有的cpu资源.重装无效,试图修改配置文件,无效.最后的解决方法是在系统中新建一个用户,把新用户的C:\Documents and Settings\***\Application Data\Mozilla\Firefox拷贝到原来用户相应位置,问题解决,cp回来原来的收藏,问题搞定!
VI..用于备份
星期二, 4月 3rd, 2007一、简介
Vi命令可以说是Unix/Linux世界里最常用的编辑文件的命令了,很多人不喜欢VI因为它 的众多的命令集,但是我们只需要掌握基本的命令然后灵活地加以运用,相信你会象我一样喜欢它的。 本文旨在更有条理有归纳性地介绍VI的一些最常用命令和一些高级的应用。
二、基本命令介绍
1) 光标命令
k,j,h,l——上下左右光标移动命令,虽然你可以在Linux中使用键盘右边的四个光标键, 但是记住这四个命令还有非常有用的,也就是右手在键盘上放置的位置部分。
nG ——n为行数,该命令立即使光标跳到指定行。
Ctrl+G——光标所在位置的行数和列数报告。
w,b——使光标向前或向后跳过一个单词。
2) 编辑命令
i,a,r——在光标的前,后,上方插入字符命令(i=insert,a=append,r=replace)。
cw,dw——改变(置换)/删除光标所在处的单词的命令 (c=change,d=delete)。
x,d$,dd——删除一个字符,光标所在处到行尾的所有字符,和整行的命令。
3) 查找命令
/string,string——从光标所在处向后/向前查找相应的字符串的命令。
4)拷贝复制命令
yy,p ——拷贝一行到剪贴板/取出剪贴板中内容的命令。
三、常见问题及应用技巧
1) 在一个新文件中读/etc/passwd中的内容,取出用户名部分
vi file
:r /etc/passwd 在打开的文件file中光标所在处读入/etc/passwd。
:%s/:.*//g 删除/etc/passwd中用户名后面的从冒号开始直到行尾的所有部分。
:3r /etc/passwd 这是在指定的行号后面读入文件内容。
另外一种方法删掉文件中所有的空行及以#开始的注释行。
#cat squid.conf.default | grep -v ‘^$’ | grep -v ‘^#’
2) 在打开一个文件编辑后才知道登录的用户对该文件没有写权,不能存盘。
vi file
:w /tmp/1 既然没法存盘,不想放弃所做的所有修改,先临时存到/tmp/1。
:20,59w /tmp/1 或者仅仅把第20到59行之间的内容存盘成文件/tmp/1。
3) 用VI编辑一个文件,但需要删除大段大段的内容。
vi file
Ctrl+G 把光标移到需要删除的行的处按ctrl+G显示行号,再到结尾处再按Ctrl+G。
:23,1045d 假定两次行号为23和1045,则把这几间的内容全删除。 也可以在开始和结束两行中用ma,mb命令标记后用:’a,’bd删除。
4) 在整个文件或某几行中在行首或行尾加一些字符串
vi file
:3,$s/^/some string /
在文件的第一行至最后一行的行首前插入some string。
:%s/$/ some string/g 在整个文件每一行的行尾添加 some string。
:%s/string1/string2/g 在整个文件中替换string1成string2。
:3,7s/string1/string2/ 仅替换文件中的第三到七行中的string1成string2。
Note: s为substitute,%表示所有行,g表示global。
5) 同时编辑两个文件,在两个文件中拷贝剪贴文本
vi file1 file2
yy 同时打开两个文件,在文件1的光标所在处拷贝所在行。
:n 切换到文件2 (n=next)。
p 在文件2的光标所在处粘贴所拷贝的行。
:N 切换回文件1。
6) 替换文件中的路径
:%s#/usr/bin#/bin#g 把文件中所有路径/usr/bin换成/bin。或者用:%s/\/usr\/bin/\/bin/g 在’/'前用\符号指出’/'是真的单个字符’/'。
VMware Server 的安装说明
星期五, 3月 2nd, 2007VMware Server 现在是一个免费软件(freeware),只不过配置的某个步骤需要 SN,SN 是可以在 vmware.com 上免费申请的,我一次就申请了 100 个。:)
因为 VMware 需要加载内核模块,所以其 Linux 版本支持的操作系统数目是有限的,从说明看,host 操作系统推荐是 SUSE Linux 10.1 或 Ubuntu 6.x,Red Hat Enterprise Linux 3.0 Update 8 和 Red Hat Enterprise Linux 4.0 Update 4 也能工作,现在我们是在 CentOS 4.3 上安装的,看起来似乎一切良好。
安装:rpm -i VMware-server-1.0.0-28343.i386.rpm
执行 /usr/bin/vmware-config.pl 进行配置
基本上一路回车下来,最后输入 SN,然后服务就自动启动了.
以后可以通过 /etc/init.d/vmware start/stop 来维护
下面就是安装 VMware-server-console,有 linux 版本(要求 gtk 环境),也有windows版本。server-console 是连接 server 进行管理的,比如创建虚拟机这样的活动。我们的 host 系统是双核的 CPU,在创建虚拟机的时候就有选项 CPU 的数目是 1 颗还是 2 颗
实际测试中发现,ubuntu 6.06 desktop 无法顺利启动 X,估计只能用 server install cd
安装配置 VMware Server 对于熟悉 VMware-Player/Workstation 的人来说可以说是小菜一叠,所以这里写的也很简单,主要是要感叹一下:现在这么强的软件都可以免费使用了,世界变化太大了。
后记:
即使硬件配置不高,VMware 也有用武之地,就是可以快速部署一个定制的系统环境,比如用于测试或者软件创建(build)
如果硬件配置较好的话,就可以在一台服务器上创建多个 Server,让每个开发人员有一个独立的系统。使用中感觉最落后的还是 I/O,怪不得 VMware 的企业环境 都是配合 SAN 创建的。在目前的条件下,最好还是每块 SATA 硬盘上配一个虚拟机,最多也就配两个,否则有严重的瓶颈,gcc 编译可是相当重的 I/O 操作。如果只是做 PHP 开发的话,也许同样的硬件能配置更多的虚拟机.
转载:如何在Linux 修复系统的 MBR
星期一, 11月 27th, 20061, MBR 总共有 512 个字节,前面446个字节是一个最简单的 boot loader,这个boot loader 的任务很简单,就是将第一个要启动的分区的第一个扇区装入内存。boot loader 之后64个字节是分区表,最后两个字节是 0×55AA.
2, M$ dos 下的 fdisk /mbr 命令就是将 M$ 的boot loader 写入 MBR 的前 446 个字节。M$ 的位于 mbr 的 boot loader 是根据分区的 activity 信息来决定装入哪个分区的。
3, Linux 的 grub-install /dev/hda 也会将自身的 stage1 内容写入 MBR 的前 446 个字节。实际上 grub 是一个很大的 boot loader,不可能全部放在 MBR 的 446 个字节里面,其他内容放在 /boot/grub 下面(debian sarge为例)。grub 比 M$ 的boot loader 智能,支持用户选择所配置的启动分区,然后装入这个分区的启动扇区。
综上所述,如果系统的 MBR 坏了,最简单的办法是用 DOS 启动盘启动系统后执行 fdisk /mbr 命令或者用 Linux 的启动盘启动系统后,chroot 到原来的 Linux 根目录下运行 grub-install /dev/sda 命令。
4, 关于 dd
4.1, dd if=/dev/hda of=/mbr.bak bs=446 count=1
这样可以把可用的 MBR 备份出来。
4.2, dd if=/mbr.bak of=/dev/hda bs=446 count=1
将原来备份的 MBR 恢复到硬盘上。
4.3, dd if=/dev/zero of=/dev/hda bs=446 count=1
将 MBR 上的 boot loader 删除掉,这样之后系统是不能启动的了,因为 BIOS 根据用户配置找到要启动的设备后没有boot loader 的入口了。这个命令看起来没有用,但是当 grub-install 或者 fdisk /mbr 在某些特殊情况下运行失败的情况下,先执行上述清空命令后往往可以解决问题。
-= 手工操作 MBR 有风险,执行 dd 命令需谨慎!=-
附:上述 hda 表示硬盘为 IDE, sda 表示硬盘为SCSI 或者 SATA; grub 不仅可以安装在 MBR,grub-install 命令还支持将 grub 安装到指定分区的头部。
原文来自小熊的blog
LVS基本配置(转)
星期三, 5月 31st, 2006简单术语:
Director:前端负载均衡器,运行lvs,目前只能为Linux,针对FreeBSD刚刚出来,性能不知道如何。可以针对web、ftp、cache、mms甚至mysql等服务做loadbalance。
RealServer:后段需要负载均衡的服务器,可以为各类系统,Linux、Solaris、Aix、BSD、Windows都可,甚至Director本身也可以作为RealServer使用
过完春节一直忙的稀里糊涂,脑袋一直转的太快,下午暂时有点空闲,正好最近N多朋友要做web 方式下的负载均衡,简单描述一下lvs的设置(不涉及HA、Mult-homing),当做大脑休息好了:p
lvs Linux Virtual Server,Linux下的负载均衡器,不多作介绍了,跟DNS轮询以及一些商业产品的比较等不做论述,具体看看LVS网站,支持LVS-NAT、 LVS-DR、LVS-TUNL三种不同的方式,nat用的不是很多,这里简单介绍一下DR、TUNL方式。
DR方式适合所有的RealServer同一网段下,即接在同一个交换机上
TUNL方式就RealServer可以任意了,完全可以跨地域、空间,只要系统支持Tunnel就成(Win2k3好像已经不支持了……)
方便以后扩充的话直接Tunl方式即可
Director系统为RHEL3+ClusterSuite(偶是懒人,懒得打kernel patch了:p)
RealServer系统为Rhel3+noarp补丁
Director设置:
需要在Director设置的就是/etc/sysconfig/ha/lvs.cf,以及安装ClusterSuite后启动pulse服务(Redhat的lvs服务,当然也可以手动),下面是一个简单的lvs设置(没有设置director HA),man lvs.cf看看详细设置,RHEL3里已经有了详细的手册
203.x.x.a为Director公网ip地址
203.x.x.b为需要Loadbance的域名的Ip地址
203.x.x.c 为第一个RealServer
203.x.x.d为第二个RealServer
#cat /etc/sysconfig/ha/lvs.cf
serial_no = 45
primary = 203.x.x.a
service = lvs
rsh_command = ssh
backup_active = 0
backup = 0.0.0.0
heartbeat = 1
heartbeat_port = 539
keepalive = 10
deadtime = 20
network = direct(Tunl方式改为tunnel)
nat_nmask = 255.255.255.255
reservation_conflict_action = preempt
debug_level = NONE
virtual www.test.com {
active = 1
address = 203.x.x.b eth0:0
vip_nmask = 255.255.255.255
port = 80
send = “GET / HTTP/1.0\r\n\r\n”
expect = “HTTP”
load_monitor = uptime
scheduler = wlc
protocol = tcp
timeout = 10
reentry = 15
quiesce_server = 0
server r1 {
address = 203.x.x.c
active = 1
weight = 1
}
server r2 {
address = 203.x.x.d
active = 1
weight = 1
}
}
上面的设置是对某个域名的web访问进行负载均衡,Director使用ssh定时收集RealServer上的负载,然后决定 Loadbalance 的分配,分配方式为WLC方式,然后启动pulse服务,看看/var/log/message里有没有什么配置错误,RHEL3里设置已经非常方便、简单
RealServer配置:
RS系统为Rhel3,针对DR、Tunl需要不同的设置,但关键的是arp问题,这里使用的noarp module,当然Rhel3里也提供了arptables来配合lvs(效果可能不是很好),这里介绍一下noarp
noarp编译不做介绍了,configure install后,insmod noarp把noarp加入内核,然后需要执行
noarpctl add 203.x.x.b 203.x.x.a
这是把所有对203.x.x.b的arp请求转向203.x.x.a(Director),然后建立虚拟ip以完成路由
DR的话需要建立网卡,放在eth0或者lo都行
ifconfig eth0:1 203.x.x.b netmask 255.255.255.255 up
Tunl方式的话需要启动tunl虚拟网卡
ifconfig tunl0 203.x.x.b netmask 255.255.255.255 up
同样在RealServer2上同样的设置
在两个RealServer上启动apache
Director上检测一下连接
ipvsadm -Ln
看看当前的负载分配
lvs的稳定性不用置疑,Rhas2.1、Rhel3里的LVS在偶这个懒人的4年使用里极其稳定,访问量从当时的几百人在线到现在的接近10K,只需 要根据负载增加后段的RealServer即可,但Rhas2.1的LVS对Tunl支持的不好,建议使用Rhel3进行tunl方式的 Loadbalance
升级2。6的内核
星期六, 4月 15th, 2006要关掉
/etc/selinux/config 中的enforcing
谁知道这是个什么参数?