开源 企业版 高校版 私有云 模力方舟 AI 队友
代码拉取完成,页面将自动刷新
开源项目 > WEB应用开发 > RPC开发框架 &&
捐赠
捐赠前请先登录
扫描微信二维码支付
取消
支付完成
支付提示
将跳转至支付宝完成支付
确定
取消
7 Star 4 Fork 7

cxxjava/Tars

加入 Gitee
与超过 1400万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
已有帐号? 立即登录
文件
master
分支 (1)
master
master
分支 (1)
master
克隆/下载
克隆/下载
提示
下载代码请复制以下命令到终端执行
为确保你提交的代码身份被 Gitee 正确识别,请执行以下命令完成配置
初次使用 SSH 协议进行代码克隆、推送等操作时,需按下述提示完成 SSH 配置
1 生成 RSA 密钥
2 获取 RSA 公钥内容,并配置到 SSH公钥
在 Gitee 上使用 SVN,请访问 使用指南
使用 HTTPS 协议时,命令行会出现如下账号密码验证步骤。基于安全考虑,Gitee 建议 配置并使用私人令牌 替代登录密码进行克隆、推送等操作
Username for 'https://gitee.com': userName
Password for 'https://userName@gitee.com': # 私人令牌
master
分支 (1)
master
Tars
/
cpp
/
framework
/
NodeServer
/
BatchPatchThread.cpp
Tars
/
cpp
/
framework
/
NodeServer
/
BatchPatchThread.cpp
BatchPatchThread.cpp 5.95 KB
一键复制 编辑 原始数据 按行查看 历史
suziliu 提交于 2017年01月18日 16:19 +08:00 . tars 1.0.1
/**
* Tencent is pleased to support the open source community by making Tars available.
*
* Copyright (C) 2016THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the BSD 3-Clause License (the "License"); you may not use this file except
* in compliance with the License. You may obtain a copy of the License at
*
* https://opensource.org/licenses/BSD-3-Clause
*
* 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.
*/
#include "util/tc_md5.h"
#include "BatchPatchThread.h"
#include "ServerFactory.h"
#include "CommandPatch.h"
#include "NodeRollLogger.h"
#include "util.h"
using namespace tars;
BatchPatch::BatchPatch()
{
}
BatchPatch::~BatchPatch()
{
terminate();
}
void BatchPatch::start(int iNum)
{
for (int i = 0; i < iNum; i++)
{
BatchPatchThread * t = new BatchPatchThread(this);
t->setPath(_downloadPath);
t->start();
_runners.push_back(t);
}
}
void BatchPatch::terminate()
{
for (size_t i = 0; i < _runners.size(); ++i)
{
if(_runners[i]->isAlive())
{
_runners[i]->terminate();
}
}
for (size_t i = 0; i < _runners.size(); ++i)
{
if(_runners[i]->isAlive())
{
_runners[i]->getThreadControl().join();
}
}
}
void BatchPatch::push_back(const tars::PatchRequest & request, ServerObjectPtr serverPtr)
{
{
TC_ThreadLock::Lock LockQueue(_queueMutex);
if (_patchIng.count(request.appname + request.servername) == 1)
{
std::string sException = "reduplicate patch request:" + request.version + "," + request.user;
NODE_LOG("patchPro")->debug() << FILE_FUN<< request.appname + "." + request.servername << "|" << sException << endl;
throw TC_Exception(sException);
}
if (!serverPtr)
{
NODE_LOG("patchPro")->error() << FILE_FUN<< "server null " <<endl;
throw TC_Exception("sever null");
}
_patchQueue.push_back(make_pair(request,serverPtr));
_patchIng.insert(request.appname + request.servername);
}
}
bool BatchPatch::pop_front(pair<tars::PatchRequest,ServerObjectPtr>& item)
{
TC_ThreadLock::Lock LockQueue(_queueMutex);
bool bRet=false;
bRet=_patchQueue.pop_front(item);
if(bRet)
{
_patchIng.erase(item.first.appname+item.first.servername);
}
return bRet;
}
void BatchPatch::timedWait(int millsecond)
{
TC_ThreadLock::Lock lock(_queueMutex);
_queueMutex.timedWait(millsecond);
}
BatchPatchThread::BatchPatchThread(BatchPatch * patch) : _batchPatch(patch)
{
_shutDown = false;
}
BatchPatchThread::~BatchPatchThread()
{
terminate();
}
void BatchPatchThread::terminate()
{
_shutDown = true;
if (isAlive())
{
getThreadControl().join();
}
}
void BatchPatchThread::doPatchRequest(const tars::PatchRequest & request, ServerObjectPtr server)
{
NODE_LOG("patchPro")->debug() << FILE_FUN
<< request.appname + "." + request.servername + "_" + request.nodename << "|"
<< request.groupname << "|"
<< request.version << "|"
<< request.user << "|"
<< request.servertype << "|"
<< request.patchobj << "|"
<< request.md5 << "|"
<< request.ostype << endl;
//设置发布状态
try
{
std::string sError;
if (!server)
{
NODE_LOG("patchPro")->error() <<FILE_FUN<< request.appname + "." + request.servername << "|" << request.md5 << "|get server object fault:" << sError << endl;
return ;
}
//查看本地硬盘是否已经存在该文件
NODE_LOG("patchPro")->debug() <<FILE_FUN<< request.appname + "." + request.servername << "|" << request.md5 << "|patch begin" << endl;
CommandPatch command(server, _downloadPath, request);
if (command.canExecute(sError) != ServerCommand::EXECUTABLE)
{
NODE_LOG("patchPro")->error() << FILE_FUN<< request.appname + "." + request.servername << "|" << request.md5 << "|canExecute error:" << sError << endl;
return ;
}
if (command.execute(sError) == 0)
{
NODE_LOG("patchPro")->debug() <<FILE_FUN<< request.appname + "." + request.servername << "|" << request.md5 << "|patch succ" << endl;
}
else
{
NODE_LOG("patchPro")->error() <<FILE_FUN<< request.appname + "." + request.servername << "|" << request.md5 << "|patch fault:" << sError << endl;
}
}
catch (exception & e)
{
NODE_LOG("patchPro")->error() << FILE_FUN<< request.appname + "." + request.servername << "|" << request.md5 << "|Exception:" << e.what() << endl;
}
catch (...)
{
NODE_LOG("patchPro")->error() <<FILE_FUN<< request.appname + "." + request.servername << "|" << request.md5 << "|Unknown Exception" << endl;
}
}
void BatchPatchThread::run()
{
while (!_shutDown)
{
try
{
pair<tars::PatchRequest,ServerObjectPtr> item;
if (_batchPatch->pop_front(item))
{
if (!(item.second))
{
NODE_LOG("patchPro")->error() <<FILE_FUN<< " server error" << endl;
throw TC_Exception("server error");
}
doPatchRequest(item.first,item.second);
}
else
{
_batchPatch->timedWait(2000);
}
}
catch (exception& e)
{
NODE_LOG("patchPro")->error()<<FILE_FUN<<"catch exception|"<<e.what()<<endl;
}
catch (...)
{
NODE_LOG("patchPro")->error()<<FILE_FUN<<"catch unkown exception"<<endl;
}
}
}
Loading...
举报
举报成功
我们将于2个工作日内通过站内信反馈结果给你!
请认真填写举报原因,尽可能描述详细。
请选择举报类型
取消
发送
误判申诉

