Skip to content
GitLab
Projects
Groups
Snippets
Help
Loading...
Help
What's new
10
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Open sidebar
p2p
go-p2p-kad-dht
Commits
f2df3ec5
Commit
f2df3ec5
authored
Jan 29, 2019
by
Raúl Kripalani
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
fix shutdown logic; fix timer logic.
parent
72f9d4c2
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
27 additions
and
18 deletions
+27
-18
dial_queue.go
dial_queue.go
+24
-15
query.go
query.go
+3
-3
No files found.
dial_queue.go
View file @
f2df3ec5
...
...
@@ -91,18 +91,23 @@ func (dq *dialQueue) control() {
waiting
<-
chan
waitingCh
lastScalingEvt
=
time
.
Now
()
)
for
{
// First process any backlog of dial jobs and waiters -- making progress is the priority.
// This block is copied below; couldn't find a more concise way of doing this.
select
{
case
<-
dq
.
ctx
.
Done
()
:
defer
func
()
{
// close channels.
if
resp
.
ch
!=
nil
{
close
(
resp
.
ch
)
}
for
w
:=
range
waiting
{
close
(
dq
.
waitingCh
)
for
w
:=
range
dq
.
waitingCh
{
close
(
w
.
ch
)
}
}()
for
{
// First process any backlog of dial jobs and waiters -- making progress is the priority.
// This block is copied below; couldn't find a more concise way of doing this.
select
{
case
<-
dq
.
ctx
.
Done
()
:
return
case
p
=
<-
dialled
:
dialled
,
waiting
=
nil
,
dq
.
waitingCh
...
...
@@ -113,6 +118,7 @@ func (dq *dialQueue) control() {
resp
.
ch
<-
p
close
(
resp
.
ch
)
dialled
,
waiting
=
dq
.
out
.
DeqChan
,
nil
// stop consuming waiting jobs until we've cleared a peer.
resp
.
ch
=
nil
continue
// onto the top.
default
:
// there's nothing to process, so proceed onto the main select block.
...
...
@@ -129,6 +135,7 @@ func (dq *dialQueue) control() {
resp
.
ch
<-
p
close
(
resp
.
ch
)
dialled
,
waiting
=
dq
.
out
.
DeqChan
,
nil
// stop consuming waiting jobs until we've cleared a peer.
resp
.
ch
=
nil
case
<-
dq
.
growCh
:
if
time
.
Now
()
.
Sub
(
lastScalingEvt
)
<
DialQueueScalingMutePeriod
{
continue
...
...
@@ -169,6 +176,10 @@ func (dq *dialQueue) Consume() <-chan peer.ID {
// park the channel until a dialled peer becomes available.
select
{
case
<-
dq
.
ctx
.
Done
()
:
// return a closed channel with no value if we're done.
close
(
ch
)
return
ch
case
dq
.
waitingCh
<-
waitingCh
{
ch
,
time
.
Now
()}
:
default
:
panic
(
"detected more consuming goroutines than declared upfront"
)
...
...
@@ -226,8 +237,7 @@ func (dq *dialQueue) shrink() {
func
(
dq
*
dialQueue
)
worker
()
{
// This idle timer tracks if the environment is slow. If we're waiting to long to acquire a peer to dial,
// it means that the DHT query is progressing slow and we should shrink the worker pool.
idleTimer
:=
time
.
NewTimer
(
0
)
idleTimer
:=
time
.
NewTimer
(
24
*
time
.
Hour
)
// placeholder init value which will be overridden immediately.
for
{
// trap exit signals first.
select
{
...
...
@@ -238,12 +248,11 @@ func (dq *dialQueue) worker() {
default
:
}
if
!
idleTimer
.
Stop
()
{
idleTimer
.
Stop
()
select
{
case
<-
idleTimer
.
C
:
default
:
}
}
idleTimer
.
Reset
(
DialQueueMaxIdle
)
select
{
...
...
query.go
View file @
f2df3ec5
...
...
@@ -206,9 +206,9 @@ func (r *dhtQueryRunner) spawnWorkers(proc process.Process) {
case
<-
r
.
rateLimit
:
ch
:=
r
.
peersDialed
.
Consume
()
select
{
case
p
,
_
:=
<-
ch
:
if
p
==
""
{
//
peer is nil;
this signals context cancellation.
case
p
,
ok
:=
<-
ch
:
if
!
ok
{
// this signals context cancellation.
return
}
// do it as a child func to make sure Run exits
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment