Superskyyy commented on code in PR #250:
URL: https://github.com/apache/skywalking-python/pull/250#discussion_r1024803641


##########
docs/en/profiling/profiling.md:
##########
@@ -0,0 +1,83 @@
+# How does threading-profiler (the default mode) work  
+
+These blogs 
[skywalking-profiling](https://skywalking.apache.org/blog/2020-04-13-apache-skywalking-profiling/#profiling-in-production)
 and 
[skywalking-python-profiling](https://skywalking.apache.org/blog/2021-09-12-skywalking-python-profiling/)
 described how the threading-profiler works
+
+And this figure demonstrates how the profiler works as well:
+
+
+```mermaid
+sequenceDiagram
+    API->>+working thread: get: /api/v1/user/
+    rect rgb(0,200,0)
+    API->>+profiling thread: start profiling
+    profiling thread->>working thread: snapshot
+    profiling thread->>working thread: snapshot
+    profiling thread->>working thread: snapshot
+    profiling thread->>-working thread: snapshot
+    end
+    working thread-->>-API: response
+```
+  
+
+It works well with threading mode because the whole process will be executed 
in **the same** thread, so the profiling thread can fetch the complete 
profiling info of the process of the API request.
+
+# Why doesn't threading-profiler work in greenlet mode
+When the python program runs with gevent + greenlet, the process would be like 
this:
+
+
+
+```mermaid
+sequenceDiagram
+    API->>+working thread 1: get: /api/v1/user/
+    rect rgb(0,200,0)
+    greenlet.HUB-->>+working thread 1: swap in the profiled greenlet
+    API->>+profiling thread: start profiling
+    profiling thread->>working thread 1: snapshot
+    working thread 1-->>-greenlet.HUB : swap out the profiled greenlet
+    end
+    greenlet.HUB-->>+working thread 1: swap in the other greenlet
+    profiling thread->>working thread 1: snapshot
+    greenlet.HUB-->>+working thread 2: swap in the profiled greenlet
+    profiling thread->>working thread 1: snapshot
+    profiling thread->>working thread 1: snapshot
+    working thread 2-->-greenlet.HUB : swap out the profiled greenlet
+    profiling thread->>working thread 1: snapshot
+    profiling thread->>-working thread 1: snapshot
+    working thread 1-->>-greenlet.HUB : swap out the other greenlet
+    working thread 1-->>-API: response
+```
+  
+
+In this circumstance, the snapshot of the working thread includes multi 
contexts of different greenlets, which will make skywalking confused to build 
the trace stack.
+
+
+Fortunately, greenlet has an API for profiling, the doc is 
[here](https://greenlet.readthedocs.io/en/latest/tracing.html). We can 
implement a greenlet profiler to solve this issue.
+
+
+# How the greenlet profiler works
+
+A greenlet profiler leverages the trace callback of greenlet, it works like 
this:
+
+
+```mermaid
+sequenceDiagram
+    API->>+working thread 1: get: /api/v1/user/
+    rect rgb(0,200,0)
+    greenlet.HUB-->>+working thread 1: swap in the profiled greenlet and 
snapshot
+    working thread 1-->>-greenlet.HUB : swap out the profiled greenlet and 
snapshot
+    end
+    greenlet.HUB-->>+working thread 1: swap in the other greenlet
+    rect rgb(0,200,0)
+    greenlet.HUB-->>+working thread 2: swap in the profiled greenlet and 
snapshot
+    working thread 2-->-greenlet.HUB : swap out the profiled greenlet and 
snapshot
+    end
+    working thread 1-->>-greenlet.HUB : swap out the other greenlet
+    working thread 1-->>-API: response
+```
+
+We can set a callback function to the greenlet that we need to profiling, then 
when the greenlet.HUB switches the context in/out to the working thread, the 
callback will build a snapshot of the greenlet's traceback and send it to 
skywalking.
+
+
+# the difference between these two profilers

Review Comment:
   ```suggestion
   # The difference between these two profilers
   ```



-- 
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

To unsubscribe, e-mail: [email protected]

For queries about this service, please contact Infrastructure at:
[email protected]

Reply via email to