mirror of
https://gitee.com/Zhaoxin59/my-chat_-server.git
synced 2026-02-14 01:21:50 +08:00
update
This commit is contained in:
34
message/test/es_test/main.cc
Normal file
34
message/test/es_test/main.cc
Normal file
@ -0,0 +1,34 @@
|
||||
#include "../../../common/data_es.hpp"
|
||||
#include <gflags/gflags.h>
|
||||
|
||||
DEFINE_bool(run_mode, false, "程序的运行模式,false-调试; true-发布;");
|
||||
DEFINE_string(log_file, "", "发布模式下,用于指定日志的输出文件");
|
||||
DEFINE_int32(log_level, 0, "发布模式下,用于指定日志输出等级");
|
||||
|
||||
|
||||
DEFINE_string(es_host, "http://127.0.0.1:9200/", "es服务器URL");
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
{
|
||||
google::ParseCommandLineFlags(&argc, &argv, true);
|
||||
bite_im::init_logger(FLAGS_run_mode, FLAGS_log_file, FLAGS_log_level);
|
||||
|
||||
auto es_client = bite_im::ESClientFactory::create({FLAGS_es_host});
|
||||
|
||||
auto es_msg = std::make_shared<bite_im::ESMessage>(es_client);
|
||||
// es_msg->createIndex();
|
||||
// es_msg->appendData("用户ID1", "消息ID1", 1723025035, "会话ID1", "吃饭了吗?");
|
||||
// es_msg->appendData("用户ID2", "消息ID2", 1723025035 - 100, "会话ID1", "吃的盖浇饭!");
|
||||
// es_msg->appendData("用户ID3", "消息ID3", 1723025035, "会话ID2", "吃饭了吗?");
|
||||
// es_msg->appendData("用户ID4", "消息ID4", 1723025035 - 100, "会话ID2", "吃的盖浇饭!");
|
||||
auto res = es_msg->search("盖浇", "会话ID1");
|
||||
for (auto &u : res) {
|
||||
std::cout << "-----------------" << std::endl;
|
||||
std::cout << u.user_id() << std::endl;
|
||||
std::cout << u.message_id() << std::endl;
|
||||
std::cout << u.session_id() << std::endl;
|
||||
std::cout << boost::posix_time::to_simple_string(u.create_time()) << std::endl;
|
||||
std::cout << u.content() << std::endl;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
72
message/test/es_test/请求格式规范.txt
Normal file
72
message/test/es_test/请求格式规范.txt
Normal file
@ -0,0 +1,72 @@
|
||||
POST /message/_doc
|
||||
{
|
||||
"settings" : {
|
||||
"analysis" : {
|
||||
"analyzer" : {
|
||||
"ik" : {
|
||||
"tokenizer" : "ik_max_word"
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
"mappings" : {
|
||||
"dynamic" : true,
|
||||
"properties" : {
|
||||
"chat_session_id" : {
|
||||
"type" : "keyword",
|
||||
"analyzer" : "standard"
|
||||
},
|
||||
"message_id" : {
|
||||
"type" : "keyword",
|
||||
"analyzer" : "standard"
|
||||
},
|
||||
"content" : {
|
||||
"type" : "text",
|
||||
"analyzer" : "ik_max_word"
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
GET /message/_doc/_search?pretty
|
||||
{
|
||||
"query": {
|
||||
"match_all": {}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
POST /message/_doc/_bulk
|
||||
{"index":{"_id":"1"}}
|
||||
{"chat_session_id" : "会话ID1","message_id" : "消息ID1","content" : "吃饭了么?"}
|
||||
{"index":{"_id":"2"}}
|
||||
{"chat_session_id" : "会话ID1","message_id" : "消息ID2","content" : "吃的盖浇饭。"}
|
||||
{"index":{"_id":"3"}}
|
||||
{"chat_session_id" : "会话ID2","message_id" : "消息ID3","content" : "昨天吃饭了么?"}
|
||||
{"index":{"_id":"4"}}
|
||||
{"chat_session_id" : "会话ID2","message_id" : "消息ID4","content" : "昨天吃的盖浇饭。"}
|
||||
|
||||
|
||||
GET /message/_doc/_search?pretty
|
||||
{
|
||||
"query": {
|
||||
"bool": {
|
||||
"must": [
|
||||
{
|
||||
"term": {
|
||||
"chat_session_id.keyword": "会话ID1"
|
||||
}
|
||||
},
|
||||
{
|
||||
"match": {
|
||||
"content": "盖浇饭"
|
||||
}
|
||||
}
|
||||
]
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
DELETE /message
|
||||
170
message/test/message_client.cc
Normal file
170
message/test/message_client.cc
Normal file
@ -0,0 +1,170 @@
|
||||
#include "etcd.hpp"
|
||||
#include "channel.hpp"
|
||||
#include "utils.hpp"
|
||||
#include <gflags/gflags.h>
|
||||
#include <gtest/gtest.h>
|
||||
#include <thread>
|
||||
#include <boost/date_time/posix_time/posix_time.hpp>
|
||||
#include "message.pb.h"
|
||||
#include "base.pb.h"
|
||||
#include "user.pb.h"
|
||||
|
||||
|
||||
DEFINE_bool(run_mode, false, "程序的运行模式,false-调试; true-发布;");
|
||||
DEFINE_string(log_file, "", "发布模式下,用于指定日志的输出文件");
|
||||
DEFINE_int32(log_level, 0, "发布模式下,用于指定日志输出等级");
|
||||
|
||||
DEFINE_string(etcd_host, "http://127.0.0.1:2379", "服务注册中心地址");
|
||||
DEFINE_string(base_service, "/service", "服务监控根目录");
|
||||
DEFINE_string(message_service, "/service/message_service", "服务监控根目录");
|
||||
|
||||
bite_im::ServiceManager::ptr sm;
|
||||
|
||||
void range_test(const std::string &ssid,
|
||||
const boost::posix_time::ptime &stime,
|
||||
const boost::posix_time::ptime &etime) {
|
||||
auto channel = sm->choose(FLAGS_message_service);
|
||||
if (!channel) {
|
||||
std::cout << "获取通信信道失败!" << std::endl;
|
||||
return;
|
||||
}
|
||||
bite_im::MsgStorageService_Stub stub(channel.get());
|
||||
bite_im::GetHistoryMsgReq req;
|
||||
bite_im::GetHistoryMsgRsp rsp;
|
||||
req.set_request_id(bite_im::uuid());
|
||||
req.set_chat_session_id(ssid);
|
||||
req.set_start_time(boost::posix_time::to_time_t(stime));
|
||||
req.set_over_time(boost::posix_time::to_time_t(etime));
|
||||
brpc::Controller cntl;
|
||||
stub.GetHistoryMsg(&cntl, &req, &rsp, nullptr);
|
||||
ASSERT_FALSE(cntl.Failed());
|
||||
ASSERT_TRUE(rsp.success());
|
||||
|
||||
std::cout << rsp.msg_list_size() << std::endl;
|
||||
|
||||
for (int i = 0; i < rsp.msg_list_size(); i++) {
|
||||
std::cout << "-----------------------获取时间区间消息--------------------------\n";
|
||||
auto msg = rsp.msg_list(i);
|
||||
std::cout << msg.message_id() << std::endl;
|
||||
std::cout << msg.chat_session_id() << std::endl;
|
||||
std::cout << boost::posix_time::to_simple_string(boost::posix_time::from_time_t(msg.timestamp())) << std::endl;
|
||||
std::cout << msg.sender().user_id() << std::endl;
|
||||
std::cout << msg.sender().nickname() << std::endl;
|
||||
std::cout << msg.sender().avatar() << std::endl;
|
||||
if (msg.message().message_type() == bite_im::MessageType::STRING) {
|
||||
std::cout << "文本消息:" << msg.message().string_message().content() << std::endl;
|
||||
}else if (msg.message().message_type() == bite_im::MessageType::IMAGE) {
|
||||
std::cout << "图片消息:" << msg.message().image_message().image_content() << std::endl;
|
||||
}else if (msg.message().message_type() == bite_im::MessageType::FILE) {
|
||||
std::cout << "文件消息:" << msg.message().file_message().file_contents() << std::endl;
|
||||
std::cout << "文件名称:" << msg.message().file_message().file_name() << std::endl;
|
||||
}else if (msg.message().message_type() == bite_im::MessageType::SPEECH) {
|
||||
std::cout << "语音消息:" << msg.message().speech_message().file_contents() << std::endl;
|
||||
}else {
|
||||
std::cout << "类型错误!!\n";
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void recent_test(const std::string &ssid, int count) {
|
||||
auto channel = sm->choose(FLAGS_message_service);
|
||||
if (!channel) {
|
||||
std::cout << "获取通信信道失败!" << std::endl;
|
||||
return;
|
||||
}
|
||||
bite_im::MsgStorageService_Stub stub(channel.get());
|
||||
bite_im::GetRecentMsgReq req;
|
||||
bite_im::GetRecentMsgRsp rsp;
|
||||
req.set_request_id(bite_im::uuid());
|
||||
req.set_chat_session_id(ssid);
|
||||
req.set_msg_count(count);
|
||||
brpc::Controller cntl;
|
||||
stub.GetRecentMsg(&cntl, &req, &rsp, nullptr);
|
||||
ASSERT_FALSE(cntl.Failed());
|
||||
ASSERT_TRUE(rsp.success());
|
||||
for (int i = 0; i < rsp.msg_list_size(); i++) {
|
||||
std::cout << "----------------------获取最近消息---------------------------\n";
|
||||
auto msg = rsp.msg_list(i);
|
||||
std::cout << msg.message_id() << std::endl;
|
||||
std::cout << msg.chat_session_id() << std::endl;
|
||||
std::cout << boost::posix_time::to_simple_string(boost::posix_time::from_time_t(msg.timestamp())) << std::endl;
|
||||
std::cout << msg.sender().user_id() << std::endl;
|
||||
std::cout << msg.sender().nickname() << std::endl;
|
||||
std::cout << msg.sender().avatar() << std::endl;
|
||||
if (msg.message().message_type() == bite_im::MessageType::STRING) {
|
||||
std::cout << "文本消息:" << msg.message().string_message().content() << std::endl;
|
||||
}else if (msg.message().message_type() == bite_im::MessageType::IMAGE) {
|
||||
std::cout << "图片消息:" << msg.message().image_message().image_content() << std::endl;
|
||||
}else if (msg.message().message_type() == bite_im::MessageType::FILE) {
|
||||
std::cout << "文件消息:" << msg.message().file_message().file_contents() << std::endl;
|
||||
std::cout << "文件名称:" << msg.message().file_message().file_name() << std::endl;
|
||||
}else if (msg.message().message_type() == bite_im::MessageType::SPEECH) {
|
||||
std::cout << "语音消息:" << msg.message().speech_message().file_contents() << std::endl;
|
||||
}else {
|
||||
std::cout << "类型错误!!\n";
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
void search_test(const std::string &ssid, const std::string &key) {
|
||||
auto channel = sm->choose(FLAGS_message_service);
|
||||
if (!channel) {
|
||||
std::cout << "获取通信信道失败!" << std::endl;
|
||||
return;
|
||||
}
|
||||
bite_im::MsgStorageService_Stub stub(channel.get());
|
||||
bite_im::MsgSearchReq req;
|
||||
bite_im::MsgSearchRsp rsp;
|
||||
req.set_request_id(bite_im::uuid());
|
||||
req.set_chat_session_id(ssid);
|
||||
req.set_search_key(key);
|
||||
brpc::Controller cntl;
|
||||
stub.MsgSearch(&cntl, &req, &rsp, nullptr);
|
||||
ASSERT_FALSE(cntl.Failed());
|
||||
ASSERT_TRUE(rsp.success());
|
||||
for (int i = 0; i < rsp.msg_list_size(); i++) {
|
||||
std::cout << "----------------------关键字搜索消息---------------------------\n";
|
||||
auto msg = rsp.msg_list(i);
|
||||
std::cout << msg.message_id() << std::endl;
|
||||
std::cout << msg.chat_session_id() << std::endl;
|
||||
std::cout << boost::posix_time::to_simple_string(boost::posix_time::from_time_t(msg.timestamp())) << std::endl;
|
||||
std::cout << msg.sender().user_id() << std::endl;
|
||||
std::cout << msg.sender().nickname() << std::endl;
|
||||
std::cout << msg.sender().avatar() << std::endl;
|
||||
if (msg.message().message_type() == bite_im::MessageType::STRING) {
|
||||
std::cout << "文本消息:" << msg.message().string_message().content() << std::endl;
|
||||
}else if (msg.message().message_type() == bite_im::MessageType::IMAGE) {
|
||||
std::cout << "图片消息:" << msg.message().image_message().image_content() << std::endl;
|
||||
}else if (msg.message().message_type() == bite_im::MessageType::FILE) {
|
||||
std::cout << "文件消息:" << msg.message().file_message().file_contents() << std::endl;
|
||||
std::cout << "文件名称:" << msg.message().file_message().file_name() << std::endl;
|
||||
}else if (msg.message().message_type() == bite_im::MessageType::SPEECH) {
|
||||
std::cout << "语音消息:" << msg.message().speech_message().file_contents() << std::endl;
|
||||
}else {
|
||||
std::cout << "类型错误!!\n";
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
{
|
||||
google::ParseCommandLineFlags(&argc, &argv, true);
|
||||
bite_im::init_logger(FLAGS_run_mode, FLAGS_log_file, FLAGS_log_level);
|
||||
|
||||
|
||||
//1. 先构造Rpc信道管理对象
|
||||
sm = std::make_shared<bite_im::ServiceManager>();
|
||||
sm->declared(FLAGS_message_service);
|
||||
auto put_cb = std::bind(&bite_im::ServiceManager::onServiceOnline, sm.get(), std::placeholders::_1, std::placeholders::_2);
|
||||
auto del_cb = std::bind(&bite_im::ServiceManager::onServiceOffline, sm.get(), std::placeholders::_1, std::placeholders::_2);
|
||||
//2. 构造服务发现对象
|
||||
bite_im::Discovery::ptr dclient = std::make_shared<bite_im::Discovery>(FLAGS_etcd_host, FLAGS_base_service, put_cb, del_cb);
|
||||
|
||||
boost::posix_time::ptime stime(boost::posix_time::time_from_string("2000-08-02 00:00:00"));
|
||||
boost::posix_time::ptime etime(boost::posix_time::time_from_string("2050-08-09 00:00:00"));
|
||||
range_test("会话ID1", stime, etime);
|
||||
recent_test("会话ID1", 2);
|
||||
search_test("会话ID1", "盖浇");
|
||||
return 0;
|
||||
}
|
||||
63
message/test/mysql_test/main.cc
Normal file
63
message/test/mysql_test/main.cc
Normal file
@ -0,0 +1,63 @@
|
||||
#include "mysql_message.hpp"
|
||||
#include <gflags/gflags.h>
|
||||
|
||||
|
||||
DEFINE_bool(run_mode, false, "程序的运行模式,false-调试; true-发布;");
|
||||
DEFINE_string(log_file, "", "发布模式下,用于指定日志的输出文件");
|
||||
DEFINE_int32(log_level, 0, "发布模式下,用于指定日志输出等级");
|
||||
|
||||
void insert_test(bite_im::MessageTable &tb) {
|
||||
bite_im::Message m1("消息ID1", "会话ID1", "用户ID1", 0, boost::posix_time::time_from_string("2002-01-20 23:59:59.000"));
|
||||
tb.insert(m1);
|
||||
bite_im::Message m2("消息ID2", "会话ID1", "用户ID2", 0, boost::posix_time::time_from_string("2002-01-21 23:59:59.000"));
|
||||
tb.insert(m2);
|
||||
bite_im::Message m3("消息ID3", "会话ID1", "用户ID3", 0, boost::posix_time::time_from_string("2002-01-22 23:59:59.000"));
|
||||
tb.insert(m3);
|
||||
|
||||
//另一个会话
|
||||
bite_im::Message m4("消息ID4", "会话ID2", "用户ID4", 0, boost::posix_time::time_from_string("2002-01-20 23:59:59.000"));
|
||||
tb.insert(m4);
|
||||
bite_im::Message m5("消息ID5", "会话ID2", "用户ID5", 0, boost::posix_time::time_from_string("2002-01-21 23:59:59.000"));
|
||||
tb.insert(m5);
|
||||
}
|
||||
void remove_test(bite_im::MessageTable &tb) {
|
||||
tb.remove("会话ID2");
|
||||
}
|
||||
|
||||
void recent_test(bite_im::MessageTable &tb) {
|
||||
auto res = tb.recent("会话ID1", 2);
|
||||
auto begin = res.rbegin();
|
||||
auto end = res.rend();
|
||||
for (; begin != end; ++begin) {
|
||||
std::cout << begin->message_id() << std::endl;
|
||||
std::cout << begin->session_id() << std::endl;
|
||||
std::cout << begin->user_id() << std::endl;
|
||||
std::cout << boost::posix_time::to_simple_string(begin->create_time()) << std::endl;
|
||||
}
|
||||
}
|
||||
|
||||
void range_test(bite_im::MessageTable &tb) {
|
||||
boost::posix_time::ptime stime(boost::posix_time::time_from_string("2002-01-20 23:59:59.000"));
|
||||
boost::posix_time::ptime etime(boost::posix_time::time_from_string("2002-01-21 23:59:59.000"));
|
||||
auto res = tb.range("会话ID1", stime, etime);
|
||||
for (const auto &m : res) {
|
||||
std::cout << m.message_id() << std::endl;
|
||||
std::cout << m.session_id() << std::endl;
|
||||
std::cout << m.user_id() << std::endl;
|
||||
std::cout << boost::posix_time::to_simple_string(m.create_time()) << std::endl;
|
||||
}
|
||||
}
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
{
|
||||
google::ParseCommandLineFlags(&argc, &argv, true);
|
||||
bite_im::init_logger(FLAGS_run_mode, FLAGS_log_file, FLAGS_log_level);
|
||||
|
||||
auto db = bite_im::ODBFactory::create("root", "123456", "127.0.0.1", "bite_im", "utf8", 0, 1);
|
||||
bite_im::MessageTable tb(db);
|
||||
// insert_test(tb);
|
||||
// remove_test(tb);
|
||||
// recent_test(tb);
|
||||
// range_test(tb);
|
||||
return 0;
|
||||
}
|
||||
Reference in New Issue
Block a user