新版YARV(基于Ruby 1.9.0 v2006-11-01)编译/安装/测试手记

昨晚作SVN例行更新时发现了这次变动。今天有空,作了个尝试:

一、Win32平台下安装

cd /yarv-svn/win32
configure
nmake(需要用到Bison,我用的是Cygwin带的)
nmake install-nodoc

默认会安装在当前盘符根目录下的/usr文件夹

C:/usr/bin>ruby -v

ruby 2.0.0 (Base: Ruby 1.9.0 2006-11-01) [i386-mswin32]
YARVCore 0.4.1 Rev: 572 (2006-11-04) [opts: [inline method cache] ]

如果现在运行程序,还是会报错,说ubygem未找到。需要将lib/ruby/site_ruby/1.8下的rubygems.rb, ubygems.rb以及rubygems, rbconfig这两个文件夹copy到usr/lib/ruby/site_ruby/2.0下;而且现在还未安装扩展库,还得将yarv-svn/ win32/.ext目录下的内容Copy到usr/lib/ruby/2.0下。就OK了。

二、Untuntu平台下安装
一开始编译时出错如下:

gcc -g -O2 -DRUBY_EXPORT -I. -I. -c eval_load.c
gcc -g -O2 -DRUBY_EXPORT -I. -I. -c eval_proc.c
eval_proc.c:14: 错误: 对 ‘rb_cUnboundMethod’ 的静态声明出现在非静态声明之后
ruby.h:725: 错误: ‘rb_cUnboundMethod’ 的上一个声明在此
eval_proc.c:15: 错误: 对 ‘rb_cMethod’ 的静态声明出现在非静态声明之后
ruby.h:710: 错误: ‘rb_cMethod’ 的上一个声明在此
make: *** [eval_proc.o] 错误 1

注释掉ruby.h三行多余的声明后(line:699,710,725),在Ubuntu下编译通过。

步骤总结:

autoconf
./configure --program-suffix=-yarv
make
make install-nodoc
(其余步骤与Win32下的类似)

suninny@lenovo-laptop:~/work/yarv-svn$ ruby-yarv -v

ruby 2.0.0 (Base: Ruby 1.9.0 2006-11-01) [i686-linux]
YARVCore 0.4.1 Rev: 572 (2006-11-04) [opts: [direct threaded code] [inline method cache] ]

三、跨平台对比测试:

这是那个词频统计程序的分值对比(U代表Ubuntu,C代表Cygwin,W代表Win32;/后是内存占用情况;括号中为上次的得分):

UA:3.10s(3.36s)/64M(91M)
UB:3.73s(4.11s)/2.2M(3.2M)
CA:3.16s(3.84s)/68M(95M)
CB:5.31s(6.04s)/5M(5M)
WA:4.98s/69M
WB:7.59s/5M

效能提升还是蛮显著地。令人惊讶的是WB方案中YARV的分值竟然比普通的Ruby184-win32还低。Ruby系列对Win32有偏见呀。

### 正确配置和运行 Flume-ng Agent 为了正确启动 `flume-ng` 代理并指定配置文件路径以及设置日志级别为 `INFO`,可以按照以下方法操作: #### 设置日志级别 Flume 的日志级别可以通过修改 `log4j.properties` 文件实现。通常情况下,该文件位于 `$FLUME_HOME/conf/log4j.properties` 路径下。打开此文件并将日志级别更改为 `INFO`,如下所示: ```properties log4j.rootLogger=INFO, CONSOLE ``` #### 启动命令 在设置了日志级别之后,使用以下命令启动 Flume-ng 代理,并指定配置文件路径 `dir-memory-hdfs.conf` 和代理名称 `a1`[^5]。 ```bash bin/flume-ng agent \ --name a1 \ --conf conf \ --conf-file conf/dir-memory-hdfs.conf \ -Dflume.log.file=flume-agent-a1.log \ -Dflume.root.logger=INFO,CONSOLE ``` 上述命令中各参数的作用说明如下: - `--name a1`: 指定 Flume 中的代理名为 `a1`。 - `--conf conf`: 指向 Flume 配置目录的位置。 - `--conf-file conf/dir-memory-hdfs.conf`: 指定使用的配置文件为 `dir-memory-hdfs.conf`。 - `-Dflume.log.file=flume-agent-a1.log`: 定义日志文件名以便于区分不同代理的日志记录。 - `-Dflume.root.logger=INFO,CONSOLE`: 将根日志器设置为 `INFO` 级别,并将日志输出到控制台。 #### 故障排查 如果在启动过程中遇到错误,可以根据以下提示进行排查: 1. 如果发现 HDFS 上的状态异常(如 Active 变成 Standby),需检查 NameNode 是否正常工作[^4]。 2. 若两个 NameNode 均处于 Standby 状态,则应确认 ZKFC 是否已成功启动。必要时可尝试重启 ZKFC 服务。 #### 示例代码片段 以下是完整的启动脚本示例: ```bash #!/bin/bash export FLUME_HOME=/path/to/apache-flume $FLUME_HOME/bin/flume-ng agent \ --name a1 \ --conf $FLUME_HOME/conf \ --conf-file $FLUME_HOME/conf/dir-memory-hdfs.conf \ -Dflume.log.file=flume-agent-a1.log \ -Dflume.root.logger=INFO,CONSOLE ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值