Растение колба: Не поверите своим глазам: как черемша творит чудеса

alexxlab Разное

Содержание

Не поверите своим глазам: как черемша творит чудеса

16 апреля 2021 18:25     Фото: prostayaferma.ru

После изнурительной зимы многих начинают интересовать полезные свойства и противопоказания черемши, которую в народе почитают как весеннюю зелень, богатую важными для организма элементами. Сезон для употребления этой травы в свежем виде достаточно короткий, поэтому актуальной является информация о методиках ее заготовки впрок.

Увидеть в природе, что это за растение черемша, удается не всем, но весной ароматные листья можно приобрести практически повсеместно, поскольку ареал ее произрастания очень обширный.

Излюбленные места, где растет черемша, характеризуются наличием влаги и тени, хотя она может поселиться и на менее подходящих участках, постепенно расширяя территорию своего произрастания.

Колба, дикий чеснок, левурда, медвежий лук – это не виды черемши, а разные названия этой витаминной травы. Широкие с заостренными вытянутыми верхушками листья насыщенно зеленого цвета. Крепятся на сочных ножках цилиндрической формы. Белые мелкие цветы формируются в зонтики, располагающиеся на верхушке растения.
Состав

Чтобы понять, чем полезна черемша для организма, необходимо проанализировать, какие многообразные элементы входят в состав травы:

    эфирные масла;
    аминокислоты;
    богатейший минеральный спектр – калий, фтор, кальций, сера;
    микроэлементы, играющие важную роль в биохимических процессах – фтор, бор, медь, йод. Представлено железо, марганец, цинк.

Также содержатся разнообразные витамины в черемше, обусловливающие возможность восстановления весной защитных сил организма (на 100 гр.):

    А – 4,4 гр;
    РР – 0,5 мг;
    В1 – 0,045 гр;
    В2 – 0,15 мг;
    В9 – 4,2 мг;
    С – 10 гр.

Если анализировать состав черемши с точки зрения пищевой ценности (из расчета на 100 гр. сырья), то отмечается наличие в ней белков (максимальный показатель достигает 3 гр.), жиров (примерно 0,2 гр.), углеводов – до 6 – 7 гр. Предельное содержание пищевых волокон достигает 7 гр, воды – 85,5 гр, золы – 1,2 гр.

Средняя калорийность черемши составляет 35,5 – 38 ккал/100 гр.

Многообразные полезные свойства черемши сделали это растение популярным. Оно используется как вещество, усиливающее аппетит. Благодаря богатой структурной формуле, трава применяется в роли природного средства от авитаминоза.

Известны и другие лечебные свойства черемши при условии правильного употребления.

    Производит бактерицидный эффект, влияя губительно на большинство патогенных микроорганизмов.
    Облегчает состояние больных гипертонией, оказывая укрепляющее действие на сосуды. Регулируя концентрацию холестерина, содействует замедлению развития тромбов.

    Позволяет быстрее очистить от мокроты бронхи, помогая справиться с кашлем и одышкой.
    Нормализует обменные процессы, улучшая настроение, поднимая работоспособность.
    Стимулирует сердечно — сосудистую деятельность.
    Содействует избавлению от кишечных паразитов.
    Оказывает общеукрепляющее действие.
    Благодаря наличию в структурной формуле пищевых волокон, стимулирует функционирование желудочно-кишечного тракта, содействуя выведению токсинов и шлаков.

Сок черемши способен избавить от лишая, бородавок и других кожных поражений. Велика польза черемши для организма человека в укреплении нервной системы, обретении спокойствия, устойчивости к стрессам. Это позволяет избавиться от бессонницы, раздражительности, тревожности.

Стремясь повысить жизненный тонус весенней витаминной зеленью, следует учитывать конкретные противопоказания черемши, которые не нужно игнорировать. Нельзя употреблять эту ароматную траву, если есть следующие заболевания:

    острый гастрит;
    холецистит;
    язвенная болезнь;
    панкреатит;
    патологические нарушения желудочно-кишечного тракта;
    гепатит.

С осторожностью употребляется черемша при беременности, несмотря на полезные качества. Целесообразно при возникновении сильного желания съесть витаминный салат с колбой посоветоваться с врачом. Если возражений не последует, вводите в меню небольшое количество продукта.

Также потребуется консультативная помощь педиатра, который решит, нужна ли в рационе черемша при грудном вскармливании и в каких количествах.

Несмотря на стимулирование обменных процессов, черемша для похудения практически не используется. Связано это с тем, что эта трава одновременно повышает аппетит. Не следует злоупотреблять этим весенним источником витаминов людям, склонным к полноте.

Имея в виду подобные противоречия, обязательно изучается польза и вред черемши во всех проявлениях и принимается взвешенное решение о введении продукта в меню.

Заготавливают для употребления в основном дикорастущую траву, хотя при желании можно на собственном огороде отвести уголок под деревьями для посадки дикого лука.

Важно знать, в каких количествах и как есть черемшу, чтобы получить пользу для организма.

Оптимальная дневная норма взрослого человека — 3-8 листов с сочной ножкой. В неделю рекомендуется трехразовое введение травы в рацион. Чрезмерно увлекаться не стоит, чтобы не вызвать проблем с функционированием кишечника, сердца.

В умеренных количествах принесет пользу черемша детям в возрасте старше 2 лет. Добавляйте продукт в салат или вторые блюда не более двух листов три раза в неделю.

При подборе зелени обращают внимание на то, что черешки не должны быть грубыми, а сами листья вялыми. В свежем состоянии хранение черемши после завертывания в пищевую пленку осуществляют в холодильнике максимум 4 дня. Можно траву заморозить.

    Чаще всего делают из свежей колбы салат. Добавляют огурцы, отварной картофель, крапивные листья. Вводят в состав одуванчик, листья которого предварительно 30 минут выдерживают в соленой воде и отжимают. Для заправки салата используют растительное масло, сметану, майонез в соответствии с вкусовыми предпочтениями.


    Применяют рецепты, разъясняющие, как варить черемшу, при условии точного соблюдения указанного времени. Очищенную от лишних фрагментов и промытую траву закладывают в кипящую воду. Верхний слой прижимают шумовкой, чтобы был погружен в жидкость. После закипания черемша варится 1,5 минуты.
    Сливают воду, и вливают нерафинированное подсолнечное масло (из расчета – 3 ст. л. на килограмм травы). Добавляют по вкусу соль и томатную пасту. После перемешивания блюдо готово к употреблению. Но по-настоящему свой букет кушанье раскроет, если его подержать два часа в холодильнике.
    Добавляют медвежий лук в суп за две – три минуты до готовности. Когда кастрюлю снимают с огня, накрывают крышкой и дают настояться 30 минут.
    Смешав мелко накрошенный дикий чеснок с порезанным зеленым луком, перцем и заправив смесь майонезом, получают острую аппетитную приправу к мясу.

С колбой тушат мясо. Вкусными получаются пирожки с ароматной начинкой из этой травы. В целом приготовление черемши отличается разнообразием, так как продукт гармонирует с крупами, картофелем, макаронными изделиями.


В роли аппетитной бутербродной начинки может выступить сало с медвежьим луком. Готовится кушанье быстро:

    Прокрутить на мясорубке 200 гр. сала и 500 гр. черемши.
    В получившийся фарш по вкусу добавить соль, любимые специи и пряности.
    Перемешать.

Позволяет сохранить значительную долю полезных свойств консервация черемши, проводимая разными способами.

    Подготовленную чистую черемшу (2 кг.) положить в эмалированную пятилитровую кастрюлю.
    Для маринада смешать воду (1,2 литра) с уксусом (190 мл.).
    Добавить черный перец (4-6 горошин), сахар (3 ст. л.), соль (2 ст. л.), лавровый лист (2-3 штуки).
    Закипевшим маринадом залить колбу.

    Оставить остывать.
    Поместить кастрюлю на 3 дня в холодильник или вынести в погреб.

Вкусная закуска готова. Если планируется заготовка черемши на зиму, ее закатывают в стерильные банки.
Колба в томатном соусе

Несложно готовится черемша на зиму, если использовать для маринада следующий рецепт.

    Положить в закипевшую воду (0,8 л.) томатную пасту (200 гр.).
    Перемешать.
    Всыпать соль (4 ст. л.), сахар (вдвое меньше), перец черный (5 горошин), лавровый лист (3 штуки).

    Промытую зелень разложить по стерильным литровым банкам.
    Залить кипящим маринадом.
    Стерилизовать 20 мин.
    Закатать.

Черемша с чесноком

Ценителям острых закусок придется по вкусу следующий рецепт.

    В четыре полулитровых банки на дно положить по дольке чеснока, лавровому листу.
    Заполнить черемшой.
    Из литра воды, 250 грамм 9%-ного уксуса, соли и сахара (по 2 ст. л.) сварить маринад.
    Кипящим влить в банки.
    Перед закатыванием стерилизовать 25 мин.

Консервированный медвежий лук

    Промыть черемшу (1 кг.)
    Пропустить через мясорубку.
    Добавить томатную пасту (200 гр.), сахар и соль (по столовой ложке).
    Влить растительное масло (250 мл.).
    Довести получившуюся массу до кипения.
    Снять кастрюлю с плиты через 1 минуту.
    Сразу разложить по стерильным банкам.
    Полулитровые емкости дополнительно стерилизовать 20 минут.
    Закатать.

Соление витаминной зелени

Соленая черемша

Перед тем, как солить черемшу, тщательно переберите зелень. Удалите загрязнения, твердые частицы, подсохшие листики. Затем сырье помойте и выложите на тканевую салфетку для просушки.

Классический рецепт засолки черемши не представляет трудностей, поскольку требует только наличия крупной соли из расчета 4 ст. л. на 2 кг. зелени.

    Подготовленную траву шинкуют на кусочки средней величины.
    Всыпают соль.
    Перетирают массу руками.
    Плотно утрамбовывая, укладывают в предварительно прошедшие стерилизацию банки небольшого объема.
    Закатывают.

Хранится соленая черемша в прохладных условиях – погреб, холодильник. Ее добавляют в салаты, заправляют первые блюда.
Черемша по-корейски

    К ошпаренной колбе (1 кг.) добавляют нашинкованную тонкими полосками сырую морковь.
    Для заливки смешивают сахар (чайную ложку), соль (вдвое меньше), винный уксус (2 столовые ложки), растительное масло (4 столовые ложки), немного специальной приправы по-корейски.
    Вливают готовый маринад в черемшу.
    Распределяют получившуюся массу по стерильным банкам.
    Через три часа кушанье можно употреблять. Если планируется оставить на зиму, банки стерилизуют 15 минут и закатывают.

При правильном употреблении черемша дает возможность быстро адаптироваться после зимнего сезона и избавиться от авитаминоза. Если в доме будут заготовки из этой уникальной травы, можно испытывать на себе ее полезное воздействие в течение всего года, сообщает сайт зож.

Колба (растение) — это… Что такое Колба (растение)?

Черемша́, медве́жий лук, ди́кий чесно́к, колба́ (лат. Állium ursínum) — многолетнее травянистое растение; вид рода Лук семейства Луковые.

Листья используют в пищу в сыром и маринованном виде, в горячих блюдах, в хлебе и пирогах.

Иногда черемшой называют также Лук победный (Allium victoriale)[1].

Распространение и произрастание

Черемша распространена во многих областях Европы, северной Азии, встречается в Северной Америке, на Кавказе, на западе и юго-западе Европейской части России, в Сибири, на Дальнем Востоке, в Беларуси, на севере Украины, в Германии. В диком виде может расти вплоть до тундровой зоны.[2]

Произрастает большей частью в тенистых лесах в долинах вблизи рек, реже культивируется как садовое растение. Наиболее вкусны листья, выращенные при температуре 12–17°С. При температурах выше 20°С вкусовые качества, как и у всех луковых, ухудшаются, особенно при сухой погоде.[3]

Черемшу выращивают как культурное растение, но чаще собирают дикорастущую. Особенно много черемши собирается массово на юге Дальнего Востока, что может привести к истощению природных ресурсов[2]. Размножается семенами (возможно разведение луковицами, но почти не практикуется).

Использование

Кулинария

Листья черемши, которые обычно собирают весной, до того как черемша цветёт, используются как зеленая культура, входят в состав салатов и прочих блюд. Луковицы у черемши малые, в пищу не используются, хотя неядовиты и вреда здоровью при употреблении не принесут. На вкус листья черемши напоминают зелень чеснока и лука, они богаты витамином С.

Молодое растение в лесу в долине Рейна.

Особенно популярна черемша на Кавказе, в Сибири и на Дальнем Востоке, в Германии, в корейской и китайской кухне. В западной части России и на Украине черемша в пищу используется реже. На Кавказе преимущественно используют в горячих блюдах, собирают в предгорных, горных лесах. В Западной Европе распространена, в частности, в Австрии и Германии, где известна под названием Bärlauch (по-немецки дословно: медвежий зелёный лук). В немецком городе Эбербахе (на реке Неккар) ежегодно проводится ряд мероприятий под названием «Эбербахский фестиваль черемши» («Eberbacher Bärlauchtage»)[4], посвящённых черемше и её использованию в кулинарии. В Германии с черемшой также пекут хлеб (нем. Bärlauchbrot[5]) и пироги (нем. Bärlauchkuchen), используют в горячих блюдах, добавляют вместо базилика в особенный вид песто (нем. Bärlauchpesto).

Лекарственное растение

Черемша — древнее лекарственное растение, известное ещё германцам, кельтам и римлянам[6]. При археологических исследованиях в поселениях эпохи неолита в предгории Альп, нередко находили следы черемши, что предполагает её использование ещё 5 000 лет тому назад[6].

Черемша обладает противоглистным и антимикробным действием. Рекомендуется употреблять её при цинге и атеросклерозе, в народной медицине употербляется тысячелетиями, в том числе при лихорадке, как противоглистное и антимикробное средство, как наружное при ревматизме, при различных кишечных инфекционных заболеваниях. В Древнем Риме и в средневековье черемша считалась хорошим средством для очищения желудка и крови.[7][2].

Источники

Ссылки

  • Черемша на сайте kuking.net
  • baerlauch.net(нем.) — германский сайт, посвящённый черемше: «Bärlauch — Ail des Ours — Allium ursinum — wilder Knoblauch».

Wikimedia Foundation. 2010.

Колба (растение) — это… Что такое Колба (растение)?

Черемша́, медве́жий лук, ди́кий чесно́к, колба́ (лат. Állium ursínum) — многолетнее травянистое растение; вид рода Лук семейства Луковые.

Листья используют в пищу в сыром и маринованном виде, в горячих блюдах, в хлебе и пирогах.

Иногда черемшой называют также Лук победный (Allium victoriale)[1].

Распространение и произрастание

Черемша распространена во многих областях Европы, северной Азии, встречается в Северной Америке, на Кавказе, на западе и юго-западе Европейской части России, в Сибири, на Дальнем Востоке, в Беларуси, на севере Украины, в Германии. В диком виде может расти вплоть до тундровой зоны.[2]

Произрастает большей частью в тенистых лесах в долинах вблизи рек, реже культивируется как садовое растение. Наиболее вкусны листья, выращенные при температуре 12–17°С. При температурах выше 20°С вкусовые качества, как и у всех луковых, ухудшаются, особенно при сухой погоде.[3]

Черемшу выращивают как культурное растение, но чаще собирают дикорастущую. Особенно много черемши собирается массово на юге Дальнего Востока, что может привести к истощению природных ресурсов[2]. Размножается семенами (возможно разведение луковицами, но почти не практикуется).

Использование

Кулинария

