نظرة عامة على بنية الخدمة لتقييم المظهر بناءً على الشبكات العصبية



المقدمة



مرحبا!



في هذه المقالة ، سوف أشارك تجربتي في بناء بنية الخدمات المصغرة لمشروع باستخدام الشبكات العصبية.



دعنا نتحدث عن متطلبات العمارة ، ونلقي نظرة على المخططات الهيكلية المختلفة ، ونحلل كل مكون من مكونات العمارة النهائية ، ونقيم المقاييس الفنية للحل.



استمتع بالقراءة!



بضع كلمات عن المشكلة وحلها



– .



, , . , , .



, . 



, :





MTCNN. PyTorch, backbone ResNet34 – « / CPU»









ML , , .





ML



– -, . :



  1. – ,
  2. — Bottleneck
  3. - —
  4. () ,
  5. , ,




, .



, , Telegram API.



, , .







, Single Responsibility .



«attrai-telegram-bot»



Telegram API. 2 – . .



:



  1. , :

    • ,
  2. docker volume
  3. “to_estimate” , , , , volume
  4. – , . – , .


, , celery worker, «after_estimate», , .



“after_estimate”:



  1. – , –
  2. ,


«attrai-estimator»



celery worker , . – .



“to_estimate”:



  1. :

    1. (MTCNN)
    2. ( ResNet34)


      1. bounding boxes
  2. ()
  3. “after_estimate”, “attrai-telegram-bot”


Graylog (+ mongoDB + Elasticsearch)



Graylog — . , .



, ELK , Python. , Graylog, GELFTCPHandler graypy root logger handlers python-.



, , ELK , , Graylog. , – Kibana - Graylog.



RabbitMQ



RabbitMQ — AMQP.



Celery durable .



Redis



Redis — NoSQL , « — »



python- , - .



, Redis hashmap «telegram_user_id => », , , DoS-.





  1. Telegram
  2. «attrai-telegram-bot» Telegram API
  3. «to_estimate»
  4. «attrai-estimator» «to_estimate», «after_estimate»
  5. «attrai-telegram-bot», «after_estimate»,


DevOps



, , — DevOps



Docker Swarm



 





Docker Swarm  - , Docker Engine .



«», 2 – worker manager. (), , . .





leader manager worker



– 1 , leader manager worker. , .



, , production-, , , , ( , - - , ).



Docker Stack



«» ( docker services) docker stack



docker-compose , deploy .  



, ( N N , - , PyTorch`, )



attrai_estimator:
  image: 'erqups/attrai_estimator:1.2'
  deploy:
    replicas: 4
    resources:
      limits:
        cpus: '4'
    restart_policy:
      condition: on-failure
      …


, Redis, RabbitMQ Graylog — stateful , «attrai-estimator»,



— Kubernetes?



, Kubernetes – , Docker Swarm, user friendly , .





VDS :



  • CPU: 4 Intel® Xeon® Gold 5120 CPU @ 2.20GHz
  • RAM: 8 GB
  • SSD: 160 GB


, , , .



, , (, ), . CPU RAM .









, ,











, , — . 



, , CPU, , .



سأضيف أن المقالة كانت في البداية أكبر ، لكن لكي لا أنشر قراءة طويلة ، قررت حذف بعض النقاط في هذه المقالة - سنعود إليها في المنشورات المستقبلية.



يمكنك النقر على الروبوت في Telegram -AttraiBot ، وسيعمل على الأقل حتى نهاية خريف 2020. دعني أذكرك - لا يتم تخزين بيانات المستخدم - لا الصور الأصلية ولا نتائج خط أنابيب التقييم - يتم هدم كل شيء بعد المعالجة.




All Articles