[root@localhost tars]# /usr/local/tars/cpp/script/cmake_tars_server.sh TestApp HelloServer Hello
APP:TestApp, SERVER:HelloServer, SERVANT:Hello
[mkdir: HelloServer]
[create server: TestApp.HelloServer ...]
-- The C compiler identification is GNU 9.3.1
-- The CXX compiler identification is GNU 9.3.1
-- Check for working C compiler: /opt/rh/devtoolset-9/root/usr/bin/cc
-- Check for working C compiler: /opt/rh/devtoolset-9/root/usr/bin/cc - works
-- Detecting C compiler ABI info
-- Detecting C compiler ABI info - done
-- Detecting C compile features
-- Detecting C compile features - done
-- Check for working CXX compiler: /opt/rh/devtoolset-9/root/usr/bin/c++
-- Check for working CXX compiler: /opt/rh/devtoolset-9/root/usr/bin/c++ - works
-- Detecting CXX compiler ABI info
-- Detecting CXX compiler ABI info - done
-- Detecting CXX compile features
-- Detecting CXX compile features - done
-------------------------------------------------------------------------------------
CMAKE_SOURCE_DIR: /usr/local/app/tars/HelloServer
CMAKE_BINARY_DIR: /usr/local/app/tars/HelloServer/build
PROJECT_SOURCE_DIR: /usr/local/app/tars/HelloServer
CMAKE_BUILD_TYPE: Release
PLATFORM: linux
TARS2CPP: /usr/local/tars/cpp/tools/tars2cpp
TARSMERGE: /usr/local/tars/cpp/tools/tarsmerge
TARS_MYSQL: ON
TARS_HTTP2: OFF
TARS_SSL: OFF
TARS_WEB_HOST: http://web.tars.com
TARS_TOKEN:
-------------------------------------------------------------------------------------
-- Configuring done
-- Generating done
-- Build files have been written to: /usr/local/app/tars/HelloServer/build
Scanning dependencies of target tars-HelloServer
[ 25%] /usr/local/tars/cpp/tools/tars2cpp /usr/local/app/tars/HelloServer/src/Hello.tars
[ 25%] Built target tars-HelloServer
Scanning dependencies of target HelloServer
[ 50%] Building CXX object src/CMakeFiles/HelloServer.dir/HelloImp.cpp.o
[ 75%] Building CXX object src/CMakeFiles/HelloServer.dir/HelloServer.cpp.o
[100%] Linking CXX executable ../bin/HelloServer
[100%] Built target HelloServer
[done.]
These files already contain the basic service framework and the default test interface
implementation.We just need to fill in the code that reflects the logic of the program.
生成的这些文件已经包含了基础的服务框架和默认的测试接口实现,我们需要做的仅仅就是填充反应
程序逻辑的代码.
You can modify Hello.tars and add function with the below commands:
module TestApp
{
interface Hello
{
int test();
int testHello(string sReq, out string sRsp);
};
};
Use /usr/local/tars/cpp/tools/tars2cpp hello.tars to recreate hello.h.
Next,modify HelloImp.h/HelloImp.cpp to implement the new interface code.
In HelloImp.h, the testHello method of inheriting from the Hello class is:
virtual int testHello(const std::string &sReq, std::string &sRsp,
tars::TarsCurrentPtr current);
For HelloImp.cpp to implement testHello function:
int HelloImp::testHello(const std::string &sReq, std::string &sRsp,
tars::TarsCurrentPtr current)
{
TLOGDEBUG("HelloImp::testHellosReq:"<<sReq<<endl);
sRsp = sReq;
return 0;
}
The make clean all;make;make tar command can recreate the HelloServer.tgz package.
至此,服务器端的开发就完成了.
mkdir -p /home/tarsproto/TestApp/HelloServer
mkdir -p /home/tarsproto/TestApp/HelloClient
将HelloServer下的Hello.h和Hello.cpp文件放到/home/tarsproto/TestApp/HelloClient下.
Makefile
----------------------------------------------------------------------
APP :=TestApp
TARGET :=TestHelloClient
CONFIG :=
STRIP_FLAG := N
INCLUDE += -I/home/tarsproto/TestApp/HelloServer/
LIB +=
#-----------------------------------------------------------------------
include /usr/local/tars/cpp/makefile/makefile.tars
#-----------------------------------------------------------------------
#include <iostream>
#include "servant/Communicator.h"
#include "Hello.h"
using namespace std;
using namespace TestApp;
using namespace tars;
int main(int argc,char ** argv)
{
Communicator comm;
try
{
HelloPrx prx;
//comm.stringToProxy("TestApp.HelloServer.HelloObj@tcp -h 192.168.118.138 -p 15319" , prx);
// 注意 "应用+服务名+对象" 要对应到注册的那个服务上
comm.stringToProxy("tars.HelloServer.HelloObj@tcp -h 192.168.118.138 -p 15319" , prx);
try
{
string sReq("hello world");
string sRsp("");
int iRet = prx->testHello(sReq, sRsp);
cout<<"iRet:"<<iRet<<" sReq:"<<sReq<<" sRsp:"<<sRsp<<endl;
}
catch(exception &ex)
{
cerr << "line 23 , ex:" << ex.what() << endl;
}
catch(...)
{
cerr << "unknown exception." << endl;
}
}
catch(exception& e)
{
cerr << "exception:" << e.what() << endl;
}
catch (...)
{
cerr << "unknown exception." << endl;
}
return 0;
}
"应用"指你的服务程序归在哪一个应用下,例如:"TestApp"或者图中的"tars";
"服务名称"指你的服务程序的标识名字,例如:"HelloServer";
"服务类型"指你的服务程序用什么语言写的,例如:c++的选择“tars_cpp”。
"模版"指你的服务程序在启动时,设置的配置文件的名称,默认用"tars.default"即可,也可以用对应想要的;
"节点"指服务部署的机器IP;
"Set分组"指设置服务的Set分组信息,Set信息包括3部分:Set名,Set地区,Set组名;
"OBJ名称"指Servant的名称;
"OBJ绑定IP"指服务绑定的机器IP,一般与节点一样;
"端口"指OBJ要绑定的端口;
"端口类型"指使用TCP还是UDP;
"协议"指应用层使用的通信协议,Tars框架默认使用tars协议;
"线程数"指业务处理线程的数目;
"最大连接数"指支持的最大连接数;
"队列最大长度"指请求接收队列的大小;
"队列超时时间"指请求接收队列的超时时间.
然后在服务列表中点击启动即可,如果一切正常,就可以正常启动.
至此,一个简单的hello world完成了.
因篇幅问题不能全部显示,请点此查看更多更全内容