二月 2006


uBrowser 是一个简单的浏览器,用 LibXUL 技术,把 Mozilla Gecko 引擎嵌入到了一个单独的应用程序。官方网站有更详细的关于这个浏览器的介绍,下载有两个版本,一个是源代码,文件很小,但配置很复杂。另一个版本直接运行版,下载后解压运行即可。这个浏览器的特点就是使用了openGL加速,你可以随意拖动网页,动态感非常强。刚刚用了一阵子,换成正常的浏览方式忽然有点晕了。希望尝新的朋友,快点自己去下载试用吧。

原文: http://www.ratiatum.com/news2874_Les_serveurs_de_Razorback_saisis.html

Razorback edonkey服务器是世界上最大的edonkey服务器,在线人数超过100万。但现在它已经成为过去了,比利时警察将服务器扣留了,它的两个管理员现在还不能联系上。当前得到的消息很少,Razorback的管理人员在当地时间2月21日早上10点左右被比利时联盟警察逮捕了,虽然Razorback在瑞士支付费用,但是它的服务器放置在比利时。Razorback服务器上并没有任何的不当内容和其他的版权内容。

MyMPC 系列之迪奥 DIY 版
一款专门为配合视频转换而打造的编解码器集成包

声明:本软件是由MyMPC 系列之精品 DIY 版改造而成,原作者为Silence。
致谢:Silence、风の铃音、阿飞、三月鸟、sdxy、空气空、比坂良、酒少爷及所有支持者。

注意:
1.推荐的安装环境是Windows XP,DirectX 9.0C,Windows Media Player 9/10,IE6,不支持Windows9x。
2.组件中有一些分离器、解码器的功能是重复的,故写上(默认启用)和(默认不启用)。(默认启用):装上即启用;(默认不启用):只是以文件方式复制,要使用时通过快捷方式切换启用。[学于AVPack]

组件:
AAC parser filter for DirectShow v 1.1.0
InterVideo Audio Decoder 6.0.88.0(默认不启用)
AC3/DTS Filter
AC3 Filter 1.01 RC5(默认启用)
APE 解码器
Gabest Avi Splitter 1.0.0.4
AviSynth 2.5.6a
CyberLink Video/SP Filter 6.0.0.1006(默认启用)
CoreAAC 1.2.0.573
CoreAVC Video Decoder 0.0.0.4(默认启用)
CoreVorbis 1.1.0.79
DC-DSP Filter 1.0.3.0(默认不启用)
DivX 5.2.1 解码器和编码器
ffdshow-20051129 builds by Daily
GraphEdit 9.4.78.0 汉化版
GSpot v2.52 Beta1 Build 040915 汉化版
GV Codec 1.2
Haali Media Splitter 2006.01.30(Matroska Splitter、MP4 Splitter、AVI Splitter、Ogg Splitter 都默认不启用)
Indeo 3.x-5.x(只有 XP SP1 及 2003 需要安装)
MPEG Layer-3 Audio Decoder 1.9.0.311
Lame MP3 codec 0.9.1.0(3.96.1) & LAME Audio Encoder 3.98 alpha 2
MatroskaDiag 1.0.0.62
Gabest Matroska Splitter v1.0.2.6(默认不启用)
Gabest MP4 Splitter 1.0.0.1
MPC 综合设置程序
Moonlight-Elecard MPEG 2 Demultiplexer 3.1.200.50117
Gabest Mpeg Splitter 1.0.0.0 (默认不启用)
Moonlight-Elecard MPEG2 Video Decoder 2.00.0.3611 (默认不启用)
Media Player Classic 6.4.8.7 蓝色网际汉化版
AC-3 ACM Decompressor 1.2
DivX;-) Audio Codec 4.1.00.3920
MPEG Layer-3 Audio Codec for MSACM 3.3.0.44
Ogg Vorbis Audio CODEC for MSACM 0.0.3.6
Gabest Ogg Splitter 1.0.0(默认启用)
Gabest RealMedia Splitter 1.0.1.1
RadLight MPC 解码器 版本:1.0.0.3 *不支持 Windows98
True Audio DirectShow Splitter 1.0.0.203 & Decoder 1.0.0.157 & Encoder 1.0.0.38
VobSub 字幕插件 2.33/2.37(默认启用2.33)
On2 VP6 Video Codec 6.4.2.0
On2 VP7 Video Codec 7.0.9.0
WavPack Audio DirectShow Splitter 1.0.3.277 & Decoder 1.0.3.431
Windows Media Video 9 VCM 9.0.1.0369
XVD 解码器 1.0.11.14
Koepi’s XviD Codec v1.1.0 final
QuickTime Decoder 7.0.3.50
RealPlayer 10.5 解码核心 & ActiveX 6.0.12.1348

