<p dir="ltr"><br>
On Dec 6, 2013 4:26 PM, "Akihiro Motoki" <<a href="mailto:motoki@da.jp.nec.com">motoki@da.jp.nec.com</a>> wrote:<br>
><br>
><br>
> (2013/12/06 17:57), Joe Gordon wrote:<br>
> ><br>
> > On Dec 6, 2013 9:57 AM, "Maru Newby" <<a href="mailto:marun@redhat.com">marun@redhat.com</a> <mailto:<a href="mailto:marun@redhat.com">marun@redhat.com</a>>> wrote:<br>
> >  ><br>
> >  ><br>
> >  > On Dec 6, 2013, at 1:09 AM, John Dickinson <<a href="mailto:me@not.mn">me@not.mn</a> <mailto:<a href="mailto:me@not.mn">me@not.mn</a>>> wrote:<br>
> >  ><br>
> >  > ><br>
> >  > > On Dec 5, 2013, at 1:36 AM, Maru Newby <<a href="mailto:marun@redhat.com">marun@redhat.com</a> <mailto:<a href="mailto:marun@redhat.com">marun@redhat.com</a>>> wrote:<br>
> >  > ><br>
> >  > >><br>
> >  > >> On Dec 3, 2013, at 12:18 AM, Joe Gordon <<a href="mailto:joe.gordon0@gmail.com">joe.gordon0@gmail.com</a> <mailto:<a href="mailto:joe.gordon0@gmail.com">joe.gordon0@gmail.com</a>>> wrote:<br>

> >  > >><br>
> >  > >>><br>
> >  > >>><br>
> >  > >>><br>
> >  > >>> On Sun, Dec 1, 2013 at 7:04 PM, John Dickinson <<a href="mailto:me@not.mn">me@not.mn</a> <mailto:<a href="mailto:me@not.mn">me@not.mn</a>>> wrote:<br>
> >  > >>> Just to add to the story, Swift uses "X-Trans-Id" and generates it in the outer-most "catch_errors" middleware.<br>
> >  > >>><br>
> >  > >>> Swift's catch errors middleware is responsible for ensuring that the transaction id exists on each request, and that all errors previously uncaught, anywhere in the pipeline, are caught and logged. If there is not a common way to do this, yet, I submit it as a great template for solving this<br>

> > problem. It's simple, scalable, and well-tested (ie tests and running in prod for years).<br>
> >  > >>><br>
> >  > >>> <a href="https://github.com/openstack/swift/blob/master/swift/common/middleware/catch_errors.py">https://github.com/openstack/swift/blob/master/swift/common/middleware/catch_errors.py</a><br>

> >  > >>><br>
> >  > >>> Leaving aside error handling and only focusing on the transaction id (or request id) generation, since OpenStack services are exposed to untrusted clients, how would you propose communicating the appropriate transaction id to a different service? I can see great benefit to having a glance<br>

> > transaction ID carry through to Swift requests (and so on), but how should the transaction id be communicated? It's not sensitive info, but I can imagine a pretty big problem when trying to track down errors if a client application decides to set eg the X-Set-Transaction-Id header on every request<br>

> > to the same thing.<br>
> >  > >>><br>
> >  > >>> -1 to cross service request IDs, for the reasons John mentions above.<br>
> >  > >>><br>
> >  > >>><br>
> >  > >>> Thanks for bringing this up, and I'd welcome a patch in Swift that would use a common library to generate the transaction id, if it were installed. I can see that there would be huge advantage to operators to trace requests through multiple systems.<br>

> >  > >>><br>
> >  > >>> Another option would be for each system that calls an another OpenStack system to expect and log the transaction ID for the request that was given. This would be looser coupling and be more forgiving for a heterogeneous cluster. Eg when Glance makes a call to Swift, Glance cloud log the<br>

> > transaction id that Swift used (from the Swift response). Likewise, when Swift makes a call to Keystone, Swift could log the Keystone transaction id. This wouldn't result in a single transaction id across all systems, but it would provide markers so an admin could trace the request.<br>

> >  > >>><br>
> >  > >>> There was a session on this at the summit, and although the notes are a little scarce this was the conclusion we came up with.  Every time a cross service call is made, we will log and send a notification for ceilometer to consume, with the request-ids of both request ids.  One of the<br>

> > benefits of this approach is that we can easily generate a tree of all the API calls that are made (and clearly show when multiple calls are made to the same service), something that just a cross service request id would have trouble with.<br>

> >  > >><br>
> >  > >> Is wise to trust anything a client provides to ensure traceability?  If a user receives a request id back from Nova, then submits that request id in an unrelated request to Neutron, the traceability would be effectively corrupted.  If the consensus is that we don't want to securely deliver<br>

> > request ids for inter-service calls, how about requiring a service to log its request id along with the request id returned from a call to another service to achieve the a similar result?<br>
> >  > ><br>
> >  > > Yes, this is what I was proposing. I think this is the best path forward.<br>
><br>
> I think Logging returned request-id at client side is the best way.<br>
> We can track each API call even when multiple API calls are invoked in one API request.<br>
>  ><br>
>  > Nova does this for glance client today.  Glance client logs the out glances request Id and that message is wrapped with novas request id.<br>
><br>
> When I ran devstack, glance client log (with glance request-id) is not wrapped<br>
> with nova request-id: <a href="http://paste.openstack.org/show/54590/">http://paste.openstack.org/show/54590/</a><br>
> It is because glanceclient uses standard logging instead of openstack.common.log.<br>
> It is common to all client libraries and I am not sure why client libraries<br>
> do not use openstack.common.log.</p>
<p dir="ltr">Woops you are correct, we log both request ids just not on the same line</p>
<p dir="ltr">> ><br>
> > Ceilometer wanted notifications of these events as well so it could track things better.<br>
><br>
> Should this feature a part of client libraries or server side which calls client libraries?</p>
<p dir="ltr">Server side</p>
<p dir="ltr">> At now client libraries do not return information about response headers including request-id.<br>
> If we support it in server side, a standard way to return request-id in a response to a caller.<br>
> I don't have good idea on it at the moment and it is just a question.</p>
<p dir="ltr">Agreed, this point is where most of the work will be.</p>
<p dir="ltr">><br>
> Thanks,<br>
> Akihiro<br>
><br>
> ><br>
> >  ><br>
> >  > Ok, great.  And as per your suggestion, a middleware-based error handler will soon be proposed for oslo that will secondarily ensure that a request id is added to the request.<br>
> >  ><br>
> >  > ><br>
> >  > ><br>
> >  > >> The catch is that every call point (or client instantiation?) would have to be modified to pass the request id instead of just logging at one place in each service.  Is that a cost worth paying?<br>

> >  > ><br>
> >  > > Perhaps this is my ignorance of how other projects work today, but does this not already happen? Is it possible to get a response from an API call to an OpenStack project that doesn't include a request id?<br>

> >  ><br>
> >  > We'll have it in Neutron real-soon-now, and then I think the answer will be 'yes'.<br>
> >  ><br>
> >  > On reflection, it should be easy enough for a given service to ensure that calls to other services are automatically instrumented to log request id pairs.  Again, probably something for oslo.<br>
> >  ><br>
> >  ><br>
> >  > m.<br>
> >  > _______________________________________________<br>
> >  > OpenStack-dev mailing list<br>
> >  > <a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</a> <mailto:<a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</a>><br>
> >  > <a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
> ><br>
> _______________________________________________<br>
> OpenStack-dev mailing list<br>
> <a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</a><br>
> <a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
</p>