mirror of
https://github.com/wangyu-/UDPspeeder.git
synced 2025-01-19 06:19:34 +08:00
performance optimization for dup_max=0
This commit is contained in:
parent
a13358cdb3
commit
b1a47bb8ea
30
main.cpp
30
main.cpp
@ -198,9 +198,15 @@ struct conn_manager_t //TODO change map to unordered map
|
|||||||
}
|
}
|
||||||
int insert_fd(u32_t fd,u64_t u64)
|
int insert_fd(u32_t fd,u64_t u64)
|
||||||
{
|
{
|
||||||
|
int before=fd_last_active_time.bucket_count();
|
||||||
u64_to_fd[u64]=fd;
|
u64_to_fd[u64]=fd;
|
||||||
fd_to_u64[fd]=u64;
|
fd_to_u64[fd]=u64;
|
||||||
fd_last_active_time[fd]=get_current_time();
|
fd_last_active_time[fd]=get_current_time();
|
||||||
|
int after=fd_last_active_time.bucket_count();
|
||||||
|
if(after!=before)//rehash happens!
|
||||||
|
{
|
||||||
|
clear_it=fd_last_active_time.begin();
|
||||||
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
int erase_fd(u32_t fd)
|
int erase_fd(u32_t fd)
|
||||||
@ -422,7 +428,7 @@ int remove_seq(char * data,int &data_len)
|
|||||||
seq=ntoh64(seq);
|
seq=ntoh64(seq);
|
||||||
if(anti_replay.is_vaild(seq)==0)
|
if(anti_replay.is_vaild(seq)==0)
|
||||||
{
|
{
|
||||||
if(disable_replay_filter==1)
|
if(disable_replay_filter==1) // inefficient, to make packet_recv_count++ work for only non-dup packet
|
||||||
return 0;
|
return 0;
|
||||||
mylog(log_trace,"seq %llx dropped bc of replay-filter\n ",seq);
|
mylog(log_trace,"seq %llx dropped bc of replay-filter\n ",seq);
|
||||||
return -1;
|
return -1;
|
||||||
@ -773,9 +779,20 @@ int event_loop()
|
|||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
mylog(log_warn, "send returned %d ,errno:%s\n", ret,strerror(errno));
|
mylog(log_warn, "send returned %d ,errno:%s\n", ret,strerror(errno));
|
||||||
}
|
}
|
||||||
|
if(dup_delay_max!=0)
|
||||||
|
{
|
||||||
add_and_new(new_udp_fd, dup_num - 1,random_between(dup_delay_min,dup_delay_max), data, data_len,u64);
|
add_and_new(new_udp_fd, dup_num - 1,random_between(dup_delay_min,dup_delay_max), data, data_len,u64);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
{
|
||||||
|
for(int i=0;i<dup_num - 1;i++)
|
||||||
|
{
|
||||||
|
do_obscure(data, data_len, new_data, new_len);
|
||||||
|
ret = send_fd(new_udp_fd, new_data,new_len, 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
add_and_new(new_udp_fd, dup_num,random_between(jitter_min,jitter_max), data, data_len,u64);
|
add_and_new(new_udp_fd, dup_num,random_between(jitter_min,jitter_max), data, data_len,u64);
|
||||||
}
|
}
|
||||||
@ -889,7 +906,18 @@ int event_loop()
|
|||||||
do_obscure(data, data_len, new_data, new_len);
|
do_obscure(data, data_len, new_data, new_len);
|
||||||
ret = sendto_u64(local_listen_fd, new_data,
|
ret = sendto_u64(local_listen_fd, new_data,
|
||||||
new_len , 0,u64);
|
new_len , 0,u64);
|
||||||
|
if(dup_delay_max!=0)
|
||||||
|
{
|
||||||
add_and_new(udp_fd, dup_num - 1,random_between(dup_delay_min,dup_delay_max), data, data_len,u64);
|
add_and_new(udp_fd, dup_num - 1,random_between(dup_delay_min,dup_delay_max), data, data_len,u64);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
for(int i=0;i<dup_num-1;i++)
|
||||||
|
{
|
||||||
|
do_obscure(data, data_len, new_data, new_len);
|
||||||
|
ret = sendto_u64(local_listen_fd, new_data,new_len , 0,u64);
|
||||||
|
}
|
||||||
|
}
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
mylog(log_warn, "sento returned %d,%s\n", ret,strerror(errno));
|
mylog(log_warn, "sento returned %d,%s\n", ret,strerror(errno));
|
||||||
//perror("ret<0");
|
//perror("ret<0");
|
||||||
|
Loading…
x
Reference in New Issue
Block a user