Листья черемши, которые обычно собирают весной, до того как черемша цветёт, используются как зеленая культура, входят в состав салатов и прочих блюд. Луковицы у черемши малые, в пищу не используются, хотя неядовиты и вреда здоровью при употреблении не принесут. На вкус листья черемши напоминают зелень чеснока и лука, они богаты витамином С.

Молодое растение в лесу в долине Рейна.

Особенно популярна черемша на Кавказе, в Сибири и на Дальнем Востоке, в Германии, в корейской и китайской кухне. В западной части России и на Украине черемша в пищу используется реже. На Кавказе преимущественно используют в горячих блюдах, собирают в предгорных, горных лесах. В Западной Европе распространена, в частности, в Австрии и Германии, где известна под названием Bärlauch (по-немецки дословно: медвежий зелёный лук). В немецком городе Эбербахе (на реке Неккар) ежегодно проводится ряд мероприятий под названием «Эбербахский фестиваль черемши» («Eberbacher Bärlauchtage»)[4], посвящённых черемше и её использованию в кулинарии. В Германии с черемшой также пекут хлеб (нем. Bärlauchbrot[5]) и пироги (нем. Bärlauchkuchen), используют в горячих блюдах, добавляют вместо базилика в особенный вид песто (нем. Bärlauchpesto).

Лекарственное растение

Черемша — древнее лекарственное растение, известное ещё германцам, кельтам и римлянам[6]. При археологических исследованиях в поселениях эпохи неолита в предгории Альп, нередко находили следы черемши, что предполагает её использование ещё 5 000 лет тому назад[6].

Черемша обладает противоглистным и антимикробным действием. Рекомендуется употреблять её при цинге и атеросклерозе, в народной медицине употербляется тысячелетиями, в том числе при лихорадке, как противоглистное и антимикробное средство, как наружное при ревматизме, при различных кишечных инфекционных заболеваниях. В Древнем Риме и в средневековье черемша считалась хорошим средством для очищения желудка и крови.[7][2].

Источники

Ссылки

  • Черемша на сайте kuking.net
  • baerlauch.net(нем.) — германский сайт, посвящённый черемше: «Bärlauch — Ail des Ours — Allium ursinum — wilder Knoblauch».

Wikimedia Foundation. 2010.

Колба (растение) — это… Что такое Колба (растение)?

Черемша́, медве́жий лук, ди́кий чесно́к, колба́ (лат. Állium ursínum) — многолетнее травянистое растение; вид рода Лук семейства Луковые.

Листья используют в пищу в сыром и маринованном виде, в горячих блюдах, в хлебе и пирогах.

Иногда черемшой называют также Лук победный (Allium victoriale)[1].

Распространение и произрастание

Черемша распространена во многих областях Европы, северной Азии, встречается в Северной Америке, на Кавказе, на западе и юго-западе Европейской части России, в Сибири, на Дальнем Востоке, в Беларуси, на севере Украины, в Германии. В диком виде может расти вплоть до тундровой зоны.[2]

Произрастает большей частью в тенистых лесах в долинах вблизи рек, реже культивируется как садовое растение. Наиболее вкусны листья, выращенные при температуре 12–17°С. При температурах выше 20°С вкусовые качества, как и у всех луковых, ухудшаются, особенно при сухой погоде.[3]

Черемшу выращивают как культурное растение, но чаще собирают дикорастущую. Особенно много черемши собирается массово на юге Дальнего Востока, что может привести к истощению природных ресурсов[2]. Размножается семенами (возможно разведение луковицами, но почти не практикуется).

Использование

Кулинария

Листья черемши, которые обычно собирают весной, до того как черемша цветёт, используются как зеленая культура, входят в состав салатов и прочих блюд. Луковицы у черемши малые, в пищу не используются, хотя неядовиты и вреда здоровью при употреблении не принесут. На вкус листья черемши напоминают зелень чеснока и лука, они богаты витамином С.

Молодое растение в лесу в долине Рейна.

Особенно популярна черемша на Кавказе, в Сибири и на Дальнем Востоке, в Германии, в корейской и китайской кухне. В западной части России и на Украине черемша в пищу используется реже. На Кавказе преимущественно используют в горячих блюдах, собирают в предгорных, горных лесах. В Западной Европе распространена, в частности, в Австрии и Германии, где известна под названием Bärlauch (по-немецки дословно: медвежий зелёный лук). В немецком городе Эбербахе (на реке Неккар) ежегодно проводится ряд мероприятий под названием «Эбербахский фестиваль черемши» («Eberbacher Bärlauchtage»)[4], посвящённых черемше и её использованию в кулинарии. В Германии с черемшой также пекут хлеб (нем. Bärlauchbrot[5]) и пироги (нем. Bärlauchkuchen), используют в горячих блюдах, добавляют вместо базилика в особенный вид песто (нем. Bärlauchpesto).

Лекарственное растение

Черемша — древнее лекарственное растение, известное ещё германцам, кельтам и римлянам[6]. При археологических исследованиях в поселениях эпохи неолита в предгории Альп, нередко находили следы черемши, что предполагает её использование ещё 5 000 лет тому назад[6].

Черемша обладает противоглистным и антимикробным действием. Рекомендуется употреблять её при цинге и атеросклерозе, в народной медицине употербляется тысячелетиями, в том числе при лихорадке, как противоглистное и антимикробное средство, как наружное при ревматизме, при различных кишечных инфекционных заболеваниях. В Древнем Риме и в средневековье черемша считалась хорошим средством для очищения желудка и крови.[7][2].

Источники

Ссылки

  • Черемша на сайте kuking.net
  • baerlauch.net(нем.) — германский сайт, посвящённый черемше: «Bärlauch — Ail des Ours — Allium ursinum — wilder Knoblauch».

Wikimedia Foundation. 2010.

Колба (растение) — это… Что такое Колба (растение)?

Черемша́, медве́жий лук, ди́кий чесно́к, колба́ (лат.  Állium ursínum) — многолетнее травянистое растение; вид рода Лук семейства Луковые.

Листья используют в пищу в сыром и маринованном виде, в горячих блюдах, в хлебе и пирогах.

Иногда черемшой называют также Лук победный (Allium victoriale)[1].

Распространение и произрастание

Черемша распространена во многих областях Европы, северной Азии, встречается в Северной Америке, на Кавказе, на западе и юго-западе Европейской части России, в Сибири, на Дальнем Востоке, в Беларуси, на севере Украины, в Германии. В диком виде может расти вплоть до тундровой зоны.[2]

Произрастает большей частью в тенистых лесах в долинах вблизи рек, реже культивируется как садовое растение. Наиболее вкусны листья, выращенные при температуре 12–17°С. При температурах выше 20°С вкусовые качества, как и у всех луковых, ухудшаются, особенно при сухой погоде.[3]

Черемшу выращивают как культурное растение, но чаще собирают дикорастущую. Особенно много черемши собирается массово на юге Дальнего Востока, что может привести к истощению природных ресурсов[2]. Размножается семенами (возможно разведение луковицами, но почти не практикуется).

Использование

Кулинария

Листья черемши, которые обычно собирают весной, до того как черемша цветёт, используются как зеленая культура, входят в состав салатов и прочих блюд. Луковицы у черемши малые, в пищу не используются, хотя неядовиты и вреда здоровью при употреблении не принесут. На вкус листья черемши напоминают зелень чеснока и лука, они богаты витамином С.

Молодое растение в лесу в долине Рейна.

Особенно популярна черемша на Кавказе, в Сибири и на Дальнем Востоке, в Германии, в корейской и китайской кухне. В западной части России и на Украине черемша в пищу используется реже. На Кавказе преимущественно используют в горячих блюдах, собирают в предгорных, горных лесах. В Западной Европе распространена, в частности, в Австрии и Германии, где известна под названием Bärlauch (по-немецки дословно: медвежий зелёный лук). В немецком городе Эбербахе (на реке Неккар) ежегодно проводится ряд мероприятий под названием «Эбербахский фестиваль черемши» («Eberbacher Bärlauchtage»)[4], посвящённых черемше и её использованию в кулинарии. В Германии с черемшой также пекут хлеб (нем. Bärlauchbrot[5]) и пироги (нем. Bärlauchkuchen), используют в горячих блюдах, добавляют вместо базилика в особенный вид песто (нем. Bärlauchpesto).

Лекарственное растение

Черемша — древнее лекарственное растение, известное ещё германцам, кельтам и римлянам[6]. При археологических исследованиях в поселениях эпохи неолита в предгории Альп, нередко находили следы черемши, что предполагает её использование ещё 5 000 лет тому назад[6].

Черемша обладает противоглистным и антимикробным действием. Рекомендуется употреблять её при цинге и атеросклерозе, в народной медицине употербляется тысячелетиями, в том числе при лихорадке, как противоглистное и антимикробное средство, как наружное при ревматизме, при различных кишечных инфекционных заболеваниях. В Древнем Риме и в средневековье черемша считалась хорошим средством для очищения желудка и крови.[7][2].

Источники

Ссылки

  • Черемша на сайте kuking.net
  • baerlauch.net(нем.) — германский сайт, посвящённый черемше: «Bärlauch — Ail des Ours — Allium ursinum — wilder Knoblauch».

Wikimedia Foundation. 2010.

Колба (растение) — это… Что такое Колба (растение)?

Черемша́, медве́жий лук, ди́кий чесно́к, колба́ (лат. Állium ursínum) — многолетнее травянистое растение; вид рода Лук семейства Луковые.

Листья используют в пищу в сыром и маринованном виде, в горячих блюдах, в хлебе и пирогах.

Иногда черемшой называют также Лук победный (Allium victoriale)[1].

Распространение и произрастание

Черемша распространена во многих областях Европы, северной Азии, встречается в Северной Америке, на Кавказе, на западе и юго-западе Европейской части России, в Сибири, на Дальнем Востоке, в Беларуси, на севере Украины, в Германии. В диком виде может расти вплоть до тундровой зоны.[2]

Произрастает большей частью в тенистых лесах в долинах вблизи рек, реже культивируется как садовое растение. Наиболее вкусны листья, выращенные при температуре 12–17°С. При температурах выше 20°С вкусовые качества, как и у всех луковых, ухудшаются, особенно при сухой погоде.[3]

Черемшу выращивают как культурное растение, но чаще собирают дикорастущую. Особенно много черемши собирается массово на юге Дальнего Востока, что может привести к истощению природных ресурсов[2]. Размножается семенами (возможно разведение луковицами, но почти не практикуется).

Использование

Кулинария

Листья черемши, которые обычно собирают весной, до того как черемша цветёт, используются как зеленая культура, входят в состав салатов и прочих блюд. Луковицы у черемши малые, в пищу не используются, хотя неядовиты и вреда здоровью при употреблении не принесут. На вкус листья черемши напоминают зелень чеснока и лука, они богаты витамином С.

Молодое растение в лесу в долине Рейна.

Особенно популярна черемша на Кавказе, в Сибири и на Дальнем Востоке, в Германии, в корейской и китайской кухне. В западной части России и на Украине черемша в пищу используется реже. На Кавказе преимущественно используют в горячих блюдах, собирают в предгорных, горных лесах. В Западной Европе распространена, в частности, в Австрии и Германии, где известна под названием Bärlauch (по-немецки дословно: медвежий зелёный лук). В немецком городе Эбербахе (на реке Неккар) ежегодно проводится ряд мероприятий под названием «Эбербахский фестиваль черемши» («Eberbacher Bärlauchtage»)[4], посвящённых черемше и её использованию в кулинарии. В Германии с черемшой также пекут хлеб (нем. Bärlauchbrot[5]) и пироги (нем. Bärlauchkuchen), используют в горячих блюдах, добавляют вместо базилика в особенный вид песто (нем. Bärlauchpesto).

Лекарственное растение

Черемша — древнее лекарственное растение, известное ещё германцам, кельтам и римлянам[6]. При археологических исследованиях в поселениях эпохи неолита в предгории Альп, нередко находили следы черемши, что предполагает её использование ещё 5 000 лет тому назад[6].

Черемша обладает противоглистным и антимикробным действием. Рекомендуется употреблять её при цинге и атеросклерозе, в народной медицине употербляется тысячелетиями, в том числе при лихорадке, как противоглистное и антимикробное средство, как наружное при ревматизме, при различных кишечных инфекционных заболеваниях. В Древнем Риме и в средневековье черемша считалась хорошим средством для очищения желудка и крови.[7][2].

Источники

Ссылки

  • Черемша на сайте kuking.net
  • baerlauch.net(нем.) — германский сайт, посвящённый черемше: «Bärlauch — Ail des Ours — Allium ursinum — wilder Knoblauch».

Wikimedia Foundation. 2010.

Сезон колбы открыт: что следует знать томичам при выборе этой зелени? » tvtomsk.

ru

Скоро на рынках Томска появится колба (или черемша, как её называют в некоторых регионах). Она относится к травам семейства луковых растений, поэтому иногда можно встретить название «медвежий лук». Повсеместная продажа колбы, собранной в лесах, давно стала одной из примет сибирской весны. Редакция tvtomsk.ru решила узнать у специалистов, безопасна ли «дикая» колба, чем местное растение отличается от привозного, и когда колба появится в лесах нашего региона? Об этом корреспонденту tvtomsk.ru рассказал начальник отдела государственного фитосанитарного надзора Управления Россельхознадзора по Томской области Владислав Азаренко. 

«Колба, конечно, продается сейчас, но это не томская и даже не алтайская — её везут из Краснодарского края и Абхазии. То, что появляется в середине марта, (собирается — ред.) в предгорьях Краснодарского края»,

– Владислав Азаренко.

По словам специалиста, местная колба может появиться в середине мая, но точный срок зависит от погоды: если будет тепло, то колба появится уже в первых числах мая или десятых. Но сначала пойдет привозная колба — алтайская. В этом регионе сезон сбора колбы начинается раньше. 

«Сначала (томская колба) будет мелкой, но наша сибирская колба больше всего ценится […] она богата витаминами и фитонцидами (вещества, которые образуются в растениях и обладают антибактериальными и антимикробными свойствами — ред.)»,

– подчеркнул начальник отдела государственного фитосанитарного надзора.

Как добавил Владислав Азаренко, колбу можно собирать и есть до самой осени. Ранняя колба по химическому составу не отличается от поздней, она не будет вредной и  сохранит свои полезные свойства, но со временем растение становится жестче, его тяжелее пережевывать. 

Что касается безопасности колбы, которую собрали в лесах Томской области, представитель Россельхознадзора отметил, что она экологически чистая и безопасная, более того, это растение -«кладезь витаминов».

«Колба, собранная в нашем регионе, всегда безопасна: она обычно произрастает в экологически чистых местах, низменностях, болотах, в грязных местах она точно расти не будет. Поэтому по качеству она безопасна»,

– рассказал Азаренко.

На вопрос, можно ли собирать колбу у обочин дорог, специалист ответил, что сама вероятность того, что колба вырастет в таком месте, достаточно низкая.

«Она любит более влажную почву, у болот, например. Конечно, если её собрали вдоль дороги, она напитается тяжелыми металлами. И узнать и увидеть, что она ими напиталась, не сделав химический анализ, невозможно. Документов на неё точно нет. То, что продают частные лица, которые собирают её, никуда не сдают на исследования. Если только она попадет в магазин, там это (документы, подтверждающие качество — ред.) — обязательное требование […] а то, что на дороге, это уже на свой страх и риск»,

– уточнил собеседник tvtomsk.ru.

Как добавил Владислав Азаренко, алтайская колба может появиться в Томске уже «дней через десять». Если речь идет о ранней колбе, то лучше выбирать алтайскую, чем краснодарскую: к тому времени, как она попадет в Томск, срок её сбора уже пройдет, и она будет с грубыми волокнами.  

