博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Rserve与Java的跨平台通信
阅读量:2716 次
发布时间:2019-05-13

本文共 4258 字,大约阅读时间需要 14 分钟。

,涵盖了R的思想,使用,工具,创新等的一系列要点,以我个人的学习和体验去诠释R的强大。

R语言作为统计学一门语言,一直在小众领域闪耀着光芒。直到大数据的爆发,R语言变成了一门炙手可热的数据分析的利器。随着越来越多的工程背景的人的加入,R语言的社区在迅速扩大成长。现在已不仅仅是统计领域,教育,银行,电商,互联网….都在使用R语言。

要成为有理想的极客,我们不能停留在语法上,要掌握牢固的数学,概率,统计知识,同时还要有创新精神,把R语言发挥到各个领域。让我们一起动起来吧,开始R的极客理想。

关于作者:

  • 张丹(Conan), 程序员Java,R,PHP,Javascript
  • weibo:@Conan_Z
  • blog: http://blog.fens.me
  • email: bsspirit@gmail.com

转载请注明出处:

前言

现在主流的异构跨平台通信组件已经火遍大江南北,支持15种编程语言,但是到目前为止还没有加入R语言。要让R实现跨平台的通信,就只能从R的社区中找方案,像rJava,RCpp,rpy都是2种语言结合的方案,这些方案类似地会把R引擎加载到其他的语言内存环境。优点是高效,缺点是紧耦合,扩展受限,接口程序无法重用。

Rserve给了我们一种新的选择,抽象R语言网络接口,基于TCP/IP协议实现与多语言之间的通信。让我们体验一下Rserve与Java的跨平台通信。

目录

  1. Rserve介绍
  2. Rserve安装
  3. Java远程连接Rserve

1. Rserve介绍

Rserve是一个基于TCP/IP协议的,允许R语言与其他语言通信的C/S结构的程序,支持C/C++,Java,PHP,Python,Ruby,Nodejs等。 Rserve提供远程连接,认证,文件传输等功能。我们可以设计R做为后台服务,处理统计建模,数据分析,绘图等的任务。

2. Rserve安装

系统环境:

Linux Ubuntu 12.04.2 LTS 64bit server
R 3.0.1 64bit

~ uname -aLinux conan 3.5.0-23-generic #35~precise1-Ubuntu SMP Fri Jan 25 17:13:26 UTC 2013 x86_64 x86_64 x86_64 GNU/Linux~ cat /etc/issueUbuntu 12.04.2 LTS \n \l~ R --versionR version 3.0.1 (2013-05-16) -- "Good Sport"Copyright (C) 2013 The R Foundation for Statistical ComputingPlatform: x86_64-pc-linux-gnu (64-bit)R is free software and comes with ABSOLUTELY NO WARRANTY.You are welcome to redistribute it under the terms of theGNU General Public License versions 2 or 3.For more information about these matters seehttp://www.gnu.org/licenses/.

Rserve安装

#建议使用root权限安装~ sudo R> install.packages("Rserve")installing via 'install.libs.R' to /usr/local/lib/R/site-library/Rserve** R** inst** preparing package for lazy loading** help*** installing help indices** building package indices** testing if installed package can be loaded* DONE (Rserve)

启动Rserve

~ R CMD RserveR version 3.0.1 (2013-05-16) -- "Good Sport"Copyright (C) 2013 The R Foundation for Statistical ComputingPlatform: x86_64-pc-linux-gnu (64-bit)R is free software and comes with ABSOLUTELY NO WARRANTY.You are welcome to redistribute it under certain conditions.Type 'license()' or 'licence()' for distribution details.  Natural language support but running in an English localeR is a collaborative project with many contributors.Type 'contributors()' for more information and'citation()' on how to cite R or R packages in publications.Type 'demo()' for some demos, 'help()' for on-line help, or'help.start()' for an HTML browser interface to help.Type 'q()' to quit R.Rserv started in daemon mode.#查看进程~ ps -aux|grep Rserveconan     7142  0.0  1.2 116296 25240 ?        Ss   09:13   0:00 /usr/lib/R/bin/Rserve#查看端口~ netstat -nltp|grep Rservetcp        0      0 127.0.0.1:6311          0.0.0.0:*               LISTEN      7142/Rserve