更新:
2006.02.10:
-修正CoreAVC的版本为0.0.0.4,20060208版里的是0.0.0.2,这回真是挂羊头卖狗肉^^b。(感谢gxhunter指出)

本地下载:  DIODIY-20060210.exe

作者主页: http://dio1888.bokee.com/

FAQ:http://dio1888.bokee.com/2517607.html 

本文作者:kxn
神说,要有光,于是有了光;
神说,要灌水,于是有了 BBS

我们现在提到的 BBS ,通常指的都是 Telnet BBS ,用一个 term 软件连接上,就可以看到 文本的界面,比起如今花哨到无以复加的 WWW BBS 们来可谓是简陋到了极点,然而就是这样 的 BBS,无数人每天面对它长达两位数小时还乐在其中,恐怕 UI 设计专家们知道也要气到吐血。 也不时有人发表预言,预言 Telnet BBS 将很快消亡而被更加富有表现力的WWW BBS 全面取代, 只是年复一年,当年的预言者已经消失不见,BBS 上的用户数目却翻了一番又一番。。。这就是 Telnet BBS 的魅力。

Telnet BBS 系统数目众多,但是从根源找起,大致可以分成两大家族,Firebird BBS 和 Maple BBS,在大陆 Firebird BBS 的变种占据了绝对优势,在台湾地区则是 Maple BBS 的天下,由于 台湾地区计算机发展历史比较长,因此 BBS 的人气也比大陆高,同时上站人数过万的站点有好几 个,不过大陆毕竟有着人口优势,近年来教育网几大 BBS 的人数也迅速增长。下面我们就分别介 绍这两大 BBS 家族。首先是在大陆最为流行的 Firebird BBS ,最有名的 SMTH BBS, YTHT BBS, Firebird 2000 三大流派都是由此而来。

很久很久以前,有那么一群大学生,也可能是科研机构的研究员什么的,他们整天在Unix 主 机上面打滚,觉得要是能在主机上面做一个论坛样的东西多好,于是他们就写了一个命令行程序, 运行这个程序,操作者可以在界面下面留言,为了让多个人同时可以操作这个系统 ,他们把这个 程序设置为系统某个用户的 shell ,每个 telnet 上该主机的用户,只要使用这个用户的用户名和 密码登陆,就可以进行交流。这就是 Internet BBS 的雏形。经过一段时间的发展,这个系统具有 了相当多的交互功能,用户不仅可以留言,还可以互相发送信件,发送信息,看到同时在线的用 户等等。

BBS 系统的开发者们为了让更多的人能使用这个系统并完善之,将BBS 系统以开源协议发布 于网络上面。只要拥有Unix 主机,就可以取得源代码并安装BBS 系统。因此BBS 系统以很快的 速度发展起来。在众多BBS 系统中,某个叫做 Pirate BBS ,经过某些人修改后叫做 Eagle BBS 的 分枝,流传入了台湾地区,交大资讯工程系从他发展出了 Phoenix BBS,Phoenix BBS 是如今大部 分中文 Telnet BBS 系统的祖先,然而它的名字却远不如其后辈响亮,在它的基础上由中正资工进 一步修改的 BBS 系统,被赋予了那个大陆 BBS 开发者耳熟能详的名字――Firebird BBS。
应该说, BBS 系统在传入台湾地区时候虽然功能还比较简陋,但是 BBS 系统的基本架构已 经定型,比如多进程模型,共享内存信息交换,利用系统信号来传递呼叫消息,用文件存储文章 和索引等,这些设计在现在的 BBS 系统中大部分还在沿用,其中不少设计即使现在来看,也是相 当标准有效的多进程 Unix 服务器设计。

Telnet BBS 是一种流行于大学和研究机构中的电子公告牌系统,和时下流行的Web BBS 系统不同,BBS 的界面采用纯文本方式表现,用户使用终端软件连接BBS 系统,文本界面在 服务器端生成并发送出来,客户端软件仅原样显示文本内容,属于一种瘦客户机的应用。Telnet BBS(后面除非特殊提到,否则简称BBS)在台湾地区和大陆的教育网地区比较流行,比较 大规模的站点在线人数一般都在万人以上。

