-
-
Notifications
You must be signed in to change notification settings - Fork 3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
IPNS names do not resolve when published with different key than self
#6360
Comments
@marcinczenko it looks like you're having DHT issues. Here's a couple things I've run on my machine with 0.4.20 that seem to work.
If it can't resolve the name initially it's almost always happened for me that running the resolve a second time results in the name resolving. Btw I think the main difference between "self" and other keys is that during the DHT search for "self" the peer is the best possible source of truth for the data. This is because the DHT works by trying to find the peer with ID closest to "key" and in this case key = self. @Stebalien does it look like I'm missing anything here? I'm currently doing some work on IPNS improvements that should help with this by allowing an option that is a less reliant on the DHT, and any help is always appreciated. Give me 1-2 days to figure out what kind of chunks I can carve out and I'll post back. |
@aschmahmann Thanks for checking it. When you say I will perform more cross-checks between different nodes - for now I was focused on two of them. So far though, my content seems to resolve well although today I saw something strange: when I do Aside from the above - isn't it already a problem that the node does not resolve the first time in your case? Why? Cannot we do something about having at least a better diagnostic message? For the moment it looks like the strategy would be to always try at least twice or otherwise assume that the resolution failed? Not very elegant, but I would be fine with it if I get it consistent - I can try even 10 times :). I do not understand yet the implementation details, so I do not really get your explanation about the difference between Thanks in advance for any help. |
@aschmahmann I aligned the ports and did some more tests. I am not sure if 4002 changes anything, but from my more recent tests across three different nodes, it looks like you may be right - the key seem to indeed have some influence on resolving. So with some keys I really cannot get it resolved and with other key I got it resolved even after first attempt to only resolve successfully after 10 attempts later. Very unpredictable. On the other hand, I am still puzzled why in some case going to ipfs.io and resolving CID that is linked to an IPNS name seem to fix things up at least in some cases (looks like sometimes ipfs.io triggers something that makes faster discovery in the given region). So I am really puzzled... Is such level of uncertainty something that you currently describe like normal? How can we make this better? It feels impossible to build any commercial solution that depends on IPNS in such a shape and because our solution requires IPNS resolution that is at the very least deterministic, it would be nice to hear your opinion about the future of IPNS. |
@marcinczenko so our options for what's going on here are either:
There are some libp2p folks investigating DHT improvements that I can connect you to if that's up your alley of interest. Additionally, if you'd like to do some debugging to verify the There are also a couple of things I'm working on now that should help with IPNS resolution speed, and that if you'd like to help would be great!
If you're interested in the PubSub persistence I can detail more about how to break that up, but I would recommend taking a stab at the rendezvous work since once we have that it will be possible to have a fork of go-ipfs that is quite fast. In case you're wondering, rendezvous isn't magic it's a form of centralization. However, unlike a traditionally centralized naming system (e.g. DNS) we're only centralizing the pointers to interested peers as opposed to the records themselves. Also, the plan is to create an open or federated system around rendezvous to decrease the centralization going forward. Let me know if you have any questions or if you're interested in one of these topics. I'm available here, or on the #ipfs IRC or Matrix channels. |
Ok. Please give me a couple of days to process this - I am traveling at the moment but I will be back on Saturday. I would like helping out as much as I can. Sometimes I may be struggling a bit with available time, but it is on my roadmap to grasp a more about internals of IPFS and the whole eco-system and potentially contribute. Let's then start with what you suggest. I do like idea on getting more insights about IPNS and PubSub as I would love to have IPNS that resolves faster and more reliably. We can always reach out to DHT people if you find it helpful later. I will contact you on IRC or Matrix. In the meantime I will look at the description of the issues you mention. Do you guys maybe also use Slack? |
The links seem to be not valid. Do you mean: libp2p/go-libp2p-pubsub#171 for "attempt 1" and libp2p/go-libp2p-pubsub#175 for "some background info"? |
Yep sorry, about the broken links, fixed them. |
@aschmahmann Are you still using Riot? I am trying to reach you there, but I am not sure if you are still using it... |
@marcinczenko yep, although I've been travelling for the past week and have a bit more ahead of me. Will try and take a look tomorrow or later this week. |
@aschmahmann Thanks - take your time! |
@marcinczenko Thank you for opening this issue, I have been having a tough time resolving both 'self' and other keys on other nodes, even with pubsub enabled everywhere. Have you made any progress or discovered a work around at all? |
@DougAnderson444 I did not manage to get IPNS name resolution to work. But, because I need to get some sort of name resolution to work sooner or later, I started to do some experiments with the IPFS PubSub service and see to which extent I can build up something from it - I seem to be building my own-purpose IPNS myself basically ;). I have some experiments with only two nodes at the moment, so it does not say anything conclusively - but if I cannot make a stable system with two directly connected nodes that how am I going to make it work in more complex cases? It is really nothing then, but if you would like to take a look, this is part of an open source project https://github.com/identity-box/identity-box. To see what kind of strange and naive things I am doing currently, you may like to take a look at https://idbox.online/developers/idbox-raspberry-pi and than https://github.com/identity-box/identity-box/tree/master/workspaces/nameservice and maybe https://github.com/identity-box/identity-box/tree/master/workspaces/identity-service. Maybe to see if anything of this applies to you, knowing something about the context may help: https://idbox.online. The code is still very aggressively changed, so please forgive me if I am not precise with something. What we have deployed at the moment is stable and works reliably - so at least it seems that the basics are working. Now the scaling up, but that comes soon I hope. Because the IPNS name resolution is not the only issue I am trying to solve, I am not really under strong pressure to get this to work immediately - that's why I can afford not to rush too much (or in other words, I seem to have bigger problems - like funding :)). However, the longer I look at IPNS/IPFS the more I am inclined to build something myself... The constraints make people creative I suppose ;). |
@DougAnderson444 it seems from your comments on discuss that you are using js-ipfs nodes with IPNS over PubSub. go-ipfs 0.5+ have some pretty significant changes to IPNS over PubSub that are not yet implemented in js-ipfs. If you're still having trouble getting IPNS over PubSub functioning using go-ipfs 0.5+ peers feel free to open an issue on discuss and tag me. @marcinczenko sorry you're still having issues. If you haven't yet I'd check out the post 0.5 IPNS over PubSub and see if that works well for you. If you're looking to utilize some building blocks that are more high level in your identity service you may want to look into Textile threads/buckets as they may have some of the application layer concerns taken care of for you. |
Thanks @aschmahmann I did tag you in there. Pubsub seems to work fine between JS-GO for the |
@DougAnderson444 I think you're correct there. I'll do some investigating into what's going on there. I suspect that it didn't previously matter since IPNS over PubSub didn't really work unless you could first resolve data via the DHT, but since go-ipfs 0.5 these subsystems are independent which has surfaced some issues. |
@aschmahmann I think I solved one issue here, see the pull request. Thanks for your help & insight on this one! |
Thanks @DougAnderson444 I'll take a look when I can, although I suspect I'll be a bit busy this week. btw you caused me to poke around in the IPNS code base a bit and I found the bug/issue where IPNS over PubSub subscriptions fail if the DHT lookup fails and/or takes too long. It's on my PR todo list and I think should close out this issue once it's done. The issue stems from this function call happening before the IPNS over PubSub router gets touched leading to a few issues, including:
If we remove the Public Key searching this probably goes away. |
I was mistaken, I cannot get keys other than
I think go-IPFS is looking for a peerID that doesn't exist, because the key was an import onto the keychain instead of being a dialable peerID? |
Do you mean "I cannot get keys other than self to work if there is pubsub, but no DHT support"? If so then yes, that's my issue above. Otherwise can you explain in more detail, since I can successfully find and publish non-self keys and find them on public gateways (e.g. http://dweb.link/ipns/QmPJFHSPVJEGNrVt9JSKSJvFd8iYqPLeJ2itZgdyzAGuSE).
If that's your IPNS key then it's probably just part of how GetPublicKey works https://github.com/libp2p/go-libp2p-kad-dht/blob/330b9beabaacd7e44aa8c80c19435b1bf1081212/records.go#L20. It will simultaneously try and "dial" (with a background DHT query to find the peer if you're not already connected) the peer and ask it directly for the public key and it will simultaneously search the DHT for the key. |
Hi Adin, Question: are you importing that "key other than self" in the go/CLI before you resolve it in If yes, can you try Why would anyone want to do this, you may ask? Well, this is exactly what happens when the key is imported in js-ipfs; it doesn't get imported in go-ipfs, yet we are trying to use go-ipfs to resolve it. This is what the current tests are doing: resolve first (to save the records in Go-Ipfs), then publish it in Js-ipfs once go-ipfs is subscribed. So perhaps this is a different issue? Since we do have the DHT support? |
Fixed in #7549. |
Version information:
ipfs --version --all
go-ipfs version: 0.4.20-
Repo version: 7
System version: arm/linux
Golang version: go1.12.4
As requested by @aschmahmann this is continuation of our conversation from ipfs-shipyard/integration-mini-projects#4.
I was initially testing publishing and resolving of IPNS together with pubsub service but it looks like the problem is more fundamental.
ipfs resolve <name>
seems to be failing when the name has been published using--key
option and the key is notself
.I included quite in-depth description of the problem in my comments in ipfs-shipyard/integration-mini-projects#4: especially ipfs-shipyard/integration-mini-projects#4 (comment) and ipfs-shipyard/integration-mini-projects#4 (comment).
The testing has been done between two different nodes - both permanently connected and on - one on AWS and another one running on RaspberryPi. In both case they use port 4001 and we keep it open.
@aschmahmann please let me know if there anything I can do to help improving this. IPNS resolution is crucial for me.
The text was updated successfully, but these errors were encountered: