Project

General

Profile

Actions

Bug #16392

closed

[keep] trailing slash in InternalURLs entry for keepstore causes problems with keepproxy

Added by Ward Vandewege over 4 years ago. Updated about 4 years ago.

Status:
Resolved
Priority:
Normal
Assigned To:
Category:
-
Target version:
Story points:
-
Release relationship:
Auto

Description

Our dev cluster, `ce8i5`, had this in its `config.yml` file:

    Services:
      Keepstore:
        InternalURLs:
          "http://10.47.0.6:25107/": {}

Since feature #16328, keepproxy now uses those entries instead of trying to discover keepstores via the api server.

It turns out that the trailing slash in the InternalURLs entry causes problems. This is what happens on the keepstore in question:

May 01 01:02:54 keep0.ce8i5.arvadosapi.com keepstore[42411]: {"PID":42411,"RequestID":"req-ck4ozsdn8womgzwr5fva","level":"info","msg":"request","remoteAddr":"10.47.0.5:39818","reqBytes":24,"reqForwardedFor":"","reqHost":"10.47.0.6:25107","reqMethod":"PUT","reqPath":"/2ad1390f7b534cf6b25765606796626a","reqQuery":"","time":"2020-05-01T01:02:54.680169064Z"}
May 01 01:02:54 keep0.ce8i5.arvadosapi.com keepstore[42411]: {"PID":42411,"RequestID":"req-ck4ozsdn8womgzwr5fva","level":"info","msg":"response","remoteAddr":"10.47.0.5:39818","reqBytes":24,"reqForwardedFor":"","reqHost":"10.47.0.6:25107","reqMethod":"PUT","reqPath":"/2ad1390f7b534cf6b25765606796626a","reqQuery":"","respBytes":0,"respStatus":"Moved Permanently","respStatusCode":301,"time":"2020-05-01T01:02:54.680293465Z","timeToStatus":0.000129,"timeTotal":0.000132,"timeWriteBody":0.000002}
May 01 01:02:54 keep0.ce8i5.arvadosapi.com keepstore[42411]: {"PID":42411,"RequestID":"req-ck4ozsdn8womgzwr5fva","level":"info","msg":"request","remoteAddr":"10.47.0.5:39818","reqBytes":0,"reqForwardedFor":"","reqHost":"10.47.0.6:25107","reqMethod":"GET","reqPath":"2ad1390f7b534cf6b25765606796626a","reqQuery":"","time":"2020-05-01T01:02:54.687455786Z"}
May 01 01:02:54 keep0.ce8i5.arvadosapi.com keepstore[42411]: {"PID":42411,"RequestID":"req-ck4ozsdn8womgzwr5fva","level":"info","msg":"response","remoteAddr":"10.47.0.5:39818","reqBytes":0,"reqForwardedFor":"","reqHost":"10.47.0.6:25107","reqMethod":"GET","reqPath":"2ad1390f7b534cf6b25765606796626a","reqQuery":"","respBody":"Forbidden\n","respBytes":10,"respStatus":"Forbidden","respStatusCode":403,"time":"2020-05-01T01:02:54.687560487Z","timeToStatus":0.000094,"timeTotal":0.000100,"timeWriteBody":0.000006}

And of course keepproxy then relays the familiar, but not so informative error to the client:

Traceback (most recent call last):
  File "/usr/bin/arv-put", line 7, in <module>
    main()
  File "/usr/share/python2.7/dist/python-arvados-python-client/lib/python2.7/site-packages/arvados/commands/put.py", line 1304, in main
    writer.start(save_collection=not(args.stream or args.raw))
  File "/usr/share/python2.7/dist/python-arvados-python-client/lib/python2.7/site-packages/arvados/commands/put.py", line 628, in start
    self._local_collection.manifest_text()
  File "/usr/share/python2.7/dist/python-arvados-python-client/lib/python2.7/site-packages/arvados/arvfile.py", line 270, in synchronized_wrapper
    return orig_func(self, *args, **kwargs)
  File "/usr/share/python2.7/dist/python-arvados-python-client/lib/python2.7/site-packages/arvados/collection.py", line 1014, in manifest_text
    self._my_block_manager().commit_all()
  File "/usr/share/python2.7/dist/python-arvados-python-client/lib/python2.7/site-packages/arvados/arvfile.py", line 816, in commit_all
    raise KeepWriteError("Error writing some blocks", err, label="block")
arvados.errors.KeepWriteError: Error writing some blocks: block 2ad1390f7b534cf6b25765606796626a+24 raised KeepWriteError (failed to write 2ad1390f7b534cf6b25765606796626a after 2 attempts (wanted 2 copies but wrote 0): service https://keep.ce8i5.arvadosapi.com:443/ responded with 413 HTTP/1.1 100 Continue
  HTTP/1.1 413 Request Entity Too Large)