此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。

如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。

取消
提交

简介

腾讯Tars(TAF)框架OSX平台移植版
取消

发行版

暂无发行版

开源评估指数源自 OSS-Compass 评估体系,评估体系围绕以下三个维度对项目展开评估:

1. 开源生态

  • 生产力:来评估开源项目输出软件制品和开源价值的能力。
  • 创新力:用于评估开源软件及其生态系统的多样化程度。
  • 稳健性:用于评估开源项目面对多变的发展环境,抵御内外干扰并自我恢复的能力。

2. 协作、人、软件

  • 协作:代表了开源开发行为中协作的程度和深度。
  • 人:观察开源项目核心人员在开源项目中的影响力,并通过第三方视角考察用户和开发者对开源项目的评价。
  • 软件:从开源项目对外输出的制品评估其价值最终落脚点。也是开源评估最"古老"的主流方向之一"开源软件" 的具体表现。

3. 评估模型

    基于"开源生态"与"协作、人、软件"的维度,找到与该目标直接或间接相关的可量化指标,对开源项目健康与生态进行量化评估,最终形成开源评估指数。

贡献者

全部

近期动态

不能加载更多了
编辑仓库简介
简介内容
主页
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
C++
1
https://gitee.com/cxxjava/Tars.git
git@gitee.com:cxxjava/Tars.git
cxxjava
Tars
Tars
master
点此查找更多帮助

搜索帮助

评论
仓库举报
回到顶部
登录提示
该操作需登录 Gitee 帐号,请先登录后再操作。
立即登录
没有帐号,去注册

AltStyle によって変換されたページ (->オリジナル) /