С другой стороны, несмотря на то, что местная колба является полезным продуктом и безопасна для здоровья человека, сборщики подвергают себя другому риску: сезон сбора колбы совпадает с пиком активности клещей.

«У нас начинается клещевой сезон. Это более серьезная опасность. Даже лучше её (колбу — ред.) собрать у обочины дороги, чем пойти в лес. Это самый пик выхода клещей. Люди, которые пойдут собирать колбу (не имея опыта — ред.), подвергают себя большой опасности. Опытные сборщики знают, как себя обезопасить, потому что занимаются этим из года в год, они знают места, где собирать»,

– рассказал Владислав Азаренко.

Редакция tvtomsk.ru также уточнила информацию о безопасности привозной колбы из Краснодарского края в пресс-службе регионального Управления Роспотребнадзора. 

«Колба в г. Томск поступает из Краснодарского края через оптовый овощной рынок, расположенный на пр. Мира,4, контроль качества осуществляет лаборатория ветсанэкспертизы ОГБУ «Томское объединение ветеринарии». Жалоб от населения на качество не поступало»,

– сообщили в региональном Роспотребнадзоре.

© При полном или частичном использовании материалов в интернете и печатных СМИ ссылка на tvtomsk.ru обязательна. Отсутствие ссылки, либо ссылка на иной источник (Вести-Томск, ГТРК «Томск» и др.) является нарушением прав на интеллектуальную собственность.

Нашли в тексте ошибку? Выделите её, нажмите Ctrl + Enter

Купите Цветной террариум с круглой колбой (4 дюйма) онлайн в магазине Nurserylive по самой низкой цене.

Описание

Украсьте свой стол или дом красочным террариумом из круглой колбы.

Примечание: — Продукция изготавливается на заказ и будет доставлена ​​вручную в течение недели после размещения заказа. Цветной террариум с круглой колбой — это коллекция растений, растущих в стеклянной таре. Этот террариум представляет собой набор небольших растений, растущих в прозрачном герметичном контейнере.

Небольшой комнатный садик в стеклянной таре сделать несложно. Этот террариум содержит контейнер круглой формы с мелкими растениями, галькой, игрушкой, горшечной средой и т. Д. По внешнему виду он похож на миниатюрные сцены сада. Высота горшка: прибл. 4 дюйма (10 см). Диаметр открытия: прибл. 5 дюймов (6,3 см).

Технические характеристики завода

* выше спецификации являются только ориентировочными. фактические размеры могут отличаться на + -10%

Общее название Круглая колба красочный террариум
Максимальная достижимая высота До 10 см (Растение)
Время цветения NA
Уровень сложности Легко выращивать