这时Rserve已经启动,端口是6311。接下来,我们来简单地用一下。

Java远程连接Rserve

1). 远程连接Rserve

刚刚启动时,使用的本地模式,如果想运程连接需要增加参数 –RS-enable-remote

#杀掉刚才的Rserve守护进程~ kill -9 7142#打开远程模式重新启动~ R CMD Rserve --RS-enable-remote#查看端口~ netstat -nltp|grep Rservetcp        0      0 0.0.0.0:6311            0.0.0.0:*               LISTEN      7173/Rserve

0 0.0.0.0:6311,表示不限IP访问了。

2). 下载Java客户端JAR包

下载Java客户端JAR包:http://www.rforge.net/Rserve/files/

  • REngine.jar
  • RserveEngine.jar

3). 创建Java工程

在Eclipse中新建Java工程,并加载JAR包环境中。

4). Java编程实现

package org.conan.r.rserve;import org.rosuda.REngine.REXP;import org.rosuda.REngine.REXPMismatchException;import org.rosuda.REngine.Rserve.RConnection;import org.rosuda.REngine.Rserve.RserveException;public class Demo1 {    public static void main(String[] args) throws RserveException, REXPMismatchException {        Demo1 demo = new Demo1();        demo.callRserve();    }    public void callRserve() throws RserveException, REXPMismatchException {        RConnection c = new RConnection("192.168.1.201");        REXP x = c.eval("R.version.string");        System.out.println(x.asString());//打印变量x        double[] arr = c.eval("rnorm(10)").asDoubles();        for (double a : arr) {//循环打印变量arr            System.out.print(a + ",");        }    }}

5). 运行结果

R version 3.0.1 (2013-05-16)1.7695224124757984,-0.29753038160770323,0.26596993631142246,1.4027325257239547,-0.30663565983302676,-0.17594309812158912,0.10071253841443684,0.9365455161259986,0.11272119436439701,0.5766373030674361,

通过Rserve非常简单地实现了,Java和R的通信。

解决了通信的问题,我们就可以发挥想象,把R更广泛的用起来。

接下来,会讲到如何设计Java和R互相调用的软件架构。敬请关注….

转载请注明出处:

打赏作者

This entry was posted in ,

你可能感兴趣的文章
使用Swagger,ApiExplorer和NSwag掌握ASP.NET Core和ABP中的外部Web API
查看>>
使用Entity Developer构建ASP.NET Core Web API应用程序
查看>>
动态构建LINQ表达式
查看>>
使用ASP.NET Web API和Handlebars的Web模板
查看>>
PowerToys 0.19.0 发布,微软开发的免费实用工具集
查看>>
华为正式开源数据虚拟化引擎 openLooKeng
查看>>
机器学习的三种方法
查看>>
使用ASP.NET Web API和Handlebars的Web模板
查看>>
微服务中的面向切面编程和更多模式
查看>>
十多位全球技术专家,为你献上近十个小时的.Net微服务介绍
查看>>
用于打开和创建SQLite,Microsoft SQL Server,PostgreSQL和MySQL SQL数据库的WPF对话框
查看>>
在Visual Studio中使用C#脚本(CSX脚本)生成代码
查看>>
检查和变异可查询表达式树
查看>>
.NET Core 下使用 Exceptionless 记录日志
查看>>
Facebook 开源 M2M-100,不依赖英语互译百种语言
查看>>
使用UWP人脸检测API在WPF中进行人脸检测
查看>>
如何编写代码解决问题,初学者指南
查看>>
阿里云、蚂蚁开源 Nydus——容器镜像加速服务
查看>>
软件项目失败的心理原因
查看>>
设置Android AI开发环境
查看>>