java通过thrift调用python远程执行shell
来源:互联网 发布:k近邻算法流程图 编辑:程序博客网 时间:2024/05/02 05:03
1、首先是在centos安装thrift
2、thrift不懂得可以参考http://blog.csdn.net/weiliu0626/article/details/8237983这篇文章
3、首先编写middle.thrift文件
namespace java com.vrv.bigdata.deploy
struct ReturnMessage {
1: list<string> shellLog,
2: string flag,
3: map<string,string> configxml
}
struct FtpServer {
1: string ip,
2: string port,
3: string username,
4: string password
}
service LongDeploy {
ReturnMessage executeInstall(1:FtpServer ftpserver, 2:string installversion, 3:string filename, 4:string configxml)
ReturnMessage executeUpdate(1:FtpServer ftpserver, 2:string installversion, 3:string filename, 4:string configxml)
ReturnMessage executeStart()
ReturnMessage executeStop()
ReturnMessage executeStatus()
ReturnMessage executeUnistall()
ReturnMessage updateShell(1:FtpServer ftpserver, 2:string installversion, 3:string filename)
}
4、然后
thrift -r --gen py tutorial.thrift
thrift -r --gen java tutorial.thrift
生成
drwxrwxr-x 4 hadoop hadoop 4096 Oct 9 15:42 gen-java
drwxrwxr-x 4 hadoop hadoop 4096 Oct 9 19:21 gen-py
这两个文件把java放入java系统中,修改python服务器
所需东西传到百度云盘中了
5、分别修改python服务端和java客户端,就可以了
--------------------------------------------------------------------------------------
thrift带返回对象例子
1、首先还是得有一个thrift文件接口
这是 tutorial.thrift
/* * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. */# Thrift Tutorial# Mark Slee (mcslee@facebook.com)## This file aims to teach you how to use Thrift, in a .thrift file. Neato. The# first thing to notice is that .thrift files support standard shell comments.# This lets you make your thrift file executable and include your Thrift build# step on the top line. And you can place comments like this anywhere you like.## Before running this file, you will need to have installed the thrift compiler# into /usr/local/bin./** * The first thing to know about are types. The available types in Thrift are: * * bool Boolean, one byte * byte Signed byte * i16 Signed 16-bit integer * i32 Signed 32-bit integer * i64 Signed 64-bit integer * double 64-bit floating point value * string String * binary Blob (byte array) * map<t1,t2> Map from one type to another * list<t1> Ordered list of one type * set<t1> Set of unique elements of one type * * Did you also notice that Thrift supports C style comments? */// Just in case you were wondering... yes. We support simple C comments too./** * Thrift files can reference other Thrift files to include common struct * and service definitions. These are found using the current path, or by * searching relative to any paths specified with the -I compiler flag. * * Included objects are accessed using the name of the .thrift file as a * prefix. i.e. shared.SharedObject */include "shared.thrift"/** * Thrift files can namespace, package, or prefix their output in various * target languages. */namespace cpp tutorialnamespace d tutorialnamespace dart tutorialnamespace java tutorialnamespace php tutorialnamespace perl tutorialnamespace haxe tutorial/** * Thrift lets you do typedefs to get pretty names for your types. Standard * C style here. */typedef i32 MyInteger/** * Thrift also lets you define constants for use across languages. Complex * types and structs are specified using JSON notation. */const i32 INT32CONSTANT = 9853const map<string,string> MAPCONSTANT = {'hello':'world', 'goodnight':'moon'}/** * You can define enums, which are just 32 bit integers. Values are optional * and start at 1 if not supplied, C style again. */enum Operation { ADD = 1, SUBTRACT = 2, MULTIPLY = 3, DIVIDE = 4}/** * Structs are the basic complex data structures. They are comprised of fields * which each have an integer identifier, a type, a symbolic name, and an * optional default value. * * Fields can be declared "optional", which ensures they will not be included * in the serialized output if they aren't set. Note that this requires some * manual management in some languages. */struct Work { 1: i32 num1 = 0, 2: i32 num2, 3: Operation op, 4: optional string comment,}/** * Structs can also be exceptions, if they are nasty. */exception InvalidOperation { 1: i32 whatOp, 2: string why}/** * Ahh, now onto the cool part, defining a service. Services just need a name * and can optionally inherit from another service using the extends keyword. */service Calculator extends shared.SharedService { /** * A method definition looks like C code. It has a return type, arguments, * and optionally a list of exceptions that it may throw. Note that argument * lists and exception lists are specified using the exact same syntax as * field lists in struct or exception definitions. */ void ping(), i32 add(1:i32 num1, 2:i32 num2), i32 calculate(1:i32 logid, 2:Work w) throws (1:InvalidOperation ouch), /** * This method has a oneway modifier. That means the client only makes * a request and does not listen for any response at all. Oneway methods * must be void. */ oneway void zip()}/** * That just about covers the basics. Take a look in the test/ folder for more * detailed examples. After you run this file, your generated code shows up * in folders with names gen-<language>. The generated code isn't too scary * to look at. It even has pretty indentation. */
这是shared.thrift
/* * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. *//** * This Thrift file can be included by other Thrift files that want to share * these definitions. */namespace cpp sharednamespace d share // "shared" would collide with the eponymous D keyword.namespace dart sharednamespace java sharednamespace perl sharednamespace php sharednamespace haxe sharedstruct SharedStruct { 1: i32 key 2: string value}service SharedService { SharedStruct getStruct(1: i32 key)}
2、执行
thrift -r --gen py tutorial.thrift
thrift -r --gen java tutorial.thrift
形成drwxrwxr-x 4 hadoop hadoop 4096 Oct 9 15:42 gen-java
drwxrwxr-x 4 hadoop hadoop 4096 Oct 9 19:21 gen-py
文档
3、修改服务端和客户端
具体代码在百度云盘李新凯thriftstruct中
- java通过thrift调用python远程执行shell
- Java通过SSH2协议执行远程Shell脚本
- Java通过SSH2协议执行远程Shell脚本
- Java通过SSH2协议执行远程Shell脚本
- Linux 通过shell远程调用
- thrift远程调用示例
- thrift远程调用示例
- netty学习九:(window7上)python客户端通过thrift调用java服务端
- python通过thrift连接hive,异步执行查询
- 通过java执行shell脚本
- java本地调用cmd,shell命令,远程调用Linux执行命令方法总结
- java本地调用cmd,shell命令,远程调用Linux执行命令方法总结
- Java调用远程Shell脚本
- Java调用远程Shell脚本
- java 远程调用shell脚本
- java远程调用shell脚本
- java远程调用shell脚本
- Python ssh 远程执行shell命令
- 151016的测试总结
- 写入数据后程序查询没结果
- SecureCrt自动生成log 设置图解
- MySQL数据库写入图片并读取图片显示到JLabel上的详解
- HUD1203——I NEED A OFFER!(背包问题,最小值的动态规划)
- java通过thrift调用python远程执行shell
- 九度OJ 1013:开门人和关门人 (排序)
- Leetcode || Add Two Numbers
- linux命令-rmdir
- 厦门大学线下编程比赛第一题:求和
- Beaglebone Black 断网后重新连接问题
- php判断日期时间
- DayDayUP_Linux运维学习_MySQL 主从配置
- 如何提高支付宝芝麻信用的分数