Посадка и уход

  • Обрежьте кончики нервных растений, чтобы получилось более густое растение.
  • Опрыскивайте почву водой один раз в две недели из пульверизатора.
  • Избегать опрыскивания растений.
  • В этом контейнере для террариума нет дренажного отверстия или отверстий, избегайте применения большого количества воды.
  • Обеспечьте яркость при непрямом солнечном свете или вблизи источников искусственного света.
  • Почва не должна быть влажной или сырой, так как это приведет к гниению.
  • Стеклянные стены должны пропускать свет на растения и быть чистыми от пыли, сквозняков и перепадов температур.
  • Если на внутренней стороне контейнера слишком много влаги, и вы не можете видеть свои растения, то временно откройте крышку, чтобы дать ему высохнуть.
  • Избегайте попадания слишком большого количества прямых солнечных лучей на контейнер; он может обжечь растения, а стеклянный контейнер может сильно нагреться.

    Круглая колба для ухода за красочным террариумом

    Следует использовать водорастворимые органические удобрения в небольшом количестве. Не применяйте в большом количестве; это будет способствовать большему вегетативному росту. Мы сохраняем небольшие размеры растений в террариуме.Так мы должны контролировать вегетативный рост.

    Если есть необходимость в повторной заливке, то заливочная среда должна иметь следующий слой от полутора до двух дюймов на дне контейнера. Почва должна быть пористой, чтобы обеспечить хороший дренаж. Для посадки он должен быть слегка влажным. В равных частях садовая земля, песок и торфяной мох (1: 1: 1).

    Солнечный свет Яркая зона с непрямым солнечным светом
    Полив Экономно
    Почва Почва, песок и торф (1: 1: 1)
    Температура от 20 до 25 градусов Цельсия
    Удобрение Жидкие удобрения

    Яркий террариум в круглой колбе. Особенность

    Благоустроенный, благоустроенный террариум

    Цветной террариум с круглой колбой использует

    Использование в декоративных целях:

    • Используется для декоративных целей
  • выращивающих орхидей из колбы | Питомник орхидей Такера

    Процедуры удаления колбы

    Скачать брошюру PDF >>

    Удаление флакона — это немного сложный процесс, но он очень полезен, когда вы видите, что ваши маленькие растения растут. Оптимальное время для опорожнения — весна, когда погода начинает нагреваться и наступает период «весеннего роста». Взгляните на свои фруктовые деревья и посмотрите, когда они начнут цвести и отрастить листья. Последнее предпочтительное время распаковки — с конца лета до начала осени, чтобы у них было достаточно времени, чтобы они «застыли» до того, как начнутся холода.

    После получения флаконов оставьте их на пару недель в месте, где они будут попадать под яркий свет, но не под прямыми солнечными лучами.Подоконник, выходящий на юг, или в защищенной теплице — два подходящих места. Причина в том, чтобы растения начали фотосинтез. Вы начнете замечать образование конденсата внутри банки. После фотосинтеза растения после посадки в горшках уже будут иметь преимущество в выращивании и питании сами по себе, а не за счет сахара, содержащегося в агаре. За день или два до того, как вы будете готовы очистить свои растения от флакона, отвинтите крышку и оставьте растение свободно лежать на банке. Это приведет к акклиматизации растений в их новом доме.

    Для начала смешайте таз теплой воды и фунгицида (следуя инструкциям на упаковке). Осторожно достаньте растения из колбы, стараясь не повредить корни. Промойте растения в растворе фунгицида, смыв с корней все остатки агара и аккуратно отделив растения. Слейте воду с растений и оставьте сохнуть на газетном или бумажном полотенце примерно на 15-30 минут. Посадите их целиком в горшок, который примерно вдвое меньше колбы, из которой они вылезли.Расстояние между растениями должно составлять около 1 см. Используйте регидратированный мох сфагнум с длинными прядями или кору орхидеи номер 2 (5-10 мм), замоченную на ночь. Прикрепите этикетку к горшку с названием растения с одной стороны и датой снятия с флакона с другой. Для этого рекомендуется использовать карандаш HB, так как он водостойкий и не выцветает.

    Поместите горшок обратно в теплицу в защищенный угол, где он будет получать хороший свет, но без прямых солнечных лучей, а также с хорошей циркуляцией воздуха, но не с холода. Если вы решите очистить колбу перед зимой, растениям потребуется защита от холода. Не позволяйте температуре опускаться ниже 5oC за ночь. После посадки вы можете поместить горшок в пластиковый пакет большего размера с замком на молнии. Закройте пакет, оставив примерно 2-3 см расстегнутыми. Это помогает создать микросреду для молодых растений. Альтернативой было бы выращивание их зимой в помещении. Вы по-прежнему можете использовать полиэтиленовый пакет для создания микросреды в помещении.

    Растения должны оставаться в этом первоначальном горшке примерно 3-6 месяцев.Поливайте их примерно один или два раза в неделю, поочередно подкармливая слабым раствором азотных удобрений, таких как Growing Orchid Tucker. Вы хотите, чтобы смесь (кора или мох) была равномерно влажной без полного насыщения. Частота полива будет колебаться в зависимости от температуры и скорости испарения. Убедитесь, что на дне горшка нет воды, так как корни должны дышать. Если вы заметили коричневые кончики или пятна на листьях, опрыскайте растения раствором фунгицида.

    Как только растения вырастут примерно в два раза, их можно высаживать в отдельные горшки. Мы используем квадратные горшки 5-7 см для небольших растений и квадратные или круглые горшки 10 см для более крупных растений. На этом этапе посадите их либо в кору номер 2, либо в кору номер 3. Поддерживайте тот же режим полива и подкормки, но увеличивайте количество удобрений до полной дозировки. Также поддерживайте фунгицидный режим по мере необходимости. Примерно через месяц, при условии, что погода не слишком холодная, переместите растения в среду их окончательного выращивания в зависимости от потребностей типа орхидеи.Для каждого нового горшка потребуется этикетка с названием растения и датой посадки на обратной стороне.

    Помните, дождь действует как полив для уличных растений. Если у вас сильный дождь, уменьшите полив. Если у вас высокие температуры и сильное испарение, увеличьте частоту полива. Точно так же низкие температуры означают меньший полив. Следите за растениями и пересаживайте их в горшок следующего размера, когда они начнут перерастать свой нынешний. Добавьте дату новой посадки на обратную сторону этикетки.Затем вы можете легко отслеживать, когда вы в последний раз посадили это растение в горшок. У вас должно получиться почти цветущее или цветущее растение в горшке диаметром 15 см примерно через 2 ½ — 4 года, в зависимости от типа орхидеи. На этом этапе начните использовать Tucker для цветущих орхидей в соответствии с инструкциями, чтобы помочь зачатию цветков.

    Мерная колба

    , размер опытной установки, Ace Glass Incorporated

    Положения и условия

    Спасибо, что посетили наш сайт. Эти условия использования применимы к веб-сайтам США, Канады и Пуэрто-Рико (далее «Веб-сайт»), которыми управляет VWR («Компания»).Если вы заходите на веб-сайт из-за пределов США, Канады или Пуэрто-Рико, пожалуйста, посетите соответствующий международный веб-сайт, доступный по адресу www.vwr.com, для ознакомления с применимыми условиями. Все пользователи веб-сайта подчиняются следующим условиям использования веб-сайта (эти «Условия использования»). Пожалуйста, внимательно прочтите эти Условия использования перед доступом или использованием любой части веб-сайта. Заходя на веб-сайт или используя его, вы соглашаетесь с тем, что вы прочитали, понимаете и соглашаетесь соблюдать настоящие Условия использования с внесенными в него время от времени поправками, а также Политику конфиденциальности компании, которая настоящим включена в настоящие Условия. использования. Если вы не желаете соглашаться с настоящими Условиями использования, не открывайте и не используйте какие-либо части веб-сайта.

    Компания может пересматривать и обновлять настоящие Условия использования в любое время без предварительного уведомления, разместив измененные условия на веб-сайте. Продолжение использования вами веб-сайта означает, что вы принимаете и соглашаетесь с пересмотренными Условиями использования. Если вы не согласны с Условиями использования (в которые время от времени вносятся поправки) или недовольны Веб-сайтом, ваше единственное и исключительное средство правовой защиты — прекратить использование Веб-сайта.

    Использование сайта

    Информация, содержащаяся на этом веб-сайте, предназначена только для информационных целей. Хотя считается, что информация верна на момент публикации, вам следует самостоятельно определить ее пригодность для вашего использования. Не все продукты или услуги, описанные на этом веб-сайте, доступны во всех юрисдикциях или для всех потенциальных клиентов, и ничто в настоящем документе не предназначено как предложение или ходатайство в какой-либо юрисдикции или какому-либо потенциальному покупателю, где такое предложение или продажа не соответствует требованиям.

    Приобретение товаров и услуг

    Настоящие Условия и положения распространяются только на использование веб-сайта. Обратите внимание, что условия, касающиеся обслуживания, продаж продуктов, рекламных акций и других связанных мероприятий, можно найти по адресу https://us.vwr.com/store/content/externalContentPage.jsp?path=/en_US/about_vwr_terms_and_conditions. jsp , и эти условия регулируют любые покупки продуктов или услуг у Компании.

    Интерактивные функции

    Веб-сайт может содержать службы досок объявлений, области чата, группы новостей, форумы, сообщества, личные веб-страницы, календари и / или другие средства сообщения или связи, предназначенные для того, чтобы вы могли общаться с общественностью в целом или с группой ( вместе «Функция сообщества»).Вы соглашаетесь использовать функцию сообщества только для публикации, отправки и получения сообщений и материалов, которые являются надлежащими и относятся к конкретной функции сообщества. Вы соглашаетесь использовать веб-сайт только в законных целях.

    A. В частности, вы соглашаетесь не делать ничего из следующего при использовании функции сообщества:

    1. Оскорблять, оскорблять, преследовать, преследовать, угрожать или иным образом нарушать законные права (например, право на неприкосновенность частной жизни и гласность) других.
    2. Публиковать, размещать, загружать, распространять или распространять любую неуместную, непристойную, дискредитирующую, нарушающую авторские права, непристойную, непристойную или незаконную тему, название, материал или информацию.
    3. Загружайте файлы, содержащие программное обеспечение или другие материалы, защищенные законами об интеллектуальной собственности (или правами на неприкосновенность частной жизни), если только вы не владеете или не контролируете права на них или не получили все необходимое согласие.
    4. Загрузите файлы, содержащие вирусы, поврежденные файлы или любое другое подобное программное обеспечение или программы, которые могут повредить работу чужого компьютера.
    5. Перехватить или попытаться перехватить электронную почту, не предназначенную для вас.
    6. Рекламировать или предлагать продавать или покупать какие-либо товары или услуги для любых деловых целей, если такая функция сообщества специально не разрешает такие сообщения.
    7. Проводите или рассылайте опросы, конкурсы, финансовые пирамиды или письма счастья.
    8. Загрузите любой файл, опубликованный другим пользователем функции сообщества, который, как вы знаете или разумно должен знать, не может распространяться на законных основаниях таким образом или что у вас есть договорное обязательство сохранять конфиденциальность (несмотря на его доступность на веб-сайте).
    9. Подделывать или удалять любые ссылки на автора, юридические или другие надлежащие уведомления, обозначения собственности или ярлыки происхождения или источника программного обеспечения или других материалов, содержащихся в загружаемом файле.
    10. Предоставление ложной информации о принадлежности к какому-либо лицу или организации.
    11. Участвовать в любых других действиях, которые ограничивают или препятствуют использованию веб-сайта кем-либо или которые, по мнению Компании, могут нанести вред Компании или пользователям веб-сайта или подвергнуть их ответственности.
    12. Нарушать любые применимые законы или постановления или нарушать любой кодекс поведения или другие правила, которые могут быть применимы к какой-либо конкретной функции Сообщества.
    13. Собирать или иным образом собирать информацию о других, включая адреса электронной почты, без их согласия.

    B. Вы понимаете и признаете, что несете ответственность за любой контент, который вы отправляете, вы, а не Компания, несете полную ответственность за такой контент, включая его законность, надежность и уместность. Если вы публикуете сообщения от имени или от имени вашего работодателя или другой организации, вы заявляете и гарантируете, что у вас есть на это право. Загружая или иным образом передавая материалы в любую область веб-сайта, вы гарантируете, что эти материалы являются вашими собственными или находятся в общественном достоянии или иным образом свободны от проприетарных или иных ограничений и что вы имеете право размещать их на веб-сайте.Кроме того, загружая или иным образом передавая материал в любую область веб-сайта, вы предоставляете Компании безотзывное, бесплатное право во всем мире на публикацию, воспроизведение, использование, адаптацию, редактирование и / или изменение таких материалов любым способом, в любые и все средства массовой информации, известные в настоящее время или обнаруженные в будущем по всему миру, в том числе в Интернете и World Wide Web, для рекламных, коммерческих, торговых и рекламных целей, без дополнительных ограничений или компенсации, если это не запрещено законом, и без уведомления, проверки или одобрения.

    C. Компания оставляет за собой право, но не принимает на себя никакой ответственности (1) удалить любые материалы, размещенные на веб-сайте, которые Компания по своему собственному усмотрению сочтет несовместимыми с вышеуказанными обязательствами или иным образом неприемлемыми по любой причине. ; и (2) прекратить доступ любого пользователя ко всему или к части веб-сайта. Однако Компания не может ни просмотреть все материалы до того, как они будут размещены на веб-сайте, ни обеспечить быстрое удаление нежелательных материалов после их размещения.Соответственно, Компания не несет ответственности за какие-либо действия или бездействие в отношении передач, сообщений или контента, предоставленных третьими сторонами. Компания оставляет за собой право предпринимать любые действия, которые она сочтет необходимыми для защиты личной безопасности пользователей этого веб-сайта и общественности; тем не менее, Компания не несет ответственности перед кем-либо за выполнение или невыполнение действий, описанных в этом параграфе.

    D. Несоблюдение вами положений пунктов (A) или (B) выше может привести к прекращению вашего доступа к веб-сайту и может подвергнуть вас гражданской и / или уголовной ответственности.

    Особое примечание о содержании функций сообщества

    Любой контент и / или мнения, загруженные, выраженные или отправленные через любую функцию сообщества или любой другой общедоступный раздел веб-сайта (включая области, защищенные паролем), а также все статьи и ответы на вопросы, кроме контента, явно разрешенного Компания, являются исключительно мнениями и ответственностью лица, представляющего их, и не обязательно отражают мнение Компании.Например, любое рекомендованное или предлагаемое использование продуктов или услуг, доступных от Компании, которое публикуется через функцию сообщества, не является признаком одобрения или рекомендации со стороны Компании. Если вы решите следовать какой-либо такой рекомендации, вы делаете это на свой страх и риск.

    Ссылки на сторонние сайты

    Веб-сайт может содержать ссылки на другие веб-сайты в Интернете. Компания не несет ответственности за контент, продукты, услуги или методы любых сторонних веб-сайтов, включая, помимо прочего, сайты, связанные с Веб-сайтом или с него, сайты, созданные на Веб-сайте, или стороннюю рекламу, и не делает заявлений относительно их качество, содержание или точность.Наличие ссылок с веб-сайта на любой сторонний веб-сайт не означает, что мы одобряем, поддерживаем или рекомендуем этот веб-сайт. Мы отказываемся от всех гарантий, явных или подразумеваемых, в отношении точности, законности, надежности или действительности любого контента на любых сторонних веб-сайтах. Вы используете сторонние веб-сайты на свой страх и риск и в соответствии с условиями использования таких веб-сайтов.

    Права собственности на контент

    Вы признаете и соглашаетесь с тем, что все содержимое веб-сайта (включая всю информацию, данные, программное обеспечение, графику, текст, изображения, логотипы и / или другие материалы) и его дизайн, выбор, сбор, расположение и сборка являются являются собственностью Компании и защищены законами США и международными законами об интеллектуальной собственности. Вы имеете право использовать содержимое веб-сайта только в личных или законных деловых целях. Вы не можете копировать, изменять, создавать производные работы, публично демонстрировать или исполнять, переиздавать, хранить, передавать, распространять, удалять, удалять, дополнять, добавлять, участвовать в передаче, лицензировать или продавать какие-либо материалы в Интернете. Сайт без предварительного письменного согласия Компании, за исключением: (а) временного хранения копий таких материалов в ОЗУ, (б) хранения файлов, которые автоматически кэшируются вашим веб-браузером в целях улучшения отображения, и (в) печати разумного количество страниц веб-сайта; в каждом случае при условии, что вы не изменяете и не удаляете какие-либо уведомления об авторских правах или других правах собственности, включенные в такие материалы.Ни название, ни какие-либо права интеллектуальной собственности на любую информацию или материалы на веб-сайте не передаются вам, а остаются за Компанией или соответствующим владельцем такого контента.

    Товарные знаки

    Название и логотип компании, а также все связанные названия, логотипы, названия продуктов и услуг, появляющиеся на веб-сайте, являются товарными знаками компании и / или соответствующих сторонних поставщиков. Их нельзя использовать или повторно отображать без предварительного письменного согласия Компании.

    Отказ от ответственности

    Компания не несет никакой ответственности за материалы, информацию и мнения, предоставленные или доступные через Веб-сайт («Контент сайта»). Вы полагаетесь на Контент сайта исключительно на свой страх и риск. Компания не несет никакой ответственности за травмы или ущерб, возникшие в результате использования любого Контента Сайта.
    ВЕБ-САЙТ, СОДЕРЖАНИЕ САЙТА И ПРОДУКТЫ И УСЛУГИ, ПРЕДОСТАВЛЯЕМЫЕ ИЛИ ДОСТУПНЫЕ ЧЕРЕЗ САЙТ, ПРЕДОСТАВЛЯЮТСЯ НА УСЛОВИЯХ «КАК ЕСТЬ» И «ПО ДОСТУПНОСТИ», СО ВСЕМИ ОШИБКАМИ.КОМПАНИЯ И НИ ЛИБО, СВЯЗАННОЕ С КОМПАНИЕЙ, НЕ ДАЕТ НИКАКИХ ГАРАНТИЙ ИЛИ ЗАЯВЛЕНИЙ В ОТНОШЕНИИ КАЧЕСТВА, ТОЧНОСТИ ИЛИ ДОСТУПНОСТИ ВЕБ-САЙТА. В частности, НО БЕЗ ОГРАНИЧЕНИЯ ВЫШЕИЗЛОЖЕННОГО, НИ КОМПАНИЯ И НИ ЛИБО, СВЯЗАННОЕ С КОМПАНИЕЙ, НЕ ГАРАНТИРУЕТ ИЛИ ЗАЯВЛЯЕТ, ЧТО ВЕБ-САЙТ, СОДЕРЖАНИЕ САЙТА ИЛИ УСЛУГИ, ПРЕДОСТАВЛЯЕМЫЕ НА САЙТЕ ИЛИ ЧЕРЕЗ САЙТ, БУДУТ ТОЧНЫМИ, НАДЕЖНЫМИ ИЛИ БЕСПЛАТНЫМИ ИЛИ БЕСПЛАТНЫМИ ЧТО ДЕФЕКТЫ БУДУТ ИСПРАВЛЕНЫ; ЧТО ВЕБ-САЙТ ИЛИ СЕРВЕР, ДЕЛАЮЩИЙ ЕГО ДОСТУПНЫМ, СВОБОДНЫ ОТ ВИРУСОВ ИЛИ ДРУГИХ ВРЕДНЫХ КОМПОНЕНТОВ; ИНАЧЕ ВЕБ-САЙТ ОТВЕЧАЕТ ВАШИМ ПОТРЕБНОСТЯМ ИЛИ ОЖИДАНИЯМ.КОМПАНИЯ ОТКАЗЫВАЕТСЯ ОТ ВСЕХ ГАРАНТИЙ, ЯВНЫХ ИЛИ ПОДРАЗУМЕВАЕМЫХ, ВКЛЮЧАЯ ЛЮБЫЕ ГАРАНТИИ КОММЕРЧЕСКОЙ ЦЕННОСТИ, ПРИГОДНОСТИ ДЛЯ ОПРЕДЕЛЕННОЙ ЦЕЛИ И НЕ НАРУШЕНИЯ.
    НИ ПРИ КАКИХ ОБСТОЯТЕЛЬСТВАХ КОМПАНИЯ ИЛИ ЕЕ ЛИЦЕНЗИАРЫ ИЛИ ПОДРЯДЧИКИ НЕ НЕСЕТ ОТВЕТСТВЕННОСТИ ЗА ЛЮБЫЕ УБЫТКИ ЛЮБОГО РОДА, ПРИ КАКИХ-ЛИБО ЮРИДИЧЕСКИХ ТЕОРИЯХ, ВОЗНИКАЮЩИЕ ИЛИ В СВЯЗИ С ИСПОЛЬЗОВАНИЕМ ВАМИ ИЛИ НЕВОЗМОЖНОСТЬЮ ИСПОЛЬЗОВАТЬ ВЕБ-САЙТ, СОДЕРЖИМОЕ САЙТА, ЛЮБЫЕ УСЛУГИ, ПРЕДОСТАВЛЯЕМЫЕ НА САЙТЕ ИЛИ ЧЕРЕЗ ВЕБ-САЙТ ИЛИ ЛЮБОЙ САЙТ, ВКЛЮЧАЮЩИЙ ПРЯМЫЙ, КОСВЕННЫЙ, СЛУЧАЙНЫЙ, СПЕЦИАЛЬНЫЙ, КОСВЕННЫЙ ИЛИ КАРАТЕЛЬНЫЙ УБЫТК, ВКЛЮЧАЯ, НО НЕ ОГРАНИЧИВАЯСЬ, ЛИЧНЫЕ ТРАВМЫ, ПОТЕРЯ ПРИБЫЛИ ИЛИ УБЫТКОВ , ВИРУСЫ, УДАЛЕНИЕ ФАЙЛОВ ИЛИ ЭЛЕКТРОННЫХ СООБЩЕНИЙ, ИЛИ ОШИБКИ, УПУЩЕНИЯ ИЛИ ДРУГИЕ НЕТОЧНОСТИ НА ВЕБ-САЙТЕ ИЛИ СОДЕРЖАНИИ САЙТА ИЛИ УСЛУГАХ, БЕЗОПАСНОСТЬ КОМПАНИИ ИЛИ НЕОБХОДИМО ЛИ ПРЕДОСТАВЛЕНИЕ ЛЮБЫЕ ТАКИЕ УБЫТКИ, ЕСЛИ НЕ ЗАПРЕЩЕНЫ ПРИМЕНИМЫМ ЗАКОНОДАТЕЛЬСТВОМ.

    Компенсация

    Вы соглашаетесь возместить и обезопасить Компанию и ее должностных лиц, директоров, агентов, сотрудников и других лиц, участвующих в веб-сайте, от любых обязательств, расходов, убытков и издержек, включая разумные гонорары адвокатам, возникающих в результате любое нарушение вами настоящих Условий использования, использование вами Веб-сайта или любых продуктов, услуг или информации, полученных с Веб-сайта или через него, ваше подключение к Веб-сайту, любой контент, который вы отправляете на Веб-сайт через любые Функция сообщества или нарушение вами каких-либо прав другого лица.

    Применимое право; Международное использование

    Настоящие условия регулируются и толкуются в соответствии с законами штата Пенсильвания без учета каких-либо принципов коллизионного права. Вы соглашаетесь с тем, что любые судебные иски или иски, вытекающие из настоящих Условий использования или связанные с ними, будут подаваться исключительно в суды штата или федеральные суды, расположенные в Пенсильвании, и вы тем самым соглашаетесь и подчиняетесь личной юрисдикции таких судов для цели судебного разбирательства по любому подобному действию.
    Настоящие Условия использования применимы к пользователям в США, Канаде и Пуэрто-Рико. Если вы заходите на веб-сайт из-за пределов США, Канады или Пуэрто-Рико, пожалуйста, посетите соответствующий международный веб-сайт, доступный по адресу www.vwr.com, для ознакомления с применимыми условиями. Если вы решите получить доступ к этому веб-сайту из-за пределов указанных юрисдикций, а не использовать доступные международные сайты, вы соглашаетесь с настоящими Условиями использования и тем, что такие условия будут регулироваться и толковаться в соответствии с законами США и штата. Пенсильвании и что мы не делаем никаких заявлений о том, что материалы или услуги на этом веб-сайте подходят или доступны для использования в этих других юрисдикциях.В любом случае все пользователи несут ответственность за соблюдение местных законов.

    Общие условия

    Настоящие Условия использования, в которые время от времени могут вноситься поправки, представляют собой полное соглашение и понимание между вами и нами, регулирующее использование вами Веб-сайта. Наша неспособность реализовать или обеспечить соблюдение какого-либо права или положения Условий использования не означает отказ от такого права или положения. Если какое-либо положение Условий использования будет признано судом компетентной юрисдикции недействительным, вы, тем не менее, соглашаетесь с тем, что суд должен попытаться реализовать намерения сторон, отраженные в этом положении и других положениях Условия использования остаются в полной силе.Ни ваши деловые отношения, ни поведение между вами и Компанией, ни какая-либо торговая практика не может считаться изменением настоящих Условий использования. Вы соглашаетесь с тем, что независимо от какого-либо закона или закона об обратном, любые претензии или основания для иска, вытекающие из или связанные с использованием Сайта или Условий использования, должны быть поданы в течение одного (1) года после такой претензии или причины. иска возникла или будет навсегда запрещена. Любые права, прямо не предоставленные в настоящем документе, сохраняются за Компанией. Мы можем прекратить ваш доступ или приостановить доступ любого пользователя ко всему сайту или его части без предварительного уведомления за любое поведение, которое мы, по нашему собственному усмотрению, считаем нарушением любого применимого законодательства или наносящим ущерб интересам другого пользователя. , стороннего поставщика, поставщика услуг или нас. Любые вопросы, касающиеся настоящих Условий использования, следует направлять по адресу [email protected].

    Жалобы на нарушение авторских прав

    Мы уважаем чужую интеллектуальную собственность и просим наших пользователей поступать так же.Если вы считаете, что ваша работа была скопирована и доступна на Сайте способом, который представляет собой нарушение авторских прав, вы можете уведомить нас, предоставив нашему агенту по авторским правам следующую информацию:

    • электронная или физическая подпись лица, уполномоченного действовать от имени правообладателя;

    • описание работы, защищенной авторским правом, в отношении которой были нарушены ваши претензии;

    • идентификация URL-адреса или другого конкретного места на Сайте, где находится материал, который, по вашему мнению, нарушает авторские права;

    • ваш адрес, номер телефона и адрес электронной почты;

    • ваше заявление о том, что вы добросовестно полагаете, что спорное использование не разрешено владельцем авторских прав, его агентом или законом; а также

    • ваше заявление, сделанное под страхом наказания за лжесвидетельство, о том, что приведенная выше информация в вашем уведомлении является точной и что вы являетесь владельцем авторских прав или уполномочены действовать от имени владельца авторских прав.

    С нашим агентом для уведомления о жалобах на нарушение авторских прав на Сайте можно связаться по адресу: [email protected].

    Создание приложения IoT с помощью InfluxDB Cloud, Python и Flask (часть 3)

    В прошлом году я начал проект Интернета вещей, Plant Buddy. Этот проект включал в себя припаивание некоторых датчиков к Arduino и обучение этого устройства тому, как напрямую общаться с InfluxDB Cloud, чтобы я мог контролировать эти растения. Теперь я развиваю эту концепцию и пишу приложение для plantbuddy.com. Это приложение позволит пользователям визуализировать и создавать предупреждения на основе загруженных данных устройства Plant Buddy в индивидуальном пользовательском интерфейсе.

    Если вам нужна дополнительная информация, вы можете ознакомиться с частью 1, где я разрабатываю основы устройства и учу его общаться и добавлять уведомления, а также в части 2, где я начинаю использовать понижающую дискретизацию и панель инструментов. (В части 4 Барбара Нельсон представляет продолжение этой статьи, в котором она показывает, как использовать пользовательский интерфейс, а не интерфейс командной строки, для тех же функций.)

    Цели (на основе InfluxDB Cloud)

    Это руководство написано специально для разработчиков приложений.Я использую Python и Flask для этого урока, но все концепции должны в равной степени применяться к любому языку или фреймворку веб-разработки.

    Этот учебник будет охватывать:

    1. Как запустить среду разработки, чтобы начать разработку в InfluxDB Cloud
    2. Как использовать клиентскую библиотеку InfluxDB Python для получения данных от пользователей и записи этих данных в InfluxDB Cloud
    3. Как запросить InfluxDB Cloud, чтобы ваше приложение могло визуализировать данные для ваших пользователей.
    4. Как установить задачу понижающей дискретизации в InfluxDB, которая сэкономит вам деньги на хранении, а также оптимизирует взаимодействие с пользователем для ваших пользователей
    5. Как использовать мощную систему «Проверок и уведомлений» InfluxDB Cloud для предоставления настраиваемых предупреждений пользователям

    Это руководство предназначено для сосредоточения на InfluxDB, а не на приложениях IoT в целом, поэтому я не буду сосредотачиваться на таких вещах, как:

    1. Создание вашего устройства и отправка с него данных
    2. Авторизация пользователя для вашего собственного веб-приложения
    3. Управление секретами в собственном веб-приложении
    4. Как использовать множество мощных библиотек визуализации для разных платформ

    Где код?

    Код этого руководства доступен на GitHub. Есть два филиала:

    1. Если вы хотите увидеть только начальную точку, то это ветка demo-start.
    2. Если вы хотите увидеть завершенный проект, то он находится в ветке demo-done.

    plantbuddy.com Обзор

    Стратегии сегментации данных

    Прежде чем мы начнем загрузку среды разработки, вот немного пищи для размышлений относительно того, можно ли и как сегментировать ваши пользовательские данные. Этот раздел довольно концептуален, поэтому вы можете пропустить его.

    Скорее всего, у вашего приложения будет много пользователей. Обычно вы хотите отображать каждому пользователю только те данные, которые он ввел в приложение. В зависимости от масштаба вашего приложения и других потребностей можно рассмотреть 3 общих подхода.

    1. Однопользовательский ковш. Это подход по умолчанию. В этом подходе вы помещаете все данные своих пользователей в одну корзину в InfluxDB и используете разные теги для каждого пользователя, чтобы обеспечить быстрое выполнение запросов.
    2. Ковш на пользователя. В этом подходе вы создаете отдельную корзину для каждого пользователя. Этот подход более сложен для управления в вашем приложении, но позволяет вам предоставлять маркеры чтения и записи вашим пользователям, чтобы они могли читать и писать прямо из своего собственного сегмента, если это необходимо для вашего приложения.
    3. Мультиорганизационная. В этом подходе вы создаете отдельную организацию для каждого пользователя. Это обеспечивает полное разделение данных о клиентах, но его сложнее настроить и управлять.Этот подход полезен, когда вы действуете как своего рода OEM, где у ваших клиентов есть собственные клиенты, и вам необходимо предоставить инструменты управления своим клиентам.
    Подход Плюсы Минусы Сводка
    Многопользовательский сегмент
    • Легко агрегировать между клиентами
    • Самый простой в настройке
    • Требуется аутентификация через пользовательский шлюз
    • Работа с пассажирами за бортом
    • Единая политика хранения для всех клиентов
    Подход по умолчанию, с использованием тегов для сегментирования клиентов в одной корзине
    Ковш на пользователя
    • Чтение и запись без шлюза
    • Несколько RP
    • Легко отвлечь клиентов
    • Сложнее агрегировать по клиентам
    • Усилия по управлению
    Полезно, когда сегментация данных о клиентах важна, но требует больших усилий. Разрешает прямое чтение и запись.
    Мультиорганизация
    • Сегментация полных данных и вычислений
    • Дополнительный уровень сложности
    Окончательный вариант сегментации данных о клиентах. Полезно, когда у ваших клиентов есть свои клиенты.

    Из-за относительно простой и низкочувствительной природы Plant Buddy подход многопользовательского ведра по умолчанию имеет наибольший смысл. У Plant Buddy довольно простая схема.Но если вам интересно узнать больше об этих темах, вы можете прочитать здесь о макете данных и дизайне схемы.

    Приложение IoT и обзор облачной архитектуры InfluxDB

    Если уменьшить масштаб, Plant Buddy будет работать примерно так:

    На верхнем уровне находится пользовательский опыт. Они смогут просматривать показания датчиков в своем веб-браузере, и каждый пользователь может иметь любое количество данных отчетов Plant Buddies.

    Само приложение Plant Buddy условно разделено на две части: то, что я называю «шлюз записи» и «шлюз чтения».Эти «шлюзы» фактически являются просто конечными точками в приложении Plant Buddy Flask, как вы увидите, но их можно легко разделить на отдельные приложения.

    Аутентификация пользователя для операций чтения и записи между пользователем и их устройствами осуществляется самим Plant Buddy. Каждое устройство и каждый запрос браузера должны быть авторизованы Plant Buddy.

    Наконец, есть бэкэнд — InfluxDB. Шлюз чтения и шлюз записи записывают в одно и то же ведро (для начала, подробнее об этом позже, когда мы введем понижающую дискретизацию).Мы также будем пользоваться преимуществами системы задач InfluxDB и предоставленных системных сегментов _tasks и _monitoring.

    Аутентификация между кодом Plant Buddy и серверной частью InfluxDB управляется токенами InfluxDB, которые хранятся в виде секретов в веб-приложении.

    Код стартера Plant Buddy

    Для начала, Plant Buddy может получать информацию с устройства пользователя, но может только анализировать отправленные данные и распечатывать их. Запись в InfluxDB еще не реализована.

      @ app.route ("/ write", methods = ['POST'])
    def write ():
       user = users.authorize_and_get_user (запрос)
       d = parse_line (request.data.decode ("UTF-8"), пользователь ["имя_пользователя"])
       print (d, flush = True)
       return {'result': "OK"}, 200
     
    def parse_line (строка, имя_пользователя):
       data = {"устройство": строка [: 2],
               "sensor_name": sensor_names.get (строка [2: 4], "неизвестно"),
               "значение": строка [4:],
               "пользователь": имя_пользователя}
       вернуть данные  

    Аналогично, существует настроенный шаблон html, который содержит слот для визуализации графика, но пока печатает только имя пользователя, извлеченное из объекта запроса.

      @ app.route ("/")
    def index ():
       user = users.authorize_and_get_user (запрос)
     
       return render_template ("home.html",
                               user_name = пользователь ["user_name"],
                               graph_code = " поместите график здесь "  

    Вы можете увидеть все это вместе в VSCode:

    Здесь вы можете увидеть полный стартовый код. По сути, веб-приложение настроено с помощью:

    1. Пользовательский модуль для проверки пользователей и извлечения имени пользователя (это подделка).
    2. Модуль хранилища секретов для безопасного хранения секретов для InfluxDB (также фальшивых).
    3. Конечная точка для приема данных от устройств Plant Buddy.
    4. HTML-шаблон для сервера Flask для рендеринга
    5. Конечная точка для рендеринга этого HTML-шаблона

    Как видите, я запускаю приложение на моем локальном хосте в контейнере Docker, чтобы упростить разработку.

    Начальная разработка приложений Интернета вещей для InfluxDB Cloud

    Теперь, когда у нас есть весь вводный материал, пора приступить к использованию InfluxDB!

    Предварительные требования:

    1. Настройте учетную запись InfluxDB Cloud.Бесплатная учетная запись — это нормально.
    2. Настроить VSCode.
    3. Загрузите и установите Influx CLI.

    Настройка InfluxDB CLI

    У меня пустая учетная запись в облаке, и на моем ноутбуке разработчика установлен интерфейс командной строки. Можно использовать интерфейс командной строки прямо из ворот, но мне сложно постоянно предоставлять такую ​​информацию, как регион, на который я нацелен, название моей организации и т. Д. Таким образом, гораздо проще настроить конфигурацию для CLI. Фактически, вы можете настроить множество конфигураций и легко переключаться между ними, но пока мне понадобится только один.

    Интерфейс командной строки Influx имеет хорошую справочную систему, поэтому я просто спрошу, как ее создать:

      $ Конфигурация притока создать -h
    Команда Influx config create создает новую конфигурацию подключения InfluxDB.
    и сохраняет его в файле конфигураций (по умолчанию в ~ / .influxdbv2 / configs).
    
    Примеры:
    # создать конфиг и сделать его активным
    Конфигурация притока create -a -n $ CFG_NAME -u $ HOST_URL -t $ TOKEN -o $ ORG_NAME  

    Это говорит мне, что мне нужно будет предоставить токен, имя организации, URL-адрес хоста, а также назвать конфигурацию.

    Во-первых, мне нужно будет перейти к пользовательскому интерфейсу InfluxDB, чтобы сгенерировать мой первый токен. Я делаю это, используя левую навигацию в пользовательском интерфейсе, чтобы перейти к Data -> Tokens .

    Затем нажмите Generate Token , выберите All Access Token и дайте ему имя.

    Затем я могу получить строку токена, щелкнув токен в списке:

    Если я забыл название своей организации, я могу взять его на странице «О нас».

    Давайте вставим все это в интерфейс командной строки и создадим профиль:

      $ Infx config create -t ​​cgIsJ7uamKESRiDkRz2mNPScXw_K_zswiOfdZmIQMina1TCtWk2NGu3VssF7cJPPf-QR88nPdFFrlC9GleTpwQ == -2.o [email protected] -user
     

    Выдает следующий результат:

      Active Name URL Org
    * plantbuddy https: // eastus-1.azure.cloud2.influxdata.com/ [адрес электронной почты защищен]  

    Теперь у нас есть конфигурация интерфейса командной строки plantbuddy.

    Создание корзины для хранения данных пользователей

    Следующим шагом является создание корзины в InfluxDB для хранения данных пользователей. Это делается с помощью команды создания корзины:

    $ ковш притока create -n plantbuddy

    Что дает следующий результат:

      ID Имя Срок хранения группы осколков Идентификатор организации
    f8fbced4b964c6a4 plantbuddy 720h0m0s н / д f1d35b5f11f06a1d  

    Это создало для меня сегмент с максимальным сроком хранения по умолчанию, в течение которого сегмент хранит данные.

    Загрузить протокол линии

    Теперь, когда у меня есть корзина, я могу загрузить в нее некоторые данные, чтобы сразу начать тестирование, вместо того, чтобы сначала записывать данные из моего кода Python. Я создал образцы данных за 2 дня.

    Формат линейного протокола хорошо задокументирован. Но вот отрывок:

      свет, пользователь = rick, device_id = 01 чтение = 26i 1621978469468115968
    почва_влажность, пользователь = rick, device_id = 01 чтение = 144i 1621978469468115968
    влажность, пользователь = rick, device_id = 01 чтение = 68i 1621978469468115968
    почва_темп, пользователь = rick, device_id = 01 чтение = 67i 1621978469468115968
    air_temp, user = rick, device_id = 01 reading = 72i 1621978469468115968
    свет, пользователь = rick, device_id = 01 чтение = 28i 1621978529468115968
    почва_влажность, пользователь = rick, device_id = 01 чтение = 140i 1621978529468115968
    влажность, пользователь = rick, device_id = 01 чтение = 65i 1621978529468115968
    почва_темп, пользователь = rick, device_id = 01 чтение = 67i 1621978529468115968
    air_temp, user = rick, device_id = 01 чтение = 72i 1621978529468115968  

    Это показывает, что я сообщаю о 5 измерениях: свет, почва_влажность, влажность, почва_темп и воздушная_темп. Для каждой точки есть тег пользователя и тег идентификатора устройства. Обратите внимание, что это решение будет работать только тогда, когда ожидается, что у пользователей будет ограниченное количество устройств. В противном случае комбинация значений тегов может привести к снижению вашей мощности. Имя поля - «чтение», которое имеет целочисленное значение. Используя быстрый и грязный скрипт Python, я генерировал одно из этих измерений в минуту за последние 48 часов, так что это длинный файл.

    $ приток записи -b plantbuddy -f ~ / сгенерирован.lp

    Об ошибках не сообщалось, поэтому похоже, что это сработало, но давайте запустим запрос, чтобы убедиться.

    Выполнить запрос

    Я могу запустить тестовый запрос с помощью команды запроса притока из интерфейса командной строки, например:

      $ запрос притока "from (bucket: \" plantbuddy \ ") |> диапазон (начало: 0)  

    Это дает много результатов, поэтому я знаю, что загрузка линейного протокола сработала, но я могу уточнить запрос, чтобы получить более точный результат.

      $ запрос притока "из (ведро: \" plantbuddy \ ") |> диапазон (начало: 0) |> последний () |> сохранить (столбцы: [\" _ время \ ", \" _ измерение \ ", \" _value \ "]) |> group ()"  

    Этот запрос дает следующий результат:

      Результат: _result
    Таблица: ключи: []
                        _time: время _value: float _measurement: строка
    ------------------------------ -------------------- -------- ----------------------
    2021-05-27T16: 00: 22.881946112Z 70 air_temp
    2021-05-27T16: 00: 22.881946112Z 69 влажность
    2021-05-27T16: 00: 22.881946112Z 36 светлый
    2021-05-27T16: 00: 22.881946112Z 173 почва_влажность
    2021-05-27T16: 00: 22.881946112Z 66 почв_темп  

    Итак, у меня уже есть данные, и я могу начать их изучение с помощью запросов, но выполнить итерацию запроса через CLI не так-то просто.Итак, давайте установим и настроим плагин InfluxDB VSCode.

    Настройте VSCode и расширение Flux для InfluxDB Cloud

    Как пользователь VSCode, я, естественно, хотел бы использовать их редактор при написании моих запросов Flux, а также держать весь мой проект под контролем источника. Итак, следующий шаг - настроить InfluxDB VSCode Extension. Расширение Flux легко найти, выполнив поиск по запросу «Influx» в диспетчере расширений.

    После установки расширения вы можете увидеть окно InfluxDB, добавленное в левый нижний угол.

    Теперь я могу использовать это окно для установки соединения с моей учетной записью в облаке, переключив фокус на окно InfluxDB и нажав кнопку + .

    Если я забыл какую-либо информацию, необходимую для настройки расширения Flux, я могу использовать команду Infx config для своих учетных данных:

      $ Конфигурация притока
    Активный URL-адрес имени организации
    * plantbuddy https: //eastus-1.azure.cloud2.influxdata.com / [email protected]  

    Я могу найти свои строки токенов с помощью команды списка аутентификации притока, например:

    $ Список авторизации притока

    Поскольку в названии моей организации есть специальные символы, мне нужно указать идентификатор своей организации вместо названия организации. Я могу найти идентификатор организации с помощью команды списка организаций притока, например:

      $ список организаций притока
    ID Имя
    f1d35b5f11f06a1d [защищенный адрес электронной почты]  

    А затем заполните форму.

    Используя кнопку Test , я вижу, что соединение работает, и затем сохраняю его. После сохранения обратите внимание, что окно InfluxDB теперь заполнено, и я могу просматривать измерения.

    Запросить InfluxDB Cloud из редактора кода

    Теперь, когда соединение установлено, я обычно добавляю в проект рабочий файл Flux для выполнения запросов Flux.

    Первое, на что следует обратить внимание, это то, что форматирование работает. Расширение Flux также включает автозавершение операторов и помощь на месте, как и следовало ожидать.

    Тогда я могу попробовать запустить запрос прямо из редактора.

    Это предоставляет мои результаты в виде чистой сетки, которую легче использовать, чем результаты, выгружаемые в терминал.

    Обратите внимание, что информация о расширении записывается на вкладке языка Flux окна ВЫВОД. Это особенно полезно, если в вашем Flux есть ошибки.

    Теперь, когда у меня настроена среда разработки для InfluxDB, давайте реализуем бэкэнд.

    Орудие записывает

    Теперь мы вернулись к написанию кода на Python, чтобы веб-приложение работало. Сначала я собираюсь обработать вызовы конечной точки / write, преобразовав эти вызовы, чтобы фактически поместить данные в InfluxDB.

    1. У меня уже есть ведро под названием «plantbuddy», созданное для этого.
    2. Затем я создам новый токен, у которого есть разрешение на чтение и запись в это ведро.
    3. Затем я импортирую клиентскую библиотеку Python InfluxDB v2.
    4. Затем я создам точки и напишу их с помощью клиентской библиотеки.

    Создать токен

    Во-первых, мне понадобится токен с разрешениями на запись и чтение из корзины. Из справки по вводу auth create видно, что существует множество опций для управления разрешениями для токена.

      k $ приток auth create -h
    Создать авторизацию
    
    Применение:
      приток авторизации создать [флаги]
    
    Флаги:
      -c, --active-config string Имя конфигурации для использования в команде; Соответствует env var $ INFLUX_ACTIVE_CONFIG
          --configs-path string Путь к конфигурациям CLI притока; Сопоставляется с env var $ INFLUX_CONFIGS_PATH (по умолчанию "/ Users / rick /.infxdbv2 / configs ")
      -d, --description строка Описание токена
      -h, --help Справка по команде создания
          --hide-headers Скрыть заголовки таблиц; по умолчанию false; Соответствует env var $ INFLUX_HIDE_HEADERS
          --host string HTTP-адрес InfluxDB; Соответствует env var $ INFLUX_HOST
          --json Выводить данные в формате json; по умолчанию false; Соответствует env var $ INFLUX_OUTPUT_JSON
      -o, --org string Название организации; Соответствует env var $ INFLUX_ORG
          --org-id строка Идентификатор организации; Соответствует env var $ INFLUX_ORG_ID
          --read-bucket stringArray Идентификатор корзины. 
          --read-buckets Предоставляет разрешение на выполнение действий чтения для сегментов организации.
          --read-Checks Предоставляет разрешение на чтение чеков.
          --read-dashboards Предоставляет разрешение на чтение информационных панелей.
          --read-dbrps Предоставляет разрешение на чтение сопоставлений политик хранения базы данных.
          --read-notificationEndpoints Предоставляет разрешение на чтение конечных точек уведомления.
          --read-notificationRules Предоставляет разрешение на чтение уведомленийRules.
          --read-orgs Разрешает читать организации.
          --read-tasks Предоставляет разрешение на чтение задач.
          --read-telegrafs Разрешает читать конфиги телеграфа
          --read-user Предоставляет разрешение на выполнение действий чтения против пользователей организации.
          --skip-verify Пропустить цепочку сертификатов TLS и проверку имени хоста.-t, --token string Токен аутентификации; Соответствует env var $ INFLUX_TOKEN
      -u, --user string Имя пользователя
          --write-bucket stringArray Идентификатор корзины. 
          --write-buckets Предоставляет разрешение на выполнение изменяющих действий с бакетами организации.
          --write-Checks Предоставляет разрешение на создание проверок.
          --write-dashboards Предоставляет разрешение на создание информационных панелей.
          --write-dbrps Предоставляет разрешение на создание сопоставлений политик хранения базы данных.
          --write-notificationEndpoints Предоставляет разрешение на создание конечных точек уведомления
          --write-notificationRules Предоставляет разрешение на создание notificationRules.
          --write-orgs Предоставляет разрешение на создание организаций.
          --write-tasks Предоставляет разрешение на создание задач.
          --write-telegrafs Предоставляет разрешение на создание конфигураций телеграфа
          --write-user Предоставляет разрешение на выполнение изменяющих действий против пользователей организации  

    --write-bucket и --read-bucket - это варианты, которые я ищу.Эти параметры принимают идентификатор сегмента, а не имя сегмента. Идентификатор легко найти с помощью команды списка ведра притока:

    .
      $ список ведра притока
    ID Имя Срок хранения группы осколков Идентификатор организации
    d6ec11a304c652aa _monitoring 168h0m0s н / д f1d35b5f11f06a1d
    fe25b83e9e002181 _tasks 72h0m0s н / д f1d35b5f11f06a1d
    f8fbced4b964c6a4 plantbuddy 720h0m0s н / д f1d35b5f11f06a1d  

    Затем я могу создать токен с помощью команды Infx auth create, например:

      $ приток auth create --write-bucket f8fbced4b964c6a4 --read-bucket f8fbced4b964c6a4  

    Вывод включает строку токена, которую я затем могу зарегистрировать в хранилище секретов моего сервера приложений.

      ID Описание Токен Имя пользователя ID пользователя Разрешения
    0797c045bc99e000 d0QnHz8bTrQU2XI798YKQzmMQY36HuDPRWiCwi8Lppo1U4Ej5IKhCC-rTgeRBs3MgWsomr-YXBbDO3o4BLJe9g == [электронная почта защищена] 078bedcd5c762000 [читать: Orgs / f1d35b5f11f06a1d / Ковши / f8fbced4b964c6a4 пишут: Orgs / f1d35b5f11f06a1d / Ковши / f8fbced4b964c6a4]  

    Импорт и настройка библиотеки Python InfluxDB

    После установки клиента Python InfluxDB в вашей среде выполните следующие действия:

    1. Импортируйте библиотеку.
    2. Настроить клиента.
    3. Создайте API записи и запроса.
      импорт Influxdb_client
    
    
    client = Influxdb_client.InfluxDBClient (
       url = "https://eastus-1.azure.cloud2.influxdata.com/",
       токен = secret_store.get_bucket_secret (),
       org = "f1d35b5f11f06a1d"
    )
    
    write_api = client.write_api ()
    query_api = client.query_api ()  

    Я добавил этот код в верхнюю часть своего файла кода, чтобы я мог легко использовать API записи и запросов во всем модуле.

    Создайте и запишите точки

    Теперь, когда у меня настроена клиентская библиотека и связанный с ней API, я могу изменить свой код, просто распечатав данные, загружаемые пользователем, на их фактическое сохранение. Первая часть - создать точку, которая представляет собой объект, представляющий данные, которые я хочу записать.

    Я сделаю это, создав новую функцию write_to_influx:

      def write_to_influx (данные):
       p = infxdb_client.Point (данные ["имя_сенсора"]).  тег ("пользователь", данные ["пользователь"]).тег ("идентификатор_устройства", данные ["устройство"]). поле ("чтение", int (данные ["значение"]))
       write_api.write (bucket = "plantbuddy", org = "f1d35b5f11f06a1d", record = p)
       print (p, flush = True)  

    Метод получает словарь Python и извлекает значения для использования в тегах и поле. Вы можете включить несколько тегов и полей в Point, но Plant Buddy использует только одно поле, «чтение». Он также выводит точку в конце функции, в основном для того, чтобы можно было увидеть, как она работает.

    Теперь я могу обновить свою конечную точку записи, чтобы использовать эту функцию:

      @app.route ("/ запись", методы = ['POST'])
    def write ():
       user = users.authorize_and_get_user (запрос)
       d = parse_line (request.data.decode ("UTF-8"), пользователь ["имя_пользователя"])
       write_to_influx (d)
       return {'result': "OK"}, 200  

    У меня есть Plant Buddy, который уже пишет точки серверу, и похоже, что он работает.

    Выполнив простой запрос, я могу подтвердить, что данные загружаются в мою корзину.

    Орудие читает

    Начать работу с веб-страницей Plant Buddy будет очень просто.Он отобразит график с данными Plant Buddy за последние 48 часов. Для работы мне нужно:

    1. Написать запрос, который извлекает данные
    2. Используйте клиентскую библиотеку Python InfluxDB v2 для получения данных
    3. Создать график
    4. Просмотрите результаты и добавьте их на график
    5. Показать график на веб-странице

    Напишите запрос

    Это простой запрос для написания.

      из (ведро: "plantbuddy")
       |> диапазон (начало: -48 ч)
       |> фильтр (fn: (r) => r.user == "rick")  

    Это возвращает много данных. Важно понимать, что данные возвращаются организованными по временным рядам. Временные ряды сначала организуются по измерениям, а затем разбиваются по значениям тегов и полям. Таким образом, каждый временной ряд представляет собой отдельную таблицу связанных данных, упорядоченных по отметкам времени. Идеально подходит для построения графиков, каждая таблица временных рядов представляет собой линию на графике.

    Однако я не знаю имя пользователя во время выполнения, поэтому мне нужно параметризовать запрос.Я собираюсь использовать для этого простую замену строки. Итак, мне просто нужно немного подправить запрос:

      из (ведро: "plantbuddy")
       |> диапазон (начало: -48 ч)
       |> фильтр (fn: (r) => r.user == "{}")  

    Кроме того, я хочу прочитать этот запрос во время выполнения, поэтому я добавил файл с именем «graph.flux» и сохранил запрос в этом файле.

    Теперь, когда у меня есть готовый запрос, я могу использовать его для получения данных.

    Получить данные из InfluxDB

    В моей функции index () в app.py, я начинаю с открытия файла Flux, заменяя имя пользователя, а затем использую API-интерфейс запроса, который я ранее создал, чтобы вернуть набор результатов, добавив это в мою функцию index ():

      query = open ("graph. flux"). Read (). Format (пользователь ["user_name"])
       result = query_api.query (query, org = "f1d35b5f11f06a1d")  

    Визуализация временных рядов с помощью mpld3 и InfluxDB Cloud

    Для Plant Buddy я выбрал библиотеку mpld3 для создания моих графиков. Я выбрал эту библиотеку, потому что она очень проста в использовании.

    После добавления библиотеки mpld3 и ее зависимостей в мою среду мне нужно импортировать несколько вещей:

    импортировать matplotlib.pyplot как plt, mpld3

    Теперь я могу построить график с результатами. Для этого для каждого измерения (освещенность, влажность и т. Д.) Мне нужно создать список значений для оси x и список значений для оси y. Конечно, по оси абсцисс будет время.

    Как упоминалось выше, модель данных Flux возвращает данные в идеальном формате для этого приложения.Он возвращает таблицу для каждого измерения, поэтому мне просто нужно перебрать таблицы, затем перебрать каждую запись в каждой таблице, построить списки и попросить matplotlib построить их.

      fig = plt.figure ()
       для таблицы в результате:
           x_val = []
           y_val = []
           label = ""
           для записи в таблице:
               y_val.append (запись ["_ значение"])
               x_valals.append (запись ["_ время"])
               метка = запись ["_ измерение"]
           plt.участок (x_val, y_val, label = label)  

    Затем я заканчиваю тем, что запрашиваю легенду, конвертирую график в html и передаю его в шаблон для визуализации.

      plt.legend ()
       grph = mpld3.fig_to_html (рис)
       return render_template ("home.html",
                               user_name = пользователь ["user_name"],
                               graph_code = grph)  

    А теперь, когда я загружаю страницу индекса, видно, что график работает.

    Агрегация и понижающая дискретизация

    Агрегация

    Следует отметить, что matplotlib требуется изрядное количество времени для создания графика и изрядное количество времени для mpld3, чтобы преобразовать его в html. Но пользователям на самом деле не нужно отображать каждую точку. Следовательно, мы можем ускорить пользовательский интерфейс, добавив немного агрегирования в запрос Flux. Вместо того, чтобы извлекать каждую точку, давайте извлечем только среднее значение за каждые 10 минут. Я просто добавляю к запросу агрегацию с помощью функции aggregateWindow ():

      из (ведро: "plantbuddy")
       |> диапазон (начало: -48 ч)
       |> фильтр (fn: (r) => r.user == "rick")
       |> aggregateWindow (каждые: 10 мин, fn: среднее)  

    Страница теперь загружается намного быстрее, да и график выглядит немного лучше.

    На самом деле, для такого простого запроса и набора данных такой запрос будет более чем адекватен для производственных сценариев использования. Тем не менее, мы можем продемонстрировать, как дополнительно оптимизировать задержку пользовательского интерфейса с помощью понижающей дискретизации.

    Даунсэмплинг

    Пониженная дискретизация влечет за собой вычисление данных с более низким разрешением для отображения из данных с высоким разрешением и сохранение этих предварительно вычисленных для отображения или дальнейших вычислений. Помимо более быстрого взаимодействия с пользователем, это также может сэкономить вам расходы на хранение, поскольку вы можете хранить данные с пониженной дискретизацией в корзине с более длительным периодом хранения, чем необработанные данные.

    Для этого мне нужно:

    1. Создайте новый сегмент понижающей дискретизации и новый токен, который может читать и записывать этот сегмент
    2. Создание сценария понижающей дискретизации Flux
    3. Создать задачу для периодического запуска этого сценария
    4. Измените поток в graph.flux, чтобы запросить сегмент с субдискретизацией
    Создать новую корзину и токен

    Сначала я создам новый сегмент, как и раньше, и назову его «субдискретизация».

    $, создание ведра притока -n с пониженной дискретизацией

    Вывод любезно дает мне идентификатор ведра:

      ID Имя Срок хранения группы осколков Идентификатор организации
    c7b43676728de98d с пониженной дискретизацией 720h0m0s нет данных f1d35b5f11f06a1d  

    Однако для простоты я создам один токен, который может читать и записывать оба сегмента. Сначала перечислите сегменты, чтобы получить идентификаторы сегментов:

      $ список ведра притока
    ID Имя Срок хранения группы осколков Идентификатор организации
    d6ec11a304c652aa _monitoring 168h0m0s н / д f1d35b5f11f06a1d
    fe25b83e9e002181 _tasks 72h0m0s н / д f1d35b5f11f06a1d
    c7b43676728de98d с пониженной дискретизацией 720h0m0s нет данных f1d35b5f11f06a1d
    f8fbced4b964c6a4 plantbuddy 720h0m0s н / д f1d35b5f11f06a1d  

    Затем создайте токен с разрешениями на чтение и запись для обоих сегментов:

      $ influenx auth create --write-bucket c7b43676728de98d --write-bucket f8fbced4b964c6a4 --read-bucket c7b43676728de98d --read-bucket f8fbced4b964c6a4
    ID Описание Токен Имя пользователя ID пользователя Разрешения
    079820bd8b7c1000 hf356pobXyeoeqpIIt6t-ge7LI-UtcBBElq8Igf1K1wxm5Sv9XK8BleS79co32gCQwQ1voXuwXu1vEZg-sYDRg == [электронная почта защищена] 078bedcd5c762000 [прочитать: Orgs / f1d35b5f11f06a1d / Ковши / c7b43676728de98d чтения: Orgs / f1d35b5f11f06a1d / Ведра / f8fbced4b964c6a4 запись: Orgs / f1d35b5f11f06a1d / Ковши / c7b43676728de98d пишут: Orgs / f1d35b5f11f06a1d / ведер / f8fbced4b964c6a4]  

    Затем возьмите этот новый токен и замените старый токен в хранилище секретов моего приложения. Перезагрузите и убедитесь, что все по-прежнему работает.

    Создание сценария понижающей дискретизации Flux

    Сценарий понижающей дискретизации состоит из двух основных шагов. Во-первых, выполните агрегирование, а во-вторых, запишите где-нибудь агрегированные данные.

    Я уже выяснил агрегацию, которую я хочу сделать при создании нового файла graph.flux. Я добавлю файл «downsample.flux», используя существующую агрегацию в качестве отправной точки. Одно из ключевых отличий заключается в том, что я хочу уменьшить выборку ВСЕХ данных, а не только данных для конкретного пользователя.Таким образом, мой шаг агрегации пропустит фильтр:

      из (ведро: "plantbuddy")
       |> диапазон (начало: -48 ч)
       |> aggregateWindow (каждые: 10 мин, fn: среднее)  

    Выполняя это, я вижу, что все данные в корзине будут агрегированы.

    Теперь мне просто нужно добавить функцию to (), чтобы записать все субдискретизированные данные в мою субдискретизированную корзину:

      из (ведро: "plantbuddy")
       |> диапазон (начало: -48 ч)
       |> aggregateWindow (каждые: 10 мин, fn: среднее)
       |> в (сегмент: "субдискретизация")  

    Запрашивая сегмент с субдискретизацией, я вижу, что там есть все данные.

    Я сделал субдискретизацию всех существующих данных, поэтому теперь я настрою задачу, чтобы по мере поступления данных они также подвергались субдискретизации.

    Создайте задачу понижающей дискретизации из скрипта Flux

    Это простой вопрос: взять мой скрипт downsample.flux и зарегистрировать его как задачу, запускаемую каждые 10 минут.

    Первый шаг - изменить диапазон, чтобы смотреть назад только за последние 10 минут. Я не хочу постоянно повторять субдискретизацию данных, которые я уже субдискретизировал.

      из (ведро: "plantbuddy")
       |> дальность (начало: -10 м)
       |> aggregateWindow (каждые: 10 мин, fn: среднее)
       |> в (сегмент: "субдискретизация")  

    Затем мне нужно добавить опцию, которая нужна каждой задаче. Доступны разные поля, но все, что мне нужно, это имя и «каждый», которые сообщают системе задач, как часто запускать Flux.

    Теперь мой полный downsample.flux выглядит так:

      option task = {
       name: "субдискретизация",
       каждые: 10 м
    }
    от (ведро: "заводчик")
       |> дальность (начало: -10 м)
       |> aggregateWindow (каждые: 10 мин, fn: среднее)
       |> в (сегмент: "субдискретизация")  

    Теперь мне просто нужно зарегистрировать его в InfluxDB Cloud. Это простой способ использования задачи create с CLI:

      $ задача потока создать -f downsample.flux
    ID Имя Организация ID Статус организации Каждый Cron
    079824d7a391b000 с пониженной дискретизацией f1d35b5f11f06a1d [защита электронной почты] активный 10 мес.  

    Поскольку выходные данные предоставляют мне идентификатор задачи, я могу использовать его, чтобы следить за задачей:

      $ список журнала задач притока --task-id 079824d7a391b000  

    И я вижу, что он работал успешно, вместе с некоторой другой полезной информацией, например, какой Flux был на самом деле запущен.

      Сообщение времени выполнения
    079825437a264000 2021-05-28T01: 30: 00.099978246Z Задача, запущенная из сценария: "option task = {\ n name: \" downsampled \ ", \ n каждые: 10 м \ n} \ nот (ведро: \" plantbuddy \ ") \ n |> диапазон (начало: -10 м) \ n |> aggregateWindow (каждые: 10 мин, fn: среднее) \ n |> до (сегмент: \ "с пониженной дискретизацией \") "
    079825437a264000 2021-05-28T01: 30: 00. 430597345Z trace_id = 0adc0ed1a407fd7a is_sampled = true
    079825437a264000 2021-05-28T01: 30: 00.466570704Z Завершено (успешно)  
    Обновить запрос графика

    Наконец, я могу обновить запрос, позволяющий графу читать из сегмента с пониженной дискретизацией. Это гораздо более простой и быстрый запрос.

      из (сегмент: "с пониженной дискретизацией")
       |> диапазон (начало: -48 ч)
       |> фильтр (fn: (r) => r.user == "{}")  

    Перезагрузите все, и все работает быстро!

    Уведомления

    Последняя особенность, которую мы добавим, - это способность plantbuddy.com, чтобы уведомить пользователей, если их почва станет слишком сухой. С InfluxDB вы можете использовать задачи для создания проверок статуса и правил уведомлений, которые будут отправлять сообщение вашему приложению при любых условиях, которые вы определяете. Не следует добавлять в приложение логику опроса для чтения статуса; вы должны позволить InfluxDB сделать это за вас!

    Хотя есть более простые способы реализовать эту функциональность с помощью одной задачи, например, выполнив простой запрос, а затем просто используя http.post () непосредственно в той же задаче, plantbuddy.com будет в полной мере использовать всю систему проверок и уведомлений. Дополнительные преимущества, в частности, включают записи статусов и уведомлений, хранящиеся в ведре _monitoring. Кроме того, поскольку эти данные хранятся в стандартном формате, можно легко обмениваться такими инструментами, как информационные панели и запросы.

    Проверка порога

    Первый тип задач, который я хочу настроить, - это проверка пороговых значений. Это задача, которая:

    1. Запрашивает в данных интересующие значения
    2. Проверяет, превышают ли эти значения определенные пороговые значения
    3. Использует библиотеку монитора потока для записи данных временных рядов в сегмент _monitoring
    4. Создайте задачу из сценария Flux и запустите ее.
    Запрос значения, которое вы хотите проверить

    Plant Buddy сможет уведомить любого пользователя, если уровень влажности почвы станет слишком сухим.Я создам связанный запрос Flux (который скоро станет задачей) в новом файле check.flux. С помощью простого запроса можно оглянуться во времени и найти все (и только) уровни влажности почвы:

      data = from (bucket: "plantbuddy")
       |> дальность (начало: -10 м)
       |> filter (fn: (r) => r._measurement == "почва_влажность")  

    Обратите внимание, что я запрашиваю необработанные данные в корзине plantbuddy, а не данные с пониженной дискретизацией.

    Определите пороговые значения для значения

    Затем мне нужно определить различные пороги, за которыми нужно следить.Система проверок будет использовать эти пороговые значения для установки статуса каждой строки данных. Существует 4 возможных уровня проверки порогового значения:

    Установите порог, создав для каждого из них функцию предиката, которая возвращает логическое значение, определяющее, находится ли значение в пределах этого порога. Вам не нужно использовать все уровни при проверке порога. Для Plant Buddy влажность почвы может быть либо «нормальной», либо «критической», поэтому я просто определяю эти две функции:

      ok = (r) => r. Чтение> 35
    крит = (г) => р.чтение <= 35  

    В основном, если показатель влажности почвы упадет до 35 или ниже, это критично.

    Как упоминалось выше, результирующий статус будет записан в корзину _monitoring. Вам также необходимо предоставить функцию предиката для создания сообщения, которое регистрируется. Это сообщение может быть сложным или простым. Я все просто:

      messageFn = (r) => "влажность почвы в $ {string (v: r.reading)} для $ {r.user}"  

    Эти функции предиката являются параметрами монитора.check (), которая генерирует статусы и записывает их в корзину _monitoring, которую мы будем использовать ниже.

    Создание статуса для каждой записи с помощью функции monitoring.check ()

    В пакете мониторинга есть функция под названием monitoring.check (), которая теперь выполняет работу по вычислению и записи статусов за вас. Он будет просматривать каждую запись в возвращенных данных, вычислять уровень статуса (в данном случае ok или cris), вычислять строку сообщения, а затем записывать ее в ведро _monitoring вместе с некоторой другой информацией.

    Однако сначала нам нужно предоставить некоторые метаданные для monitor.check. Требуются идентификатор, имя, тип и список тегов. Теги полезны, когда у вас есть несколько правил уведомления. Поскольку в настоящее время я планирую только один, я оставлю объект тегов пустым.

      check = {_check_id: "check1xxxxxxxxxx",
           _check_name: "проверка влажности почвы",
           _type: "порог",
           теги: {}  

    Теперь мой сценарий может продолжить и вызвать monitor.check. Пара замечаний:

    1. Перенаправление труб по схеме.Функция fieldsAsCols () обязательна. Это форма, которую ожидает функция monitor.check. Это также помогает упростить написание некоторых проверок, поскольку вы можете более легко писать выражения, объединяющие значения из разных полей.
    2. Это немного сбивает с толку, потому что параметр метаданных проверки называется «данные». Я называю эту опцию «проверкой» и называю полученные данные временного ряда «данными». На мой взгляд, это просто более понятно.
    3. Я добавил yield (), чтобы мне было проще запускать скрипт и проверять результаты.
      данные
       |> v1 ["fieldsAsCols"] ()
       |> yield ()
       |> monitor.check (данные: проверка, сообщениеFn: сообщениеFn, критическое значение: критическое, ок: ок)  

    Проще увидеть, как это работает, когда все это собрано в одном месте:

      импорт «Influxdata / Infxdb / monitor»
    импортировать "Influxdata / Infxdb / v1"
     
    option task = {name: "проверка влажности почвы", каждые: 10 м, смещение: 0 с}
     
    data = from (bucket: "plantbuddy")
       |> дальность (начало: -10 м)
       |> фильтр (fn: (r) => r._measurement == "почва_влажность")
     
    ok = (r) => r. чтение> 35
    cris = (r) => r.reading <= 35
     
    messageFn = (r) => "влажность почвы при $ {string (v: r.reading)} для $ {r.user}"
     
    check = {_check_id: "check1xxxxxxxxxx",
           _check_name: "проверка влажности почвы",
           _type: "порог",
           теги: {}
    }
     
    данные
       |> v1 ["fieldsAsCols"] ()
       |> yield ()
       |> monitor.check (данные: проверка, сообщениеFn: сообщениеFn, критическое значение: критическое, ок: ок)  

    Теперь я могу вручную запустить свой чек.Как и ожидалось, он создал _уровень «ОК» для каждого чтения за последние 10 минут.

    Я могу пойти немного глубже и напрямую запросить ведро _monitoring:

      из (ведро: "_monitoring")
       |> диапазон (начало: -5 м)
       |> фильтр (fn: (r) => r._field == "_message")  

    Все выглядит хорошо, поэтому теперь я настрою InfluxDB для запуска кода в check.flux по расписанию.

    Создание задачи проверки пороговых значений

    Я уже добавил опции для превращения скрипта в задачу:

      option task = {name: "проверка влажности почвы", каждые: 10 м, смещение: 0 с}  

    Итак, теперь я могу просто создать задачу с чеком.flux файл:

      $ задача потока создать -f check.flux
    ID Имя Организация ID Статус организации Каждый Cron
    0798ba98b30d5000 Проверка влажности почвы f1d35b5f11f06a1d [адрес электронной почты] активен 10 м  

    Теперь у меня есть задача, выполняемая каждые 10 минут, которая записывает статус, поэтому теперь мне нужно написать правило уведомления, которое является еще одной задачей, которая будет вызывать конечную точку на Plant Buddy, чтобы Plant Buddy мог уведомить пользователя.

    Правило уведомления

    Чтобы написать эту задачу, мне нужно выполнить несколько вещей:

    1. Добавьте секрет в InfluxDB, чтобы Plant Buddy мог авторизовать любой обмен данными обратно из InfluxDB Cloud
    2. Добавьте конечную точку на plantbuddy.com, чтобы она вызывалась при выполнении условий правила уведомления
    3. Создайте в Flux переменную конечной точки, которая указывает на общедоступный URL-адрес (я пробил дыру в брандмауэре, чтобы мой сервер разработки был доступен из InfluxDB Cloud)
    4. Используйте библиотеку мониторинга для поиска любых статусов, о которых я хочу уведомить пользователей (в частности, если _level - критический).
    5. Вызвать конечную точку для каждой записи, которая соответствует этому условию, отправив сообщение, созданное проверкой
    Хранить и использовать секрет в InfluxDB Cloud

    Сначала я хочу сохранить токен, который Plant Buddy будет использовать для проверки того, что все входящие запросы поступают от InfluxDB.Я мог бы просто добавить это в сценарий Flux, но гораздо безопаснее использовать хранилище секретов платформы, чем хранить их в исходном коде.

      $ обновление секрета притока -k pb_secret -v sqps8LCY6z8XuZ2k
    Идентификатор ключевой организации
    pb_secret f1d35b5f11f06a1d  

    Тогда я могу получить секрет с помощью этого кода. Я создал новый файл notifation_rule.flux для хранения этого потока. Это все, что нужно для получения секрета в виде строки:

      импорт «Influxdata / Infxdb / secrets»
     
    секреты.get (ключ: "pb_secret")  
    Добавить конечную точку в Plant Buddy

    На самом деле уведомление пользователя каким-либо образом еще не реализовано, поэтому я просто добавлю этот код в app.py, чтобы я мог убедиться, что система работает непрерывно:

      @ app.route ("/ notify", methods = ['POST'])
    def notify ():
       print ("уведомление получено", flush = True)
       печать (request.data, flush = True)
       return {'result': "OK"}, 200
       # TODO: проверить авторизацию и фактически уведомить пользователя  
    Добавить конечную точку в Flux

    Теперь я могу ссылаться на эту конечную точку в моем Flux:

    конечная точка = http.конечная точка (URL: "http://71.126.178.222:5000/notify")

    Вы можете заметить, что я еще не предоставил заголовки или тело. Поскольку я хочу, чтобы тело было сообщением, сохраненным со статусом для каждого статуса, я буду динамически добавлять заголовок и тело при фактическом вызове конечной точки.

    Найти совпадающие статусы

    Этот код использует удобные функции, встроенные в библиотеку монитора, чтобы оглянуться на 2 минуты назад и найти все статусы, для которых установлено значение «крит:

    ».
      монитор.от (начало: -2м)
       |> фильтр (fn: (r) => r._level == "crit")  

    На следующих шагах я действительно буду запускать и записывать все совпадающие уведомления.

    Настройка задачи правила уведомления

    Как и при проверке состояния, библиотеке монитора в Flux требуются метаданные в определенном формате для работы функции уведомления. Я определяю это в этом объекте:

      rule = {
       _notification_rule_id: "notif-rule01xxxx",
       _notification_rule_name: "критическая влажность почвы",
       _notification_endpoint_id: "12345678

    456", _notification_endpoint_name: "критическая влажность почвы", }
    Уведомить

    Теперь я могу закончить работу и позвонить монитору.notify () функция. Мне просто нужно поставить:

    1. Метаданные, которые я определил для уведомления. Это используется, когда уведомление запускается для записи в InfluxDB, что произошло событие уведомления (и было ли уведомление успешно отправлено).
    2. Предоставьте функцию map (), которая возвращает заголовки и данные, которые я хочу отправить через http.post () в определенную мной конечную точку.
      монитор. От (начало: -2м)
       |> filter (fn: (r) => r._level == "крит")
       |> монитор.поставить в известность(
           данные: правило,
           конечная точка: конечная точка (
               mapFn: (r) => ({
                   заголовки: {"Авторизация": secrets.get (key: "pb_secret")},
                   данные: байты (v: r._message),
               }),
           ),
       )
       |> yield (name: "monitor.notify")  

    Когда я запускаю это, нет результатов.

    Это потому, что нет критических статусов. Тем не менее, я могу синтетически создать критический статус, чтобы получить результат:

    $ поток записи --bucket plantbuddy "почва_влажность, пользователь = rick, device_id = 01 чтение = 20i"

    Тогда я могу повторно запустить проверку.flux и notifcation_rule.flux и увидите, что мое приложение получило уведомление, а InfluxDB записал уведомление как отправленное.

    Еще раз, я думаю, что легче увидеть, как все это работает вместе, когда вы видите полное содержимое notification_rule.flux:

      импорт «Influxdata / Infxdb / monitor»
    импортировать "Influxdata / Infxdb / secrets"
    импортировать "http"
     
    option task = {
       name: "Правило уведомления SM",
       каждые: 1 м,
       смещение: 0 с,
    }
     
    rule = {
       _notification_rule_id: "notif-rule01xxxx",
       _notification_rule_name: "критическая влажность почвы",
       _notification_endpoint_id: "12345678

    456", _notification_endpoint_name: "критическая влажность почвы", } конечная точка = http.конечная точка (URL: "http://71.126.178.222:5000/notify") monitor.from (начало: -2м) |> filter (fn: (r) => r._level == "крит") |> monitor.notify ( данные: правило, конечная точка: конечная точка ( mapFn: (r) => ({ заголовки: {"Авторизация": secrets.get (key: "pb_secret")}, данные: байты (v: r._message), }), ), ) |> yield (name: "monitor.notify")
    Задача создания правила уведомления

    Наконец, чтобы закончить, мне нужно зарегистрировать правило уведомления как задачу с InfluxDB.Как и раньше, мне нужно создать параметр с именем «задача», чтобы система задач знала, как обрабатывать сценарий:

      option task = {
       name: "Правило уведомления SM",
       каждые: 1 м,
       смещение: 0 с,
    }  

    Тогда я могу просто создать задачу, как раньше.

      $ Infx task create -f notification_rule.flux
    ID Имя Организация ID Статус организации Каждый Cron
    0798c6de048d5000 Правило уведомления SM f1d35b5f11f06a1d [защита электронной почты] активно 1 мес.  

    Оперативный мониторинг

    Что касается моего бэкэнда InfluxDB, у меня теперь есть:

    1. Данные, поступающие в InfluxDB
    2. Выполняются 3 задачи: задача понижающей дискретизации, задача проверки пороговых значений и задача правила уведомления

    Как следить за правильностью работы серверной части? Это легко сделать, установив шаблон оперативного мониторинга в свою учетную запись.Обратите внимание, что вам нужно будет перейти с бесплатной учетной записи, чтобы иметь достаточную квоту корзины для установки шаблона.

    После установки шаблона я могу, например, использовать панель управления сводкой задач, чтобы убедиться, что все мои задачи выполняются нормально. Я могу продолжить создание проверок и уведомлений, которые могут предупредить меня (в отличие от моих пользователей), если возникнут какие-либо проблемы.

    археологов нашли следы табака и мексиканских бархатцев в древних флягах майя | Археология

    Группа археологов из США и Мексики обнаружила смеси табака и нетабачного растения, называемого мексиканскими ноготками ( Tagetes lucida ), в остатках, взятых из коллекции из 14 известных контейнеров в форме бутылок доколумбовых майя. как колбы.Открытие рисует более четкую картину практики употребления наркотиков древними майя и открывает путь для будущих исследований по изучению других типов психоактивных и непсихоактивных растений, которые курили, жевали или нюхали в народе майя и других доколумбийских обществах.

    Древний май обшитый панелями колба с узким отверстием (вверху), скульптурная колба с узким отверстием (внизу слева) и скульптурная колба с широким отверстием (внизу справа). Изображение предоставлено: Zimmermann et al ., DOI: 10.1038 / s41598-021-81158-у.

    Табак (род Nicotiana ) является наиболее продуктивным продуцентом никотина, но это соединение было обнаружено в более низких концентрациях в других родах растений.

    Виды Nicotiana также содержат психоактивные алкалоиды гармалы, гарман и норхарман, которые известны своим действием в таких препаратах, как аяуаска.

    Несмотря на то, что табак был широко задокументирован как лекарство и священное растение среди коренных американцев, он был просто частью гораздо большего комплекса психоактивных продуктов, включая растения, которые курили и которые в одиночку составляют десятки родов.

    В новом исследовании доктор Марио Циммерманн из факультета антропологии Вашингтонского государственного университета и его коллеги сосредоточились на табачных препаратах как на окне в способы употребления наркотиков.

    Они извлекли остатки из коллекции склянок доколумбовых майя и проанализировали их химический состав.

    Они использовали новый метод анализа, основанный на метаболомике, который может обнаруживать тысячи растительных соединений или метаболитов в остатках, собранных из контейнеров, труб, чаш и других археологических артефактов.

    «Хотя было установлено, что табак широко использовался в Америке до и после контакта, доказательства использования других растений в медицинских или религиозных целях остались в значительной степени неисследованными», - сказал д-р Циммерманн.

    «Новые методы анализа дают нам возможность исследовать употребление наркотиков в древнем мире, как никогда раньше».

    Ранее идентификация остатков древних растений основывалась на обнаружении ограниченного числа биомаркеров, таких как никотин, анабазин, котинин и кофеин.

    «Проблема в том, что, хотя присутствие такого биомаркера, как никотин, указывает на то, что табак курили, он не говорит вам, что еще было потреблено или сохранено в артефакте», - сказал профессор Дэвид Ганг, исследователь из Института биологических исследований. Химия в Университете штата Вашингтон.

    «Наш подход не только говорит вам, да, вы нашли интересующее вас растение, но он также может сказать вам, что еще потреблялось».

    Ученые определили присутствие в колбах майя мексиканских ноготков и двух видов сушеного и сушеного табака, Nicotiana tabacum и Nicotiana rustica .

    Они думают, что мексиканские ноготки были смешаны с табаком, чтобы курение было более приятным.

    «Мы расширяем границы археологической науки, чтобы мы могли лучше исследовать глубокие временные отношения людей с широким спектром психоактивных растений, которые употреблялись (и продолжают потребляться) людьми во всем мире», - сказал профессор Шеннон. Тушингем, научный сотрудник факультета антропологии Вашингтонского государственного университета.

    «Есть много гениальных способов, которыми люди управляют, используют, манипулируют и готовят местные растения и смеси растений, и археологи только начинают понимать, насколько древними были эти обычаи.”

    Результаты опубликованы в журнале Scientific Reports .

    _____

    М. Циммерманн и др. . 2021. Основанный на метаболомике анализ содержимого миниатюрных колб позволяет выявить употребление табачных смесей древними майя. Sci Rep 11, 1590; DOI: 10.1038 / s41598-021-81158-y

    Фляга с живыми орхидеями и пурпурным цимбидиумом, 1400 рупий / штука Darjeeling Gardens Private Limited

    Фляга с живыми орхидеями и фиолетовым цимбидиумом, 1400 рупий / штука Darjeeling Gardens Private Limited | ID: 23167742673

    Спецификация продукта

    Материал Орхидеи живые растения
    Цвет Фиолетовый
    Марка Darjeeling Gardens Pvt Limited
    Назначение Садоводство
    Количество цветов 14-16

    Заинтересовал этот товар? Получите последнюю цену у продавца

    Связаться с продавцом

    Изображение продукта


    О компании

    Год основания 2008

    Юридический статус компании с ограниченной ответственностью (Ltd./Pvt.Ltd.)

    Характер бизнеса Оптовый торговец

    Количество сотрудников от 26 до 50 человек

    Годовой оборот 50 лакх - 1 крор

    IndiaMART Участник с июля 2010 г.

    GST19AACCD9124D1ZT

    С момента основания в 2008 году мы, Darjeeling Gardens Private Limited , признаны в отрасли как одна из ведущих организаций, занимающихся оптовыми поставками широкого ассортимента цветов на срезку орхидей, растений орхидей, горшков цимбидиума. Растения, саженцы цветов и т. Д.Мы закупаем эти продукты у самых надежных и заслуживающих доверия заводчиков. Все усилия компании по обеспечению своих клиентов продуктами высочайшего качества позволили им построить долгосрочные деловые отношения со своими клиентами. Вернуться к началу 1

    Есть потребность?
    Получите лучшую цену

    1

    Есть потребность?
    Получите лучшую цену

    Культура растительных клеток во встряхиваемой колбе и их связь со скоростью переноса кислорода

    Культура растительных клеток представляет собой альтернативу биотехнологии для удовлетворения спроса на многие соединения для медицинской, пищевой и сельскохозяйственной промышленности.Исследования во встряхиваемых колбах необходимы перед культивированием клеток в биореакторе. Суспензионная культура клеток - лучший вариант, чем культивирование органов, для масштабирования процесса от встряхиваемой колбы до биореактора (Doran, 1999). Однако суспензионные культуры клеток некоторых видов растений нестабильны во встряхиваемых колбах, клетки снижают свою жизнеспособность без известной причины. В этой работе была проанализирована возможность того, что скорость переноса кислорода (OTR) во встряхиваемых колбах может быть недостаточной для удовлетворения потребности клетки в кислороде.Результаты, полученные в нашей лаборатории, показали, что клеточные линии Beta vulgaris (Rodrguez-Monroy and Galindo, 1999) и Uncaria tomentosa (Trejo-Tapia et al, 2007) можно культивировать во встряхиваемых колбах, закрытых алюминиевой фольгой. Напротив, культура Azadirachta indica постоянно теряет свою жизнеспособность и снижает pH в этих условиях, и необходимо периодически регенерировать новые суспензионные культуры из каллуса. Чтобы узнать потребность в кислороде для каждого вида, использовался биореактор с мешалкой и мешалкой с 45 наклонным рабочим колесом с 6 лопастями (400 об / мин) и 0.08 ввм аэрации. Кислород измеряли с помощью полярографического электрода. Культурные суспензии, полученные во встряхиваемых колбах, использовали для инокуляции биореактора. OUR был определен динамическим методом (Doran, 1995). Измерения проводили в первый час после инокуляции, и клетки подвергали условиям без ограничения кислорода (растворенный кислород более 30%). OUR был рассчитан с учетом изменения растворенного кислорода со временем и концентрации биомассы, присутствующей в биореакторе.Полученные значения OUR составили: A. indica 0,100, B. vulgaris 0,027 и U. tomentosa 0,026 кг O2 / (кг сухих клеток в день). Эти результаты показывают, что клетки A. indica потребляют в 4,5 раза больше кислорода, чем B. vulgaris или U. tomentosa. С другой стороны, OTR встряхиваемых колб определяли с использованием различных пробок, алюминиевой фольги и хлопка. Таким образом, общий коэффициент массопереноса кислорода (Ko) и максимальный OTR (OTRmax) колб были измерены во встряхиваемых колбах объемом 500 мл при 120 об / мин со 100 мл культуральной среды с использованием метода динамического выделения газа.Можно продемонстрировать, что Ko = kplug.kLa.H / (kplug.H + kLa), являясь kplug коэффициент переноса кислорода через заглушку, kLa коэффициент переноса кислорода через границу раздела газ-жидкость и H, константа закона Генри. . Кроме того, OTRmax = Ko.CO2 *, являясь CO2 * концентрацией кислорода в жидкой фазе в состоянии равновесия с воздухом при температуре системы. Ko составлял 0,42 и 3,51 ч-1, а OTRmax составлял 0,07 и 0,58 кг O2 / (м3. День) для алюминиевых и хлопчатобумажных укупорочных средств соответственно. Значения kLa и kplug показали, что основное сопротивление потоку кислорода было в пробке, а не на границе раздела жидкий газ, при использовании обоих типов закрытия.С помощью значений OTRmax можно оценить максимальный OUR для культуры с 10 кг сухих клеток / м3 во встряхиваемых колбах. Культуры могут иметь максимальный OUR во встряхиваемой колбе 0,007 и 0,058 кг O2 / (кг сухих клеток в день) для алюминиевого и хлопкового укупорочного средства соответственно. Сравнивая теоретический OUR, полученный во встряхиваемой колбе, с данными, измеренными в биореакторе для трех видов (0,026-0,100 кг O2 / (кг сухих клеток в день)), можно заметить, что измеренные значения были выше некоторых значений максимального OUR. во встряхиваемой колбе.Этот результат показал, что культуры трех видов культур во встряхиваемых колбах могут иметь ограничение по кислороду. Используя кислородный баланс, можно показать, что клетки A. indica должны снижать свой OUR ниже 0,100 кг O2 / (кг сухих клеток в день), когда они достигают концентрации биомассы 0,7 и 5,7 г DW / л во встряхиваемых колбах, закупоренных алюминием и хлопок соответственно. Эти результаты показывают, что культура клеток, потребляющая большое количество кислорода (A. indica), не могла адаптироваться к условиям ограничения кислорода с алюминиевой фольгой, а продукты ферментации в анаэробных условиях, такие как молочная кислота и этанол, могли быть причиной снижение pH.С другой стороны, клетки U. tomentosa должны снижать свой OUR ниже 0,026 кг O2 / (кг сухих клеток в день), когда они достигают концентрации биомассы 2,7 и 22,1 г DW / л во встряхиваемых колбах, заполненных алюминием и хлопком соответственно. С целью изучения изменений pH и жизнеспособности в субкультурах A. indica клетки этого вида выращивали во встряхиваемых колбах, закрытых алюминиевой фольгой и хлопком. Жизнеспособность клеток и pH оценивали в ходе 6 непрерывных субкультур. Результаты, полученные с встряхиваемыми колбами, закрытыми алюминиевой фольгой, показали, что pH снизился с 5.1 до значений ниже 4,0, тогда как в колбах с хлопком pH был выше 5,0. Жизнеспособность клеток снизилась с 78% до 16% в колбах с алюминием, тогда как культуры в колбах, заполненных хлопком, имели жизнеспособность выше 70%. Культурные суспензии культур с pH ниже 4,0 останавливали свой рост клеток. Культуры A. indica, полученные в этих условиях, имели очевидные различия в морфологии. Клетки, культивируемые в колбах с алюминиевой фольгой, состоят из агрегатов диаметром менее 1 мм, в то время как агломераты, растущие в колбах, закупоренных ватой, имеют диаметр от 3 до 10 мм.Возможно, меньший размер агломератов способствует лучшему переносу кислорода в условиях со слишком низким содержанием кислорода. Результаты, полученные в этой работе, согласуются с данными, сообщенными Гейгенбергером (2003), который показал, что ткани растений могут снижать потребление кислорода, когда внешняя концентрация кислорода падает до 0, когда внутренняя концентрация кислорода падает в ткани, даже в хорошо насыщенной кислородом атмосфере. Растения могут снижать дыхание, процесс биосинтеза, деградацию белка или изменять свою морфологию, чтобы избежать внутренней аноксии, и только когда концентрация кислорода близка к нулю, они активируют лактатдегидрогеназу и алкогольдегидрогеназу для производства анаэробного АТФ.В заключение, растительные клетки, культивируемые во встряхиваемой колбе, могут иметь ограничение по кислороду, поэтому в колбах, закрытых алюминиевой фольгой, а также в колбах, закрытых ватой. Если OTR, предлагаемый колбой, слишком низок, клетки могут снизить ее жизнеспособность, особенно если вид растения имеет более высокую скорость поглощения кислорода, как в случае с A. indica. Необходимо определенным образом анализировать потребление кислорода различными видами растений. Итак, если культура растительных клеток имеет высокое потребление кислорода, следует изучить влияние одного низкого OTR на первичный и вторичный метаболизм и его морфологию.Для увеличения OTR во встряхиваемых колбах может быть необходимо изменить укупорку или другие переменные, влияющие на OTR (например, объем культуральной среды в колбе или скорость перемешивания). Благодарности Ф. Ороско Сначез благодарит Secretara de Relaciones Exteriores из Мксико за присужденную докторскую стипендию. Рекомендации Гейгенбергер, П. Реакция метаболизма растений на недостаток кислорода. Curr. Opin. Plant Biol. 6: 247256 Доран, П. 1999. Разработка смесительных систем для суспензий растительных клеток в реакторах с мешалкой.Biotechnol. Прог. 15: 319-335. Доран, П. 1995. Принципы биотехнологической инженерии. Академическая пресса. Лондон. СОЕДИНЕННОЕ КОРОЛЕВСТВО. Родргес-Монрой, М. и Э. Галиндо.

    Похожие записи

    Детский массаж в Минске: польза, виды, техники и рекомендации специалистов

    Каковы основные преимущества детского массажа для здоровья и развития ребенка. Какие виды детского массажа наиболее эффективны для разных возрастов. Как […]

    Почему ребенок постоянно просит грудь: причины и решения

    Почему грудничок часто требует грудь. Какие причины заставляют ребенка постоянно висеть на груди. Как определить, достаточно ли малышу молока. Что […]

    Алфавит для иммунитета: укрепление защитных сил организма в сезон простуд

    Как витаминно-минеральный комплекс Алфавит помогает укрепить иммунитет. Какие компоненты входят в состав Алфавита. Для кого предназначен Алфавит в сезон простуд. […]

    Добавить комментарий

    Ваш адрес email не будет опубликован. Обязательные поля помечены *