由于历史原因,BBS 系统采用的是Unix 下相当传统的1:1 多进程模型,每进程处理一个连接 的模型,此种模型的好处是服务相对比较稳定,不会因为一个用户出错导致整个系统的不可用, 但是也带来耗费资源较多和进程之间通信比较困难的问题。BBS 服务器端的复杂逻辑也使得分布 式设计很难实施。因此BBS 通常是单机承担几乎所有负载,大陆地区较大规模的BBS 服务器上经 常同时保持超过7000 进程,台湾地区的BBS 站甚至有并发20000 进程以上的纪录。 我们在维护大型bbs 站点的过程中,积累了一些优化和维护如BBS 这样高并发进程服务器的 经验,考虑到1:1 进程模型服务仍然有很广泛的应用,在这里写出和读者共享。

优化服务器是综合性的工作,不仅需要修改代码,还需要调整系统参数,包含有很多琐碎的 内容,根据目的来讲,大致可以根据节约资源的类型分为磁盘IO 优化,内存优化,和CPU 优化 等几方面。下面介绍的优化思路虽然应用于BBS,但是也适用于其他应用系统。

1: 磁盘IO 优化
磁盘IO 优化可以说是服务器优化中最重要的一环,除了极少数的纯计算性应用,几乎所有的 重载服务器最后都是卡在磁盘IO 瓶颈上面。
a) 尽量使用shm 等IPC 手段而不是文件
多进程和多线程相比,最大的麻烦是不同执行环境交换信息不方便,因此很多程序员选择了 使用文件交换信息,例如最早的BBS 设计中,用户的帐户信息是存在于文件中的,进程从文件中 读出内容,有修改后就写入文件。改进后的设计是将账号信息文件完整读入共享内存,所有修改 都写入共享内存,然后由外部进程定时往磁盘上面同步。 甚至flock 这样看起来不会造成太多IO 的同步操作都应该尽量避免,原因是flock 需要先open 文件,而open 文件需要找到i 节点,因此会占用文件系统的inode 缓存空间,可能造成其他IO 操 作的性能降低。在很多情况下面需要的只是一个跨进程的mutex,可以使用0/1 信号灯来实现。
b) 使用应用层缓存。
很显然,操作系统的缓存会受到很多因素的干扰,对于一些确定会经常访问的内容,例如版 面的最新几片文章和最新列表,如果放入shm 中缓冲,性能会有大幅度提升。
c) 尽量减少关键IO 数据结构的大小
Bbs 文章列表的索引文件是由定长数据结构构成的,在这个数据结构中为了将来扩展方便,留 下了很多保留域,造成了很多不必要的IO,删除不必要的域之后,数据结构变小了一半,减少了 很多IO。很多时候,扩展性和性能其实是对立的,如果很需要性能,那么损失一定的扩展性也是 不错的选择。
d) 避免在同一目录下放过多文件或者使用合适的文件系统
大部分文件系统对在同一目录中的文件列表采用线性存储,因此在一个目录下面存在很多文 件的时候,打开文件变得非常的慢,因此通常要将文件根据某种规则散列到不同的子目录中,例 如,文件 Atest 会被存放在 A/Atest ,如果文件太多,可能会需要对子目录下面的文件再次进行 散列。
另一种解决文件过多影响效率的方法是使用有特殊优化的文件系统,例如Linux 下的reiserfs。 在这些文件系统中,目录中的文件列表是用平衡树来组织的,因此同一目录下面可以同时有数十 万个文件而不会降低太多性能。
e) 根据系统的访问模式选择适合的硬件配置和系统参数
Bbs 系统使用零散的文件存放文章,它的访问模式基本是小文件随机读写,而文章数据相对比 较重要,因此bbs 使用strip 大小比较小的raid5 比较合适。文件系统选择专门为小文件优化的 reiserfs,系统的预读长度也可以调小一些,Linux 默认的长度是 256K, 有些偏大。如果是大文件 连续读写的话,那么raid 的strip 大小和系统的预读长度应该放大,文件系统则尽量选择结构简单 的文件系统例如ext2/3 等,如果数据并不是非常重要,那么甚至可以取消raid5,代之以raid0 或 者直接使用单独的硬盘。
2: 内存使用优化
Bbs 系统使用的多进程模式相当耗费内存,在BBS 发展过程中,最早遭遇的瓶颈就是内存。 减少内存的不必要浪费,可以节约出来作为系统缓存,从而间接提高更重要的IO 性能
a) 尽量避免动态初始化常量,使用const 说明将变量和常量区分开来。
Unix 系统在fork 出新进程的时候,子进程和父进程共享相同的空间,之后按照COW 机制, 对修改的页面才进行复制操作,常量如果可以预先计算出来(例如一些转换表之类),就应该尽量 避免在运行时动态初始化。另外因为只要修改一个字节,整个页面就都会被复制,因此应该避免 常量和会被修改的变量混在一起,编译器本身会自动将不会被修改的内容放在一起,程序员需要 做的事情,就是用const 通知编译器哪些内容是不会被修改的。
b) 减小内存的峰值使用,特别是堆栈中内存
很多人习惯写程序时候在堆栈上声明一个比较大的临时数组,认为退出函数之后这部分内存 会自动被释放。殊不知这样分配的内存并不会被动态被系统回收,因为系统并没有一个明显的标 记可以得知堆栈内存是否还在使用中,特别是在多线程的环境下面,操作系统通常采用的措施是 需要的时候分配页面,但是在进程退出之前并不回收。即使是通过malloc 分配的堆内存,其页面 是否回收也视库函数的实现而不确定。因此在无论什么情况下,贸然分配过大的内存,都会对性 能造成一定的影响。
c) 如有可能,尽量使用shm 来保证页面一定会被多个进程共享。
3: CPU 优化
这里说的CPU 使用优化,不包括像使用hash 来代替线性查找这类最基本的算法优化,而是涉 及一些和系统关系比较密切的操作。
a) 使用针对硬件优化的编译器
这应该是所有CPU 相关优化中最容易做到也是最容易看到效果的,Intel CPU 的Linux 系统上 面使用 Intel C/C++ 编译器,可以获得很好的效果,甚至AMD 的Athlon 系列CPU 也能获得一定 程度的加速。BBS 进站时候需要初始化很多内容,计算量比较大,使用gcc 时候负载在4 左右, 使用icc 编译以后负载马上下降到1 以下。推荐编译时候针对特定CPU 指令集优化并且打开跨文 件优化选项(-ipo)
b) 使用单独进程来初始化和维护共享内容,避免出现竞争导致逻辑错误 严格讲这并不能提升很多性能,只是为了减少多进程服务器上面经常出现的逻辑错误。在原 始的BBS 设计中,共享资源的创建是由第一个访问的进程在打开失败时候创建的,但是重负载服 务器上面有时候打开也会失败,从而导致多次创建共享资源。
c) 序列化容易导致负载上升的行为
BBS 进程在进站时候需要进行很多的初始化工作,同样进程退出的时候也要做很多的收尾工 作,此时对CPU 或者IO 的占用比较大,通过一个互斥锁可以使多个进程不要同时进行这些操作, 否则系统负载有可能上升到一定程度引起正反馈,导致系统彻底崩溃。
d) 尽量减少信号的使用
Unix 系统下面对于信号的实现的代价是比较大的,同时信号本身也很容易导致处理逻辑的混 乱。高负载服务器应该尽量减少信号的使用。
e) 对于大范围IO 读取操作,使用mmap 调用
使用mmap 操作比传统的read 操作好处是减少了一次内核态到用户态的拷贝。在大范围IO 操 作的时候具有优势,BBS 中使用mmap 操作来在文件中搜索内容,速度最高时候提高了5 倍左右。 但是需要注意的是,mmap 并不适用于有写入的情况,因为mmap 写盘的时候是以页为单位进行操 作,页中只要有一个字节被改写,就要往磁盘上面写整个页面的数据,无端增加了IO 量。
以上是我们在维护大型BBS 站点时积累的一些经验,供各位读者参考。

以前的办法是:

lilo: 在 boot: 的提示符下输入 linux single

grub: 按e修改kernel一行,在后面加上 single。

但是Debian Sarge这样做还是进入正常模式的,现在的做法是:

lilo: 在boot: 的提示符下输入 linux init=/bin/sh

grub: 按e修改kernel一行,在后面加入 init=/bin/sh

进去后就是root权限了,

mount -o remount /dev/hda1 / #请先确定/是加载于/dev/hda1,不是的话根据实际情况修改

cp /etc/shadow /etc/shadow.bak #备份一下,免得改错
vi /etc/shadow

找到root,将第一个:和第二个:之间的文字删除就可以了。
重启后,root的密码就为空了。

vhcs 2.4.x 发现一个重要的安全漏洞,请使用vhcs 2.4.x 的用户尽快更新。

更新方法:

1. 下载最新的补丁文件 vhcs_patch_2006-02-09.tar.bz2

2. 解压后用里面的 login.php 覆盖 /var/www/vhcs2/gui/include/login.php

3. 完成