Removing the trailing slash from the InternalURLs entry resolved the problem.

It would probably be most user friendly if keepproxy (or our config parsing library?) can handle entries both with and without trailing slash. We've named the field `InternalURLs`, so it is to be expected that some people will put a trailing slash there, and some will not.


Subtasks 2 (0 open2 closed)

Task #16410: Review 16392-url-trailing-slashResolvedLucas Di Pentima05/13/2020Actions
Task #16432: Remove any trailing slashes from exported config URLs on WB2ResolvedLucas Di Pentima05/20/2020Actions

Related issues 1 (0 open1 closed)

Related to Arvados - Bug #16328: [keep-proxy] should use config.yaml to identify upstream keepstoresResolvedWard Vandewege04/21/2020Actions
Actions #1

Updated by Ward Vandewege over 4 years ago

  • Description updated (diff)
Actions #2

Updated by Ward Vandewege over 4 years ago

  • Description updated (diff)
Actions #3

Updated by Ward Vandewege over 4 years ago

  • Related to Bug #16328: [keep-proxy] should use config.yaml to identify upstream keepstores added
Actions #4

Updated by Tom Clegg over 4 years ago

  • Assigned To set to Tom Clegg
Actions #5

Updated by Tom Clegg over 4 years ago

  • Status changed from New to In Progress
Actions #6

Updated by Lucas Di Pentima over 4 years ago

Reviewing 8605bce9000a8a4dfa1ae0ea5cbe1cfac0b8cc1b

  • Is the config.UnmarshalText() change enough to make keepproxy et al work with & without a trailing slash?
  • Do you think a specific test addressing the particular issue on this ticket would be useful, or it isn't worth it as it fixes a problem happening in between releases?
  • Arvbox config URLs are being generated mixed with and without trailing slashes, it may be generating the issue described below.
  • Workbench2 on arvbox auto logs out when logging in. Ran the integration tests against this branch (that use PAM instead of SSO, not sure if it has anything to do with this) and they pass OK.
Actions #7

Updated by Tom Clegg over 4 years ago

  • Is the config.UnmarshalText() change enough to make keepproxy et al work with & without a trailing slash?
  • Do you think a specific test addressing the particular issue on this ticket would be useful, or it isn't worth it as it fixes a problem happening in between releases?

The UnmarshalText change exposes the bug in the ServerRequiredConfigYmlSuite.TestGetIndex test, and then this fixes it:

        for k := range cluster.Services.Keepstore.InternalURLs {
-               arv.KeepServiceURIs = append(arv.KeepServiceURIs, k.String())
+               arv.KeepServiceURIs = append(arv.KeepServiceURIs, strings.TrimRight(k.String(), "/"))
        }

(If you remove the TrimRight you should see the test fail.)

  • Arvbox config URLs are being generated mixed with and without trailing slashes, it may be generating the issue described below.
  • Workbench2 on arvbox auto logs out when logging in. Ran the integration tests against this branch (that use PAM instead of SSO, not sure if it has anything to do with this) and they pass OK.

I don't quite follow -- are you saying this branch breaks arvbox+wb2 login? The goal here is that you can add/remove trailing slashes in your config files with no effect at all, so I don't think that should be an issue. However, it's possible this causes a double-slash problem. We've had a situation before where POST https://example//foo gets transparently redirected (by Go stdlib) to GET https://example/foo, causing surprising behavior. Perhaps it's something like that?

src/common/config.ts:88:    config.rootUrl = clusterConfigJSON.Services.Controller.ExternalURL;
src/store/auth/auth-action-session.ts:266:                    window.location.href = `${rootUrl.toString()}/login?return_to=` + encodeURI(`${window.location.protocol}//${window.location.host}/add-session?baseURL=` + encodeURI(rootUrl.toString()));

Perhaps arvados-workbench-2:source:src/common/config.ts should systematically strip trailing "/" from all of the config-exported URLs so stuff like `${rootUrl.toString()}/login` doesn't end up with a double slash regardless of API version?

Actions #8

Updated by Lucas Di Pentima over 4 years ago

Thanks, yes! WB2 will need some fixes, should I add a subtask about it assigned to me?

LGTM.

Actions #9

Updated by Tom Clegg over 4 years ago

  • Assigned To changed from Tom Clegg to Lucas Di Pentima
Actions #10

Updated by Tom Clegg over 4 years ago

  • Status changed from In Progress to Resolved
Actions #11

Updated by Peter Amstutz about 4 years ago

  • Release set to 25
Actions #12

Updated by Peter Amstutz about 4 years ago

  • Release changed from 25 to 36
Actions #13

Updated by Peter Amstutz about 4 years ago

  • Release changed from 36 to 25
Actions

Also available in: Atom PDF