От многопоточных вычислений переходим к распределённым. То есть вычисления, происходящие на нескольких компьютерах.
Конечно, в зависимости от задачи, вы можете взять готовые решения вроде CGRU или Deadline для рендеринга, charm4py или Dask для ML, или замутить что-то на AWS С2. Но хотелось бы чего-то попроще, попитоничней что ли)
А ведь в Python есть средства "из коробки" для синхронизации нескольких процессов на разных хостах.
Вот простой пример кода, который синхронизирует работу двух процессов на разных компьютерах.
В этом случае используется процесс-посредник, который является синхронизирующим сервером.
В примере создаётся некий Manager, который шарит общую для клиентов очередь. Все подключившиеся могут что-то в неё писать или забирать.
В моём коде один процесс что-то "считает" и складывает в очередь, другой забирает и продолжает какие-то свои "расчёты".
Если у вас есть несколько машин, то можете попробовать это запустить по сети (нужно заменить 'localhost' на IP-адрес сервера). Но и на локальной машине сработает.
Gist 🌎
#libs#source#tricks
Choc Chip Banana Bread ✨🍌🤎
Ingredients:
* 3 large ripe bananas (360–380 g)
* 130 g unsalted butter (will reduce to \~115 g once browned)
* 180 g dark brown sugar (+ 1–2 tbsp for topping)
* 2 large eggs
* 250 g plain flour
* 1 tsp baking soda
* ½ tsp salt
* ½ tsp cinnamon
* 70–100 g dark chocolate, chopped
* Optional: chopped nuts
#dinner
@dishes
My Kind of Girl Dinner 😮💨🍚🥒
Ingredients:
For the salmon:
* 2 salmon fillets (skin removed, cut into cubes)
* 2 tbsp soy sauce
* 1 tbsp oyster sauce
* 1 tsp brown sugar
* 2 tsp minced garlic
* 1 tbsp sriracha
* ¼ tsp chili flakes
For the rice & toppings:
* 100 g sushi rice (cooked)
* 1 tsp apple cider vinegar
* ½ tsp salt
* ½ tsp sugar
* Pinch of chili flakes
* ¼ cucumber, thinly sliced
* ¼ small onion, thinly sliced
* Handful of edamame (cooked)
* Black & white sesame seeds, for topping
#dinner
@dishes