You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@openwhisk.apache.org by "Ning You Gang (Confluence)" <no...@apache.org> on 2021/04/15 03:26:19 UTC

[CONF] OpenWhisk > FunctionPullingContainerPool

|
[![](cid:avatar_d480eea7161b2a0a400d7cd2ba38ae63)](https://cwiki.apache.org/confluence/display/~ningyougang?src=mail&src.mail.product=confluence-
server&src.mail.timestamp=1618457179048&src.mail.notification=com.atlassian.confluence.plugins.confluence-
content-notifications-plugin%3Apage-created-
notification&src.mail.recipient=8aa980875bf24635015c9267bc8e02f6) | Ning You
Gang **created** a page  
---|---  
|  
---  
|  | [![page icon](cid:page-
icon)](https://cwiki.apache.org/confluence/display/OPENWHISK/FunctionPullingContainerPool?src=mail&src.mail.product=confluence-
server&src.mail.timestamp=1618457179048&src.mail.notification=com.atlassian.confluence.plugins.confluence-
content-notifications-plugin%3Apage-created-
notification&src.mail.recipient=8aa980875bf24635015c9267bc8e02f6&src.mail.action=view
"page icon")  
---  
[FunctionPullingContainerPool](https://cwiki.apache.org/confluence/display/OPENWHISK/FunctionPullingContainerPool?src=mail&src.mail.product=confluence-
server&src.mail.timestamp=1618457179048&src.mail.notification=com.atlassian.confluence.plugins.confluence-
content-notifications-plugin%3Apage-created-
notification&src.mail.recipient=8aa980875bf24635015c9267bc8e02f6&src.mail.action=view
"FunctionPullingContainerPool")  
|

#  **1.Introduction    **  

  

    Manage New scheduler's invoker healthy management, invokerHealthyManager actor will send the memory info(e.g. freeMemory, inprogressMemory, busyMemory) and invoker healthy fsm state(e.g. down, up, unhealthy) together to etcd.

    Other components can use the healthy data which stored into etcd as well, e.g. when send creationContainerMessage to invoker instance, relative component can get the healthy invokers from etcd.

    Manage New scheduler's containerPool, includes below features.

    1\. Create prewarm container initially. 

    2. Backfill the prewarm container if possible.

    2\. Cold start container based on the ContainerCreationMessage which fetch from ContainerManager.

    3\. Maintain several kind pools, e.g. busyPool, inProgressPool, warmedPool, prewarmedPool, prewarmStartingPool.

    5. Send memoryInfo to etcd every 1 second.

#  **2.** **Architecture Diagram**

  

