MyTtcp 測試網絡帶寬

網絡編程學習ios

注意的指標
MB/S 帶寬
每秒處理的信息 查詢等 messages/s queries/s transaction/s
延時
cpu使用率git


ttcp測試網絡 讀寫讀寫 循環 測試網絡帶寬編程

正確關閉TCP shutdown_write read->0 closesocket網絡

TCP_NODELAY 延時發送小數據包 認爲設置 不等待 即時發送 開啓socket

reuseaddr socket複用tcp

 

完整代碼見oop

https://git.oschina.net/def/cppPratice/tree/master/MyTtcpV0.1學習

 

#include "RecvMessageLoop.h"


#include <boost/asio.hpp>

#include <iostream>

#include <chrono>

#include "Common.h"



using boost::asio::ip::tcp;


void RecvMessageLoop(const std::string& ipStr,
	const std::string& portStr, const std::string& MessageBlockLen) {
	//std::cout << "RecvMessageLoop" << std::endl;

	boost::asio::io_service io_service;

	tcp::acceptor acceptor(io_service, tcp::endpoint(tcp::v4(), std::atoi(portStr.c_str())));

	tcp::socket socket(io_service);
	acceptor.accept(socket);

	//SetSocketNoDelay(socket,true);



	boost::system::error_code ec;
	long recvBlocklen = 0;

	size_t len = socket.read_some(boost::asio::buffer(&recvBlocklen,sizeof(recvBlocklen)), ec);
	if (len != sizeof(recvBlocklen) || ec) {
		PRINTERRORCODE(ec);
		return;
	}
	
	std::cout << "recvlen is: " << recvBlocklen << std::endl;

	int testLoopTimes = defaultSendLength / recvBlocklen;

	len = boost::asio::write(socket,boost::asio::buffer(&testLoopTimes, sizeof(testLoopTimes)), ec);
	if (len != sizeof(testLoopTimes) || ec) {
		PRINTERRORCODE(ec);
		return;
	}

	std::unique_ptr<char[]> testBuf(new char[recvBlocklen]);//ok
	for (int i = 0; i < recvBlocklen; ++i)
	{
		testBuf[i] = '\0';
	}

	auto start = std::chrono::steady_clock::now();

	while(1) {
		len = boost::asio::read(socket,
			boost::asio::buffer(testBuf.get(), recvBlocklen),ec);
		if (ec == boost::asio::error::eof) {
			break;
		}else if (len != recvBlocklen || ec) {
			PRINTERRORCODE(ec);
			return;
		}
		//std::cout << "read success" << std::endl;

		int i = len;

		len = boost::asio::write(socket, boost::asio::buffer(&i, sizeof(i)), ec);
		if (len != sizeof(i) || ec) {
			PRINTERRORCODE(ec);
			return;
		}
		//std::cout << "write success" << std::endl;

	}

	//socket.shutdown(boost::asio::socket_base::shutdown_send);

	//len = boost::asio::read(socket,

	//	boost::asio::buffer(&len, sizeof(len)), ec);

	//socket.close();

	auto end = std::chrono::steady_clock::now();

	std::chrono::duration<double> diff = end - start;
	std::cout << "=>Time Elapse " << diff.count() << " s" << std::endl;
	std::cout << "Total Length is  " << defaultSendLength / 1024 / 1024 << "MB" << std::endl;
	std::cout << "Speed is " << defaultSendLength / 1024 / 1024/ diff.count() << "MB" << std::endl;
}
相關文章
相關標籤/搜索