增加HTTP Post上传配置接口,支持主从双机备份与同步(冷备)
This commit is contained in:
80
include/doris_producer_client.h
Normal file
80
include/doris_producer_client.h
Normal file
@@ -0,0 +1,80 @@
|
||||
#ifndef __DORIS_PRODUCER_CLIENT_H__
|
||||
#define __DORIS_PRODUCER_CLIENT_H__
|
||||
|
||||
enum FSSTAT_DRS_PROD_FILED_ITEMS
|
||||
{
|
||||
DRS_FSPRD_FILED_VERSTART=0,
|
||||
DRS_FSPRD_FILED_VEREND,
|
||||
DRS_FSPRD_FILED_VERCANCEL,
|
||||
DRS_FSPRD_FILED_FILEFRAG,
|
||||
DRS_FSPRD_FILED_FILEONCE,
|
||||
|
||||
FSSTAT_DORIS_PRD_FILED_NUM,
|
||||
};
|
||||
|
||||
enum FSSTAT_DRS_PROD_STATUS_ITEMS
|
||||
{
|
||||
DRS_FSPRD_STAT_CNNED_SERVERS=0,
|
||||
DRS_FSPRD_STAT_FAILED_SERVERS,
|
||||
DRS_FSPRD_STAT_MEMORY_USED,
|
||||
DRS_FSPRD_STAT_HTTP_SESSIONS,
|
||||
DRS_FSPRD_STAT_REQ_SESSIONS,
|
||||
|
||||
FSSTAT_DORIS_PRD_STATUS_NUM,
|
||||
};
|
||||
|
||||
struct doris_prod_statistics
|
||||
{
|
||||
long long field[FSSTAT_DORIS_PRD_FILED_NUM];
|
||||
long long status[FSSTAT_DORIS_PRD_STATUS_NUM];
|
||||
};
|
||||
|
||||
struct doris_prod_param;
|
||||
struct doris_prod_instance;
|
||||
struct doris_upload_ctx;
|
||||
|
||||
struct doris_prod_param *doris_prod_parameter_new(const char *confile, struct event_base *manage_evbase, void *runtimelog);
|
||||
struct doris_prod_instance *doris_prod_instance_new(struct doris_prod_param *param, struct event_base *worker_evbase, void *runtimelog);
|
||||
|
||||
enum PROD_VERSTART_RES
|
||||
{
|
||||
VERSTART_RES_OK=0,
|
||||
VERSTART_RES_BUSY, //<2F><>Ӧ<EFBFBD><D3A6>300<30><30><EFBFBD><EFBFBD><EFBFBD><EFBFBD>server<65><72><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>start<72><74><EFBFBD><EFBFBD>;<EFBFBD>汾
|
||||
VERSTART_RES_ERROR, //ȡ<><C8A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ӧ<EFBFBD><D3A6><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ӧ<EFBFBD><D3A6>400<30><30>Ҫô<D2AA>Ƿ<EFBFBD><C7B7><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ҫô<D2AA><C3B4>δ<EFBFBD><CEB4><EFBFBD><EFBFBD>start<72>İ汾<C4B0><E6B1BE>
|
||||
VERSTART_CURL_ERROR, //curlԭ<6C><D4AD>δ<EFBFBD><CEB4><EFBFBD><EFBFBD>ȡ<EFBFBD><C8A1><EFBFBD><EFBFBD>Ӧ
|
||||
};
|
||||
|
||||
/*cfgtype: 1-ȫ<><C8AB><EFBFBD><EFBFBD>2-<2D><><EFBFBD><EFBFBD>*/
|
||||
struct doris_upload_ctx *doris_prod_upload_ctx_new(struct doris_prod_instance *instance,const char *business, int32_t cfgtype);
|
||||
void doris_prod_upload_ctx_destroy(struct doris_upload_ctx *ctx);
|
||||
|
||||
int32_t doris_prod_version_start(struct doris_upload_ctx *ctx);
|
||||
int32_t doris_prod_version_start_with_cb(struct doris_upload_ctx *ctx,
|
||||
void (*verstart_cb)(enum PROD_VERSTART_RES result, const char *body, void *userdata), void *userdata);
|
||||
|
||||
enum PROD_VEROP_RES
|
||||
{
|
||||
VERSIONOP_RES_OK=0,
|
||||
VERSIONOP_RES_ERROR,
|
||||
VERSIONOP_CURL_ERROR,
|
||||
};
|
||||
|
||||
struct table_meta
|
||||
{
|
||||
const char *tablename; //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽmaat<61><74><EFBFBD>䣻<EFBFBD><E4A3BB><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʽΪ<CABD>ļ<EFBFBD><C4BC><EFBFBD>
|
||||
const char *filename; //<2F><><EFBFBD><EFBFBD>ʱҪ<CAB1><D2AA><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD><C4BC><EFBFBD>
|
||||
const char *userregion;
|
||||
const char *md5;
|
||||
u_int32_t cfgnum;
|
||||
};
|
||||
|
||||
int32_t doris_prod_upload_once_with_cb(struct doris_upload_ctx *ctx, char *data, size_t size,
|
||||
struct table_meta *meta, void (*upfrag_cb)(enum PROD_VEROP_RES result, void *userdata), void *userdata);
|
||||
int32_t doris_prod_upload_frag_with_cb(struct doris_upload_ctx *ctx, char *data, size_t size, size_t offset,
|
||||
bool last, struct table_meta *meta, void (*upfrag_cb)(enum PROD_VEROP_RES result, void *userdata), void *userdata);
|
||||
|
||||
int32_t doris_prod_version_end(struct doris_upload_ctx *ctx, void (*verend_cb)(enum PROD_VEROP_RES result, int64_t version, void *userdata), void *userdata);
|
||||
int32_t doris_prod_version_cancel(struct doris_upload_ctx *ctx, void (*vercancel_cb)(enum PROD_VEROP_RES result, void *userdata), void *userdata);
|
||||
|
||||
#endif
|
||||
|
||||
Reference in New Issue
Block a user