#  **3.** **Design consideration**

  

  

  

  
  
  
---  
|  | [![View page Icon](cid:com.atlassian.confluence.plugins.confluence-email-
resources_view-page-email-adg-footer-
item_icon)](https://cwiki.apache.org/confluence/display/OPENWHISK/FunctionPullingContainerPool?src=mail&src.mail.product=confluence-
server&src.mail.timestamp=1618457179048&src.mail.notification=com.atlassian.confluence.plugins.confluence-
content-notifications-plugin%3Apage-created-
notification&src.mail.recipient=8aa980875bf24635015c9267bc8e02f6&src.mail.action=view
"View page Icon") | [View
page](https://cwiki.apache.org/confluence/display/OPENWHISK/FunctionPullingContainerPool?src=mail&src.mail.product=confluence-
server&src.mail.timestamp=1618457179048&src.mail.notification=com.atlassian.confluence.plugins.confluence-
content-notifications-plugin%3Apage-created-
notification&src.mail.recipient=8aa980875bf24635015c9267bc8e02f6&src.mail.action=view
"View page") |  •  
---|---|---  
[![Like Icon](cid:com.atlassian.confluence.plugins.confluence-like_view-email-
adg-content-
item_icon)](https://cwiki.apache.org/confluence/plugins/likes/like.action?contentId=177050795&src=mail&src.mail.product=confluence-
server&src.mail.timestamp=1618457179048&src.mail.notification=com.atlassian.confluence.plugins.confluence-
content-notifications-plugin%3Apage-created-
notification&src.mail.recipient=8aa980875bf24635015c9267bc8e02f6&src.mail.action=like&jwt=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ4c3JmOjhhYTk4MDg3NWJmMjQ2MzUwMTVjOTI2N2JjOGUwMmY2IiwicXNoIjoiM2Y1NTlhZjg2ODMxMTIzYmU3MmNiOTdhNTdhMTYyYzk4ZWExMDdmZmI5NzIxNjNhZWQyOTlmYWE2Mzg5OWU3YSIsImlzcyI6ImNvbmZsdWVuY2Vfbm90aWZpY2F0aW9uc0FSRUgtWFVEMS1QT1FHLUNTQU8iLCJleHAiOjE2MTkwNjE5NzksImlhdCI6MTYxODQ1NzE3OX0.7BCbQB0gQsiahKJ4ZqdEDzYGB-1a9QZ36mmh5gMxZC0
"Like Icon") |
[Like](https://cwiki.apache.org/confluence/plugins/likes/like.action?contentId=177050795&src=mail&src.mail.product=confluence-
server&src.mail.timestamp=1618457179048&src.mail.notification=com.atlassian.confluence.plugins.confluence-
content-notifications-plugin%3Apage-created-
notification&src.mail.recipient=8aa980875bf24635015c9267bc8e02f6&src.mail.action=like&jwt=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ4c3JmOjhhYTk4MDg3NWJmMjQ2MzUwMTVjOTI2N2JjOGUwMmY2IiwicXNoIjoiM2Y1NTlhZjg2ODMxMTIzYmU3MmNiOTdhNTdhMTYyYzk4ZWExMDdmZmI5NzIxNjNhZWQyOTlmYWE2Mzg5OWU3YSIsImlzcyI6ImNvbmZsdWVuY2Vfbm90aWZpY2F0aW9uc0FSRUgtWFVEMS1QT1FHLUNTQU8iLCJleHAiOjE2MTkwNjE5NzksImlhdCI6MTYxODQ1NzE3OX0.7BCbQB0gQsiahKJ4ZqdEDzYGB-1a9QZ36mmh5gMxZC0
"Like")  
---|---  
  
|  | [Stop watching
space](https://cwiki.apache.org/confluence/users/removespacenotification.action?spaceKey=OPENWHISK&src=mail&src.mail.product=confluence-
server&src.mail.timestamp=1618457179048&src.mail.notification=com.atlassian.confluence.plugins.confluence-
content-notifications-plugin%3Apage-created-
notification&src.mail.recipient=8aa980875bf24635015c9267bc8e02f6&src.mail.action=stop-
watching&jwt=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ4c3JmOjhhYTk4MDg3NWJmMjQ2MzUwMTVjOTI2N2JjOGUwMmY2IiwicXNoIjoiMGMzMzQ4ZjZmOTM4NDExOTg2OWRkN2Y4N2ZlYzgwOWU1NDQzZWJkY2IzM2JjNTJmMDBjNDZmZTY1NThjOTQ0OSIsImlzcyI6ImNvbmZsdWVuY2Vfbm90aWZpY2F0aW9uc0FSRUgtWFVEMS1QT1FHLUNTQU8iLCJleHAiOjE2MTkwNjE5NzksImlhdCI6MTYxODQ1NzE3OX0.78gsWxELZmQftY0I_AW8ORMiodzxRMDCDAQV0MQX8HM)
| •  
---|---  
[Manage
notifications](https://cwiki.apache.org/confluence/users/editmyemailsettings.action?src=mail&src.mail.product=confluence-
server&src.mail.timestamp=1618457179048&src.mail.notification=com.atlassian.confluence.plugins.confluence-
content-notifications-plugin%3Apage-created-
notification&src.mail.recipient=8aa980875bf24635015c9267bc8e02f6&src.mail.action=manage)  
---  
| ![Confluence logo big](cid:footer-desktop-logo)  
---  
This message was sent by Atlassian Confluence 7.5.0  
![](cid:footer-mobile-